AppTaskCan.c 39 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209
  1. /*
  2. * @Author: chenjie
  3. * @Date: 2022-10-27
  4. * @LastEditTime: 2022-10-28
  5. * @LastEditors: chenjie
  6. * @Description:
  7. * @FilePath: \S32K146_4G\code\app\AppTaskCan.c
  8. * Copyright (c) 2022 by chenjie, All Rights Reserved.
  9. */
  10. #include "AppTaskCan.h"
  11. #ifdef APP_CAN_ENABLE
  12. uint32 timerCANIdle = 0x00;
  13. uint32 timerCounterNow = 0;
  14. static uint8 BattSendFlg = 0;
  15. static void UDSAnsFunc(uint8 *rawData);
  16. static void UdsAns(bool PosFlg, uint8 UdsService, uint8 UdsSubService, uint8 Idx, uint8 *AnsData, uint8 AnsDataLen);
  17. static void BattSendFunc(void);
  18. static void vCanRxCallback(TimerHandle_t pxTimer)
  19. {
  20. uint32 ulTimerID;
  21. ulTimerID = (uint32)pvTimerGetTimerID(pxTimer);
  22. if (ulTimerID == 0)
  23. {
  24. Can_MainFunction_Read();
  25. timerCANIdle++;
  26. }
  27. }
  28. void CanTask(void *pvParameters)
  29. {
  30. uint32 timerCounterNow = 0;
  31. (void)pvParameters;
  32. CanIf_bRxFlag = false;
  33. Can_Msg_Type_Data CanRxMsg;
  34. CanRecvQueueHandle1 = xQueueCreate(100, sizeof(Can_Msg_Type_Data));
  35. TimerHandle_t monitorTimer1ms;
  36. monitorTimer1ms = xTimerCreate("monitor1ms", 1, pdTRUE, (void *)0, vCanRxCallback);
  37. xTimerStart(monitorTimer1ms, 0);
  38. BaseType_t ret = pdFALSE;
  39. GsensorInit();
  40. while (1)
  41. {
  42. do
  43. {
  44. memset(&CanRxMsg, 0, sizeof(CanRxMsg));
  45. ret = xQueueReceive(CanRecvQueueHandle1, &CanRxMsg, 1);
  46. if (ret == pdPASS)
  47. {
  48. timerCANIdle = 0x00;
  49. if (IsJumptoBootloader(CanRxMsg.id, CanRxMsg.data))
  50. {
  51. DoRoutinePositiveAnswer();
  52. RequestEnterBootloader();
  53. SystemSoftwareReset();
  54. break;
  55. }
  56. else
  57. {
  58. BcuDecodeFunction(CanRxMsg.id, CanRxMsg.data); // can协议解析
  59. }
  60. }
  61. if(/*CanRxMsg.id == 0x100 ||*/ timerCANIdle>20000)
  62. {
  63. timerCANIdle = 0;
  64. xSemaphoreGive(sleep_mutex);
  65. }
  66. } while (ret == pdPASS);
  67. // if (BattSendFlg)
  68. // {
  69. // BattSendFunc();
  70. // }
  71. if((TimerCounter - timerCounterNow)>=100)
  72. {
  73. BcuRxDiagnose();
  74. timerCounterNow = TimerCounter;
  75. SL_SC7A20_Read_XYZ_Data(xyzData);
  76. // ADC_ReadValue();
  77. }
  78. }
  79. }
  80. //注意解码超限问题
  81. void BcuDecodeFunction(uint32 ID, uint8 *rawData)
  82. {
  83. switch (ID)
  84. {
  85. case 0x1801D0F3:
  86. BMS_ReqVIN = (UINT8)(((*(UINT8 *)(rawData + 0))) & 0x3);
  87. BMS_ReqHVOff = (UINT8)(((*(UINT8 *)(rawData + 0)) >> 2) & 0x3);
  88. BcuRxFlag[0] = 0x01;
  89. break;
  90. case 0x1801D8F3:
  91. BMS_SoftwareVersion = (UINT16)(((*(UINT8 *)(rawData + 0)) | (*(UINT8 *)(rawData + 1) << 8)) & 0xFFFF);
  92. BMS_HardwareVersion = (UINT16)(((*(UINT8 *)(rawData + 2)) | (*(UINT8 *)(rawData + 3) << 8)) & 0xFFFF);
  93. BMS_ProtocolEditionH = (UINT8)(((*(UINT8 *)(rawData + 4))) & 0x3);
  94. BMS_ProtocolEditionL = (UINT8)(((*(UINT8 *)(rawData + 4)) >> 2) & 0xF);
  95. BcuRxFlag[1] = 0x01;
  96. break;
  97. case 0x1880D0F3:
  98. BMS_CharDevNum = (UINT8)(((*(UINT8 *)(rawData + 0))) & 0xF);
  99. BMS_FtPosRly = (UINT8)(((*(UINT8 *)(rawData + 0)) >> 4) & 0x1);
  100. BMS_FtNegRly = (UINT8)(((*(UINT8 *)(rawData + 0)) >> 5) & 0x1);
  101. BMS_FtPosCharRly1 = (UINT8)(((*(UINT8 *)(rawData + 0)) >> 6) & 0x1);
  102. BMS_FtNegCharRly1 = (UINT8)(((*(UINT8 *)(rawData + 0)) >> 7) & 0x1);
  103. BMS_FtPosCharRly2 = (UINT8)(((*(UINT8 *)(rawData + 1))) & 0x1);
  104. BMS_FtNegCharRly2 = (UINT8)(((*(UINT8 *)(rawData + 1)) >> 1) & 0x1);
  105. BMS_FtHeatRly1 = (UINT8)(((*(UINT8 *)(rawData + 1)) >> 2) & 0x1);
  106. BMS_FtHeatRly2 = (UINT8)(((*(UINT8 *)(rawData + 1)) >> 3) & 0x1);
  107. BMS_StPosRly = (UINT8)(((*(UINT8 *)(rawData + 1)) >> 4) & 0x3);
  108. BMS_StNegRly = (UINT8)(((*(UINT8 *)(rawData + 1)) >> 6) & 0x3);
  109. BMS_StPreCharRly = (UINT8)(((*(UINT8 *)(rawData + 2))) & 0x3);
  110. BMS_StPosCharRly1 = (UINT8)(((*(UINT8 *)(rawData + 2)) >> 2) & 0x3);
  111. BMS_StNegCharRly1 = (UINT8)(((*(UINT8 *)(rawData + 2)) >> 4) & 0x3);
  112. BMS_StPosCharRly2 = (UINT8)(((*(UINT8 *)(rawData + 2)) >> 6) & 0x3);
  113. BMS_StNegCharRly2 = (UINT8)(((*(UINT8 *)(rawData + 3))) & 0x3);
  114. BMS_FtAuxRelayWeld = (UINT8)(((*(UINT8 *)(rawData + 3)) >> 2) & 0x1);
  115. BMS_BraOpenCirc = (UINT8)(((*(UINT8 *)(rawData + 3)) >> 3) & 0x1);
  116. BMS_FtBackCharCurrOutLim = (UINT8)(((*(UINT8 *)(rawData + 3)) >> 4) & 0x3);
  117. BMS_FtPosRlyOpen = (UINT8)(((*(UINT8 *)(rawData + 3)) >> 6) & 0x1);
  118. BMS_FtNegRlyOpen = (UINT8)(((*(UINT8 *)(rawData + 3)) >> 7) & 0x1);
  119. BMS_FtPosCharRly1Open = (UINT8)(((*(UINT8 *)(rawData + 4))) & 0x1);
  120. BMS_FtPosCharRly2Open = (UINT8)(((*(UINT8 *)(rawData + 4)) >> 1) & 0x1);
  121. BMS_FtNegCharRly1Open = (UINT8)(((*(UINT8 *)(rawData + 4)) >> 2) & 0x1);
  122. BMS_FtNegCharRly2Open = (UINT8)(((*(UINT8 *)(rawData + 4)) >> 3) & 0x1);
  123. BMS_FtTMSContClose = (UINT8)(((*(UINT8 *)(rawData + 4)) >> 4) & 0x1);
  124. BMS_FtTMSContOpen = (UINT8)(((*(UINT8 *)(rawData + 4)) >> 5) & 0x1);
  125. BMS_FtTMS = (UINT8)(((*(UINT8 *)(rawData + 4)) >> 6) & 0x1);
  126. BMS_Ft24VSpy = (UINT8)(((*(UINT8 *)(rawData + 4)) >> 7) & 0x1);
  127. BMS_FtPACKSelfProt = (UINT8)(((*(UINT8 *)(rawData + 5))) & 0x1);
  128. BMS_FtCharSockTempOver = (UINT8)(((*(UINT8 *)(rawData + 5)) >> 1) & 0x3);
  129. BMS_FtTempOutCtrl = (UINT8)(((*(UINT8 *)(rawData + 5)) >> 3) & 0x1);
  130. BMS_StPosHeatRly = (UINT8)(((*(UINT8 *)(rawData + 5)) >> 4) & 0x3);
  131. BMS_StNegHeatRly = (UINT8)(((*(UINT8 *)(rawData + 5)) >> 6) & 0x3);
  132. BMS_CharSysNum = (UINT8)(((*(UINT8 *)(rawData + 6))) & 0xF);
  133. BMS_FtCode = (UINT8)(((*(UINT8 *)(rawData + 7))) & 0xFF);
  134. BcuRxFlag[2] = 0x01;
  135. break;
  136. case 0x1881D0F3:
  137. BMS_ST1CheckSum = (UINT8)(((*(UINT8 *)(rawData + 0))) & 0xFF);
  138. BMS_ST1Counter = (UINT8)(((*(UINT8 *)(rawData + 1))) & 0xF);
  139. BMS_Mode = (UINT8)(((*(UINT8 *)(rawData + 1)) >> 4) & 0x3);
  140. BMS_AuxRlySt = (UINT8)(((*(UINT8 *)(rawData + 1)) >> 6) & 0x1);
  141. BMS_BattBalaSt = (UINT8)(((*(UINT8 *)(rawData + 1)) >> 7) & 0x1);
  142. BMS_CharGunSt = (UINT8)(((*(UINT8 *)(rawData + 2))) & 0x1);
  143. BMS_CharMode = (UINT8)(((*(UINT8 *)(rawData + 2)) >> 1) & 0x3);
  144. BMS_CharSt = (UINT8)(((*(UINT8 *)(rawData + 2)) >> 3) & 0x3);
  145. BMS_FtLvl = (UINT8)(((*(UINT8 *)(rawData + 2)) >> 5) & 0x3);
  146. BMS_FtCellTempDiff = (UINT8)(((*(UINT8 *)(rawData + 3))) & 0x3);
  147. BMS_FtCellTempHigh = (UINT8)(((*(UINT8 *)(rawData + 3)) >> 2) & 0x3);
  148. BMS_FtPACKOverVolt = (UINT8)(((*(UINT8 *)(rawData + 3)) >> 4) & 0x3);
  149. BMS_FtPACKUndeVolt = (UINT8)(((*(UINT8 *)(rawData + 3)) >> 6) & 0x3);
  150. BMS_FtSOCLow = (UINT8)(((*(UINT8 *)(rawData + 4))) & 0x3);
  151. BMS_FtCellOverVolt = (UINT8)(((*(UINT8 *)(rawData + 4)) >> 2) & 0x3);
  152. BMS_FtCellUndeVolt = (UINT8)(((*(UINT8 *)(rawData + 4)) >> 4) & 0x3);
  153. BMS_FtIns = (UINT8)(((*(UINT8 *)(rawData + 4)) >> 6) & 0x3);
  154. BMS_FtCellOverVoltDiff = (UINT8)(((*(UINT8 *)(rawData + 5))) & 0x3);
  155. BMS_FtCharCurrOver = (UINT8)(((*(UINT8 *)(rawData + 5)) >> 2) & 0x3);
  156. BMS_FtDisCharCurrOver = (UINT8)(((*(UINT8 *)(rawData + 5)) >> 4) & 0x3);
  157. BMS_FtCellTempLow = (UINT8)(((*(UINT8 *)(rawData + 5)) >> 6) & 0x3);
  158. BMS_FtBranVoltDifOver = (UINT8)(((*(UINT8 *)(rawData + 6))) & 0x3);
  159. BMS_FtBMSHardWare = (UINT8)(((*(UINT8 *)(rawData + 6)) >> 2) & 0x3);
  160. BMS_FtSOCHigh = (UINT8)(((*(UINT8 *)(rawData + 6)) >> 4) & 0x1);
  161. BMS_FtSOCJump = (UINT8)(((*(UINT8 *)(rawData + 6)) >> 5) & 0x1);
  162. BMS_FtInCom = (UINT8)(((*(UINT8 *)(rawData + 6)) >> 6) & 0x1);
  163. BMS_FtSysMism = (UINT8)(((*(UINT8 *)(rawData + 6)) >> 7) & 0x1);
  164. BMS_FtHvIntLock = (UINT8)(((*(UINT8 *)(rawData + 7))) & 0x1);
  165. BMS_FtSmoke = (UINT8)(((*(UINT8 *)(rawData + 7)) >> 1) & 0x1);
  166. BMS_FtFire = (UINT8)(((*(UINT8 *)(rawData + 7)) >> 2) & 0x1);
  167. BMS_FtNum = (UINT8)(((*(UINT8 *)(rawData + 7)) >> 3) & 0x1F);
  168. BcuRxFlag[3] = 0x01;
  169. break;
  170. case 0x1882D0F3:
  171. BMS_PackSOC = (UINT8)(((*(UINT8 *)(rawData + 0))) & 0xFF);
  172. BMS_PackSOH = (UINT8)(((*(UINT8 *)(rawData + 1))) & 0xFF);
  173. BMS_PackCurr = (UINT16)(((*(UINT8 *)(rawData + 2)) | (*(UINT8 *)(rawData + 3) << 8)) & 0xFFFF);
  174. BMS_MaxCharCurr = (UINT16)(((*(UINT8 *)(rawData + 4)) | (*(UINT8 *)(rawData + 5) << 8)) & 0xFFFF);
  175. BMS_MaxDisCharCurr = (UINT16)(((*(UINT8 *)(rawData + 6)) | (*(UINT8 *)(rawData + 7) << 8)) & 0xFFFF);
  176. BcuRxFlag[4] = 0x01;
  177. break;
  178. case 0x1883D0F3:
  179. BMS_PosIns = (UINT16)(((*(UINT8 *)(rawData + 0)) | (*(UINT8 *)(rawData + 1) << 8)) & 0xFFFF);
  180. BMS_NegIns = (UINT16)(((*(UINT8 *)(rawData + 2)) | (*(UINT8 *)(rawData + 3) << 8)) & 0xFFFF);
  181. BMS_BattVolt = (UINT16)(((*(UINT8 *)(rawData + 4)) | (*(UINT8 *)(rawData + 5) << 8)) & 0xFFFF);
  182. BMS_LinkVolt = (UINT16)(((*(UINT8 *)(rawData + 6)) | (*(UINT8 *)(rawData + 7) << 8)) & 0xFFFF);
  183. BcuRxFlag[5] = 0x01;
  184. break;
  185. case 0x1884D0F3:
  186. BMS_MaxCellTemp = (UINT8)(((*(UINT8 *)(rawData + 0))) & 0xFF);
  187. BMS_MinCellTemp = (UINT8)(((*(UINT8 *)(rawData + 1))) & 0xFF);
  188. BMS_AverCellTemp = (UINT8)(((*(UINT8 *)(rawData + 2))) & 0xFF);
  189. BMS_MaxCellTempCSC = (UINT8)(((*(UINT8 *)(rawData + 3))) & 0xFF);
  190. BMS_MaxCellTempNum = (UINT8)(((*(UINT8 *)(rawData + 4))) & 0xFF);
  191. BMS_MinCellTempCSC = (UINT8)(((*(UINT8 *)(rawData + 5))) & 0xFF);
  192. BMS_MinCellTempNum = (UINT8)(((*(UINT8 *)(rawData + 6))) & 0xFF);
  193. BcuRxFlag[6] = 0x01;
  194. break;
  195. case 0x1885D0F3:
  196. BMS_MaxCellVolt = (UINT16)(((*(UINT8 *)(rawData + 0)) | (*(UINT8 *)(rawData + 1) << 8)) & 0xFFFF);
  197. BMS_MaxCellVoltCSC = (UINT8)(((*(UINT8 *)(rawData + 2))) & 0xFF);
  198. BMS_MaxCellVoltNum = (UINT8)(((*(UINT8 *)(rawData + 3))) & 0xFF);
  199. BMS_AverCellVolt = (UINT16)(((*(UINT8 *)(rawData + 4)) | (*(UINT8 *)(rawData + 5) << 8)) & 0xFFFF);
  200. BcuRxFlag[7] = 0x01;
  201. break;
  202. case 0x1886D0F3:
  203. BMS_MinCellVolt = (UINT16)(((*(UINT8 *)(rawData + 0)) | (*(UINT8 *)(rawData + 1) << 8)) & 0xFFFF);
  204. BMS_MinCellVoltCSC = (UINT8)(((*(UINT8 *)(rawData + 2))) & 0xFF);
  205. BMS_MinCellVoltNum = (UINT8)(((*(UINT8 *)(rawData + 3))) & 0xFF);
  206. BMS_ContChrgCurr = (UINT16)(((*(UINT8 *)(rawData + 4)) | (*(UINT8 *)(rawData + 5) << 8)) & 0xFFFF);
  207. BMS_ContDisCharCurr = (UINT16)(((*(UINT8 *)(rawData + 6)) | (*(UINT8 *)(rawData + 7) << 8)) & 0xFFFF);
  208. BcuRxFlag[8] = 0x01;
  209. break;
  210. case 0x1887D0F3:
  211. BMS_CharReqVolt = (UINT16)(((*(UINT8 *)(rawData + 0)) | (*(UINT8 *)(rawData + 1) << 8)) & 0xFFFF);
  212. BMS_CharReqCurr = (UINT16)(((*(UINT8 *)(rawData + 2)) | (*(UINT8 *)(rawData + 3) << 8)) & 0xFFFF);
  213. BMS_SysInsRes = (UINT16)(((*(UINT8 *)(rawData + 4)) | (*(UINT8 *)(rawData + 5) << 8)) & 0xFFFF);
  214. BMS_InsDeteSt = (UINT8)(((*(UINT8 *)(rawData + 6))) & 0x1);
  215. BMS_FtCharInsLow = (UINT8)(((*(UINT8 *)(rawData + 6)) >> 1) & 0x1);
  216. BMS_FtCurrSenr = (UINT8)(((*(UINT8 *)(rawData + 6)) >> 2) & 0x1);
  217. BMS_FtHeatingFilm = (UINT8)(((*(UINT8 *)(rawData + 6)) >> 3) & 0x1);
  218. BMS_FtMainLoopPreChar = (UINT8)(((*(UINT8 *)(rawData + 6)) >> 4) & 0x1);
  219. BMS_FtAuxLoopPreChar = (UINT8)(((*(UINT8 *)(rawData + 6)) >> 5) & 0x1);
  220. BMS_FtACANLost = (UINT8)(((*(UINT8 *)(rawData + 6)) >> 6) & 0x1);
  221. BMS_FtDCDC = (UINT8)(((*(UINT8 *)(rawData + 6)) >> 7) & 0x1);
  222. BMS_FtSOCDif = (UINT8)(((*(UINT8 *)(rawData + 7))) & 0x1);
  223. BMS_FtCellOverDisChar = (UINT8)(((*(UINT8 *)(rawData + 7)) >> 1) & 0x1);
  224. BMS_FtCharOver = (UINT8)(((*(UINT8 *)(rawData + 7)) >> 2) & 0x3);
  225. BMS_FtContDisCharCurrOverLoad = (UINT8)(((*(UINT8 *)(rawData + 7)) >> 4) & 0x3);
  226. BMS_FtContCharCurrOverLoad = (UINT8)(((*(UINT8 *)(rawData + 7)) >> 6) & 0x3);
  227. BcuRxFlag[9] = 0x01;
  228. break;
  229. case 0x1888D0F3:
  230. BMS_MaxDisCharPwr = (UINT16)(((*(UINT8 *)(rawData + 0)) | (*(UINT8 *)(rawData + 1) << 8)) & 0xFFFF);
  231. BMS_MaxCharPwr = (UINT16)(((*(UINT8 *)(rawData + 2)) | (*(UINT8 *)(rawData + 3) << 8)) & 0xFFFF);
  232. BMS_ContDisCharPwr = (UINT16)(((*(UINT8 *)(rawData + 4)) | (*(UINT8 *)(rawData + 5) << 8)) & 0xFFFF);
  233. BMS_ContCharPwr = (UINT16)(((*(UINT8 *)(rawData + 6)) | (*(UINT8 *)(rawData + 7) << 8)) & 0xFFFF);
  234. BcuRxFlag[10] = 0x01;
  235. break;
  236. case 0x1889D0F3:
  237. BMS_InstEngyCons = (UINT16)(((*(UINT8 *)(rawData + 0)) | (*(UINT8 *)(rawData + 1) << 8)) & 0xFFFF);
  238. BMS_TotalEngyCons = (UINT16)(((*(UINT8 *)(rawData + 2)) | (*(UINT8 *)(rawData + 3) << 8)) & 0xFFFF);
  239. BMS_SOE = (UINT16)(((*(UINT8 *)(rawData + 4)) | (*(UINT8 *)(rawData + 5) << 8)) & 0xFFFF);
  240. BMS_RmanCharTime = (UINT16)(((*(UINT8 *)(rawData + 6)) | (*(UINT8 *)(rawData + 7) << 8)) & 0xFFFF);
  241. BcuRxFlag[11] = 0x01;
  242. break;
  243. case 0x188AD0F3:
  244. BMS_Gun1DCNegTemp = (UINT8)(((*(UINT8 *)(rawData + 0))) & 0xFF);
  245. BMS_Gun1DCPosTemp = (UINT8)(((*(UINT8 *)(rawData + 1))) & 0xFF);
  246. BMS_Gun2DCNegTemp = (UINT8)(((*(UINT8 *)(rawData + 2))) & 0xFF);
  247. BMS_Gun2DCPosTemp = (UINT8)(((*(UINT8 *)(rawData + 3))) & 0xFF);
  248. BMS_CurrHeatSt = (UINT8)(((*(UINT8 *)(rawData + 4))) & 0x3);
  249. BMS_CurrCoolSt = (UINT8)(((*(UINT8 *)(rawData + 4)) >> 2) & 0x3);
  250. BMS_FtCharCnct = (UINT8)(((*(UINT8 *)(rawData + 4)) >> 4) & 0x1);
  251. BMS_FtOverDisCharCurrDuringChar = (UINT8)(((*(UINT8 *)(rawData + 4)) >> 5) & 0x1);
  252. BMS_FtCharNTC = (UINT8)(((*(UINT8 *)(rawData + 4)) >> 6) & 0x1);
  253. BMS_FtELock = (UINT8)(((*(UINT8 *)(rawData + 4)) >> 7) & 0x1);
  254. BMS_CharNum = (UINT16)(((*(UINT8 *)(rawData + 5)) | (*(UINT8 *)(rawData + 6) << 8)) & 0xFFFF);
  255. BcuRxFlag[12] = 0x01;
  256. break;
  257. case 0x18C1D0F3:
  258. BMS_CellVoltFramNum = (UINT8)(((*(UINT8 *)(rawData + 0))) & 0xFF);
  259. BMS_CSC_Code = (UINT8)(((*(UINT8 *)(rawData + 1))) & 0xFF);
  260. if (BMS_CellVoltFramNum == 0 || BMS_CellVoltFramNum > 128)
  261. {
  262. break;
  263. }
  264. for (UINT8 i = 0; i < 3; i++)
  265. {
  266. BMS_CellVolt[(BMS_CellVoltFramNum - 1) * 3 + i] = (UINT16)(((*(UINT8 *)(rawData + i * 2 + 2)) | (*(UINT8 *)(rawData + i * 2 + 3) << 8)) & 0xFFFF);
  267. }
  268. BcuRxFlag[13] = 0x01;
  269. break;
  270. case 0x18C2D0F3:
  271. BMS_CellTempFramNum = (UINT8)(((*(UINT8 *)(rawData + 0))) & 0xFF);
  272. BMS_CSC_Code = (UINT8)(((*(UINT8 *)(rawData + 1))) & 0xFF);
  273. if (BMS_CellTempFramNum == 0 || BMS_CellTempFramNum > 12)
  274. {
  275. break;
  276. }
  277. for (UINT8 i = 0; i < 6; i++)
  278. {
  279. if (((BMS_CellTempFramNum - 1) * 6 + i) < sizeof(BMS_CellTemp))
  280. {
  281. BMS_CellTemp[(BMS_CellTempFramNum - 1) * 6 + i] = (UINT8)(((*(UINT8 *)(rawData + 2 + i))) & 0xFF);
  282. if(BMS_CellTemp[(BMS_CellTempFramNum - 1) * 6 + i] <= (0xFF - 10) && BMS_CellTemp[(BMS_CellTempFramNum - 1) * 6 + i] >= 10)
  283. {
  284. BMS_CellTemp[(BMS_CellTempFramNum - 1) * 6 + i] = BMS_CellTemp[(BMS_CellTempFramNum - 1) * 6 + i] - 10; //the tcp offset is -40, while the can message offset is -50
  285. }
  286. }
  287. }
  288. BcuRxFlag[14] = 0x01;
  289. break;
  290. case 0x18E1D0F3:
  291. BMS_Checksum = 0;
  292. for (UINT8 i = 1; i < 8; i++)
  293. {
  294. BMS_Checksum = (UINT8)(((*(UINT8 *)(rawData + i))) & 0xFF) ^ BMS_Checksum;
  295. }
  296. if (BMS_Checksum == (UINT8)(((*(UINT8 *)(rawData + 0))) & 0xFF))
  297. {
  298. BMS_PackComp = (UINT8)(((*(UINT8 *)(rawData + 1))) & 0x7);
  299. BMS_BattCodeLeng = (UINT8)(((*(UINT8 *)(rawData + 1)) >> 3) & 0x1F);
  300. BMS_SN[0] = (UINT8)(((*(UINT8 *)(rawData + 2))) & 0xFF);
  301. BMS_SN[1] = (UINT8)(((*(UINT8 *)(rawData + 3))) & 0xFF);
  302. BMS_SN[2] = (UINT8)(((*(UINT8 *)(rawData + 4))) & 0xFF);
  303. BMS_SN[3] = (UINT8)(((*(UINT8 *)(rawData + 5))) & 0xFF);
  304. BMS_SN[4] = (UINT8)(((*(UINT8 *)(rawData + 6))) & 0xFF);
  305. BMS_SN[5] = (UINT8)(((*(UINT8 *)(rawData + 7))) & 0xFF);
  306. }
  307. BcuRxFlag[15] = 0x01;
  308. break;
  309. case 0x18E2D0F3:
  310. BMS_Checksum = 0;
  311. for (UINT8 i = 1; i < 8; i++)
  312. {
  313. BMS_Checksum = (UINT8)(((*(UINT8 *)(rawData + i))) & 0xFF) ^ BMS_Checksum;
  314. }
  315. if (BMS_Checksum == (UINT8)(((*(UINT8 *)(rawData + 0))) & 0xFF))
  316. {
  317. BMS_SN[6] = (UINT8)(((*(UINT8 *)(rawData + 1))) & 0xFF);
  318. BMS_SN[7] = (UINT8)(((*(UINT8 *)(rawData + 2))) & 0xFF);
  319. BMS_SN[8] = (UINT8)(((*(UINT8 *)(rawData + 3))) & 0xFF);
  320. BMS_SN[9] = (UINT8)(((*(UINT8 *)(rawData + 4))) & 0xFF);
  321. BMS_SN[10] = (UINT8)(((*(UINT8 *)(rawData + 5))) & 0xFF);
  322. BMS_SN[11] = (UINT8)(((*(UINT8 *)(rawData + 6))) & 0xFF);
  323. BMS_SN[12] = (UINT8)(((*(UINT8 *)(rawData + 7))) & 0xFF);
  324. }
  325. BcuRxFlag[16] = 0x01;
  326. break;
  327. case 0x18E3D0F3:
  328. BMS_Checksum = 0;
  329. for (UINT8 i = 1; i < 8; i++)
  330. {
  331. BMS_Checksum = (UINT8)(((*(UINT8 *)(rawData + i))) & 0xFF) ^ BMS_Checksum;
  332. }
  333. if (BMS_Checksum == (UINT8)(((*(UINT8 *)(rawData + 0))) & 0xFF))
  334. {
  335. BMS_SN[13] = (UINT8)(((*(UINT8 *)(rawData + 1))) & 0xFF);
  336. BMS_SN[14] = (UINT8)(((*(UINT8 *)(rawData + 2))) & 0xFF);
  337. BMS_SN[15] = (UINT8)(((*(UINT8 *)(rawData + 3))) & 0xFF);
  338. BMS_SN[16] = (UINT8)(((*(UINT8 *)(rawData + 4))) & 0xFF);
  339. BMS_SN[17] = (UINT8)(((*(UINT8 *)(rawData + 5))) & 0xFF);
  340. BMS_SN[18] = (UINT8)(((*(UINT8 *)(rawData + 6))) & 0xFF);
  341. BMS_SN[19] = (UINT8)(((*(UINT8 *)(rawData + 7))) & 0xFF);
  342. }
  343. BcuRxFlag[17] = 0x01;
  344. break;
  345. case 0x18E4D0F3:
  346. BMS_Checksum = 0;
  347. for (UINT8 i = 1; i < 8; i++)
  348. {
  349. BMS_Checksum = (UINT8)(((*(UINT8 *)(rawData + i))) & 0xFF) ^ BMS_Checksum;
  350. }
  351. if (BMS_Checksum == (UINT8)(((*(UINT8 *)(rawData + 0))) & 0xFF))
  352. {
  353. BMS_SN[20] = (UINT8)(((*(UINT8 *)(rawData + 1))) & 0xFF);
  354. BMS_SN[21] = (UINT8)(((*(UINT8 *)(rawData + 2))) & 0xFF);
  355. BMS_SN[22] = (UINT8)(((*(UINT8 *)(rawData + 3))) & 0xFF);
  356. BMS_SN[23] = (UINT8)(((*(UINT8 *)(rawData + 4))) & 0xFF);
  357. BMS_SN[24] = (UINT8)(((*(UINT8 *)(rawData + 5))) & 0xFF);
  358. BMS_SN[25] = (UINT8)(((*(UINT8 *)(rawData + 6))) & 0xFF);
  359. BMS_SN[26] = (UINT8)(((*(UINT8 *)(rawData + 7))) & 0xFF);
  360. }
  361. BcuRxFlag[18] = 0x01;
  362. break;
  363. case 0x18E5D0F3:
  364. BMS_BattRateCap = (UINT16)(((*(UINT8 *)(rawData + 0)) | (*(UINT8 *)(rawData + 1) << 8)) & 0xFFFF);
  365. BMS_BattRateVolt = (UINT16)(((*(UINT8 *)(rawData + 2)) | (*(UINT8 *)(rawData + 3) << 8)) & 0xFFFF);
  366. BMS_BattRateEngy = (UINT16)(((*(UINT8 *)(rawData + 4)) | (*(UINT8 *)(rawData + 5) << 8)) & 0xFFFF);
  367. BMS_BattType = (UINT8)(((*(UINT8 *)(rawData + 6))) & 0xF);
  368. BMS_CoolType = (UINT8)(((*(UINT8 *)(rawData + 6)) >> 4) & 0x3);
  369. BcuRxFlag[19] = 0x01;
  370. break;
  371. case 0x18E6D0F3:
  372. BMS_CSC_Total = (UINT8)(((*(UINT8 *)(rawData + 0))) & 0xFF);
  373. BMS_CellTotal = (UINT16)(((*(UINT8 *)(rawData + 1)) | (*(UINT8 *)(rawData + 2) << 8)) & 0xFFFF);
  374. BMS_TempTotal = (UINT16)(((*(UINT8 *)(rawData + 3)) | (*(UINT8 *)(rawData + 4) << 8)) & 0xFFFF);
  375. BMS_CellVoltLevel = (UINT8)(((*(UINT8 *)(rawData + 5))) & 0xFF);
  376. BMS_CellMinVolt = (UINT8)(((*(UINT8 *)(rawData + 6))) & 0xFF);
  377. BMS_CellMaxVolt = (UINT8)(((*(UINT8 *)(rawData + 7))) & 0xFF);
  378. BcuRxFlag[20] = 0x01;
  379. break;
  380. case 0x18F1D0F3:
  381. BMS_TotalCharEngy = (UINT32)(((*(UINT8 *)(rawData + 0)) | (*(UINT8 *)(rawData + 1) << 8) | (*(UINT8 *)(rawData + 2) << 16) | (*(UINT8 *)(rawData + 3) << 24)) & 0xFFFFFF);
  382. BMS_TotalDisCharEngy = (UINT32)(((*(UINT8 *)(rawData + 3)) | (*(UINT8 *)(rawData + 4) << 8) | (*(UINT8 *)(rawData + 5) << 16) | (*(UINT8 *)(rawData + 6) << 24)) & 0xFFFFFF);
  383. BMS_SingleCharEngy = (UINT16)(((*(UINT8 *)(rawData + 6)) | (*(UINT8 *)(rawData + 7) << 8)) & 0xFFFF);
  384. BcuRxFlag[21] = 0x01;
  385. break;
  386. case 0x18F2D0F3:
  387. BMS_TotalBackCharEngy = (UINT32)(((*(UINT8 *)(rawData + 0)) | (*(UINT8 *)(rawData + 1) << 8) | (*(UINT8 *)(rawData + 2) << 16) | (*(UINT8 *)(rawData + 3) << 24)) & 0xFFFFFF);
  388. BMS_TotalStaCharEngy = (UINT32)(((*(UINT8 *)(rawData + 3)) | (*(UINT8 *)(rawData + 4) << 8) | (*(UINT8 *)(rawData + 5) << 16) | (*(UINT8 *)(rawData + 6) << 24)) & 0xFFFFFF);
  389. BcuRxFlag[22] = 0x01;
  390. break;
  391. case 0x18F3D0F3:
  392. BMS_TotalGunCharEngy = (UINT32)(((*(UINT8 *)(rawData + 0)) | (*(UINT8 *)(rawData + 1) << 8) | (*(UINT8 *)(rawData + 2) << 16) | (*(UINT8 *)(rawData + 3) << 24)) & 0xFFFFFF);
  393. BMS_TotalGunCharCapy = (UINT32)(((*(UINT8 *)(rawData + 3)) | (*(UINT8 *)(rawData + 4) << 8) | (*(UINT8 *)(rawData + 5) << 16) | (*(UINT8 *)(rawData + 6) << 24)) & 0xFFFFFF);
  394. BcuRxFlag[23] = 0x01;
  395. break;
  396. case 0x18F4D0F3:
  397. BMS_TotalCharCapy = (UINT32)(((*(UINT8 *)(rawData + 0)) | (*(UINT8 *)(rawData + 1) << 8) | (*(UINT8 *)(rawData + 2) << 16) | (*(UINT8 *)(rawData + 3) << 24)) & 0xFFFFFF);
  398. BMS_TotalDisCharCapy = (UINT32)(((*(UINT8 *)(rawData + 3)) | (*(UINT8 *)(rawData + 4) << 8) | (*(UINT8 *)(rawData + 5) << 16) | (*(UINT8 *)(rawData + 6) << 24)) & 0xFFFFFF);
  399. BMS_SingleCharCapy = (UINT16)(((*(UINT8 *)(rawData + 6)) | (*(UINT8 *)(rawData + 7) << 8)) & 0xFFFF);
  400. BcuRxFlag[24] = 0x01;
  401. break;
  402. case 0x18F5D0F3:
  403. BMS_TotalBackCharCapy = (UINT32)(((*(UINT8 *)(rawData + 0)) | (*(UINT8 *)(rawData + 1) << 8) | (*(UINT8 *)(rawData + 2) << 16) | (*(UINT8 *)(rawData + 3) << 24)) & 0xFFFFFF);
  404. BMS_TotalStaCharCapy = (UINT32)(((*(UINT8 *)(rawData + 3)) | (*(UINT8 *)(rawData + 4) << 8) | (*(UINT8 *)(rawData + 5) << 16) | (*(UINT8 *)(rawData + 6) << 24)) & 0xFFFFFF);
  405. BMS_HVBranNum = (UINT8)(((*(UINT8 *)(rawData + 6))) & 0xFF);
  406. BMS_SingleHVBranchCellNum = (UINT8)(((*(UINT8 *)(rawData + 7))) & 0xFF);
  407. BcuRxFlag[25] = 0x01;
  408. break;
  409. case 0x18FF45F4:
  410. BMS_ReqMode = (UINT8)(((*(UINT8 *)(rawData + 0))) & 0x3);
  411. BMS_HVCmd = (UINT8)(((*(UINT8 *)(rawData + 0)) >> 2) & 0x3);
  412. BMS_ChgSts = (UINT8)(((*(UINT8 *)(rawData + 0)) >> 4) & 0x3);
  413. BMS_HVRelaySts = (UINT8)(((*(UINT8 *)(rawData + 0)) >> 6) & 0x3);
  414. BMS_HVVolt = (UINT16)(((*(UINT8 *)(rawData + 1)) | (*(UINT8 *)(rawData + 2) << 8)) & 0xFFFF);
  415. BMS_SetTemp = (UINT8)(((*(UINT8 *)(rawData + 4))) & 0xFF);
  416. BMS_Life = (UINT8)(((*(UINT8 *)(rawData + 6))) & 0xFF);
  417. BMS_CRC = (UINT8)(((*(UINT8 *)(rawData + 7))) & 0xFF);
  418. BcuRxFlag[26] = 0x01;
  419. break;
  420. case 0x18FFC13A:
  421. TMS_WorkStatus = (UINT8)(((*(UINT8 *)(rawData + 0))) & 0x3);
  422. TMS_HVRelayST = (UINT8)(((*(UINT8 *)(rawData + 0)) >> 2) & 0x3);
  423. TMS_OutletTemp = (UINT8)(((*(UINT8 *)(rawData + 1))) & 0xFF);
  424. TMS_InletTemp = (UINT8)(((*(UINT8 *)(rawData + 2))) & 0xFF);
  425. TMS_ReqPow = (UINT16)(((*(UINT8 *)(rawData + 5)) | (*(UINT8 *)(rawData + 6) << 8)) & 0xFFFF);
  426. TMS_ErrCode = (UINT8)(((*(UINT8 *)(rawData + 7))) & 0x3F);
  427. TMS_FaultLevel = (UINT8)(((*(UINT8 *)(rawData + 7)) >> 6) & 0x3);
  428. BcuRxFlag[27] = 0x01;
  429. break;
  430. case 0x1C00EDEA:
  431. UDSAnsFunc(rawData);
  432. break;
  433. default:
  434. break;
  435. }
  436. }
  437. static void UDSAnsFunc(uint8 *rawData)
  438. {
  439. static uint8 UdsStates = 1;
  440. uint8 Data[8] = {0};
  441. memcpy(Data, rawData, 8);
  442. uint8 UdsService = 0;
  443. uint8 UdsSubService = 0;
  444. UdsService = Data[0];
  445. UdsSubService = Data[1];
  446. uint8 AnsData[24] = {0};
  447. static uint8 deviceSnRecvFlg = 0;
  448. switch (UdsService)
  449. {
  450. case 0x10: //模式切换
  451. {
  452. if (UdsSubService == 0x01)
  453. {
  454. UdsStates = 0x01; //关闭UDS诊断
  455. UdsAns(true, UdsService, UdsSubService, 0x00, NULL, 0);
  456. }
  457. else if (UdsSubService == 0x02)
  458. {
  459. if (UdsStates == 0x01 || UdsStates == 0x02)
  460. {
  461. UdsStates = 0x02; //打开UDS诊断
  462. UdsAns(true, UdsService, UdsSubService, 0x00, NULL, 0);
  463. }
  464. else
  465. {
  466. UdsAns(false, UdsService, UdsSubService, 0x00, NULL, 0);
  467. }
  468. }
  469. break;
  470. }
  471. case 0x11://控制
  472. {
  473. if(UdsStates==0x02)
  474. {
  475. switch(UdsSubService)
  476. {
  477. case 0x01://重启
  478. {
  479. AnsData[0] = AppSwVersion>>24;
  480. AnsData[1] = AppSwVersion>>16;
  481. AnsData[2] = AppSwVersion>>8;
  482. AnsData[3] = AppSwVersion>>0;
  483. UdsAns(true,UdsService,UdsSubService,0x00,AnsData,4);
  484. AppConfigInfo.appSaveFlg = true;
  485. vTaskDelay(pdMS_TO_TICKS(1000));
  486. SystemSoftwareReset();
  487. break;
  488. }
  489. default:
  490. {
  491. UdsAns(false,UdsService,UdsSubService,0x00,NULL,0);
  492. break;
  493. }
  494. }
  495. }
  496. else
  497. {
  498. UdsAns(false,UdsService,UdsSubService,0x00,NULL,0);
  499. }
  500. break;
  501. }
  502. case 0x22: //查询
  503. {
  504. if (UdsStates == 0x02)
  505. {
  506. switch (UdsSubService)
  507. {
  508. case 0x01: //版本号查询
  509. {
  510. AnsData[0] = AppSwVersion>>24;
  511. AnsData[1] = AppSwVersion>>16;
  512. AnsData[2] = AppSwVersion>>8;
  513. AnsData[3] = AppSwVersion>>0;
  514. UdsAns(true,UdsService,UdsSubService,0x00,AnsData,4);
  515. break;
  516. }
  517. case 0x02: // SN号码查询
  518. {
  519. memcpy(AnsData, AppConfigInfo.deviceSn, 17);
  520. for (uint8 i = 0; i < 5; i++)
  521. {
  522. UdsAns(true, UdsService, UdsSubService, i, &AnsData[i * 4], 4);
  523. }
  524. break;
  525. }
  526. case 0x03: // ICCID查询
  527. {
  528. memcpy(AnsData, IccidNum, 20);
  529. for (uint8 i = 0; i < 5; i++)
  530. {
  531. UdsAns(true, UdsService, UdsSubService, i, &AnsData[i * 4], 4);
  532. }
  533. break;
  534. }
  535. case 0x04: // IMEI查询
  536. {
  537. memcpy(AnsData, ImeiNum, 15);
  538. for (uint8 i = 0; i < 4; i++)
  539. {
  540. UdsAns(true, UdsService, UdsSubService, i, &AnsData[i * 4], 4);
  541. }
  542. break;
  543. }
  544. case 0x05: //驻网状态查询
  545. {
  546. AnsData[0] = RegChkRet;
  547. UdsAns(true, UdsService, UdsSubService, 0x00, AnsData, 1);
  548. break;
  549. }
  550. case 0x06: //联网状态查询
  551. {
  552. AnsData[0] = SocketId;
  553. UdsAns(true, UdsService, UdsSubService, 0x00, AnsData, 1);
  554. break;
  555. }
  556. case 0x07: //定位信息查询
  557. {
  558. GPSInfo GpsRecvData;
  559. if (xQueuePeek(GpsDataQueueHandle, &GpsRecvData, 0) == pdPASS)
  560. {
  561. AnsData[0] = GpsRecvData.locateMark;
  562. AnsData[4] = GpsRecvData.longitude[0];
  563. AnsData[5] = GpsRecvData.longitude[1];
  564. AnsData[6] = GpsRecvData.longitude[2];
  565. AnsData[7] = GpsRecvData.longitude[3];
  566. AnsData[8] = GpsRecvData.latitude[0];
  567. AnsData[9] = GpsRecvData.latitude[1];
  568. AnsData[10] = GpsRecvData.latitude[2];
  569. AnsData[11] = GpsRecvData.latitude[3];
  570. AnsData[12] = GpsRecvData.altitude[0];
  571. AnsData[13] = GpsRecvData.altitude[1];
  572. AnsData[14] = GpsRecvData.satelliteNum;
  573. for (uint8 i = 0; i < 4; i++)
  574. {
  575. UdsAns(true, UdsService, UdsSubService, i, &AnsData[i * 4], 4);
  576. }
  577. break;
  578. }
  579. else
  580. {
  581. AnsData[0] = 0xFF;
  582. UdsAns(true, UdsService, UdsSubService, 0x00, AnsData, 1);
  583. }
  584. break;
  585. }
  586. case 0x08: //温度检测查询
  587. {
  588. UdsAns(true, UdsService, UdsSubService, 0x00, AnsData, 1);
  589. break;
  590. }
  591. case 0x09: //电池信息查询
  592. {
  593. UdsAns(true, UdsService, UdsSubService, 0x00, AnsData, 1);
  594. BattSendFlg = 1;
  595. break;
  596. }
  597. case 0x0A: //三轴数据查询
  598. {
  599. AnsData[0] = xyzData[0] >> 8;
  600. AnsData[1] = xyzData[0] >> 0;
  601. AnsData[2] = xyzData[1] >> 8;
  602. AnsData[3] = xyzData[1] >> 0;
  603. AnsData[4] = xyzData[2] >> 8;
  604. AnsData[5] = xyzData[2] >> 0;
  605. for (uint8 i = 0; i < 2; i++)
  606. {
  607. UdsAns(true, UdsService, UdsSubService, i, &AnsData[i * 4], 4);
  608. }
  609. break;
  610. }
  611. } // switch
  612. } // if
  613. else
  614. {
  615. UdsAns(false, UdsService, UdsSubService, 0x00, NULL, 0);
  616. }
  617. break;
  618. }
  619. case 0x27: //控制
  620. {
  621. if (UdsStates == 0x02)
  622. {
  623. }
  624. else
  625. {
  626. UdsAns(false, UdsService, UdsSubService, 0x00, NULL, 0);
  627. }
  628. break;
  629. }
  630. case 0x2E: //写入
  631. {
  632. if (UdsStates == 0x02)
  633. {
  634. switch (UdsSubService)
  635. {
  636. case 0x01:
  637. {
  638. setbit(deviceSnRecvFlg, Data[3]);
  639. if (Data[3] < 0x04)
  640. {
  641. memcpy(&AppConfigInfo.deviceSn[Data[3] * 4], &Data[4], 4);
  642. UdsAns(true, UdsService, UdsSubService, 0x00, &Data[3], 1);
  643. }
  644. else if (Data[3] == 0x04)
  645. {
  646. memcpy(&AppConfigInfo.deviceSn[Data[3] * 4], &Data[4], 1);
  647. UdsAns(true, UdsService, UdsSubService, 0x00, &Data[3], 1);
  648. }
  649. if (deviceSnRecvFlg == 0x1F)
  650. {
  651. deviceSnRecvFlg = 0;
  652. AppConfigInfo.appSaveFlg = true;
  653. AppConfigInfo.eolFlg=true;
  654. }
  655. break;
  656. }
  657. }
  658. }
  659. else
  660. {
  661. UdsAns(false,UdsService,UdsSubService,0x00,NULL,0);
  662. }
  663. break;
  664. }
  665. case 0x31://控制
  666. {
  667. if(UdsStates==0x02)
  668. {
  669. }
  670. else
  671. {
  672. UdsAns(false, UdsService, UdsSubService, 0x00, NULL, 0);
  673. }
  674. break;
  675. }
  676. default:
  677. break;
  678. }
  679. return;
  680. }
  681. static void UdsAns(bool PosFlg, uint8 UdsService, uint8 UdsSubService, uint8 Idx, uint8 *AnsData, uint8 AnsDataLen)
  682. {
  683. Can_Msg_Type CanTxMsg;
  684. uint32 CanAnsId = 0x1C00EAED;
  685. uint8 SendData[8] = {0};
  686. if (PosFlg)
  687. {
  688. SendData[0] = 0x78;
  689. SendData[1] = UdsService;
  690. SendData[2] = UdsSubService;
  691. SendData[3] = Idx;
  692. if (AnsData != NULL && AnsDataLen != 0x00)
  693. {
  694. memcpy(&SendData[4], AnsData, AnsDataLen);
  695. }
  696. }
  697. else
  698. {
  699. SendData[0] = 0x7F;
  700. SendData[1] = UdsService;
  701. SendData[2] = UdsSubService;
  702. SendData[3] = 0x00;
  703. }
  704. CanTxMsg.id = CanAnsId;
  705. CanTxMsg.idFrame = CAN_EXTENDED_ID_TYPE;
  706. CanTxMsg.sdu = SendData;
  707. CanTxMsg.length = 8;
  708. CanIf_SendMessage(CAN1, CanTxMsg);
  709. }
  710. static void BattSendFunc(void)
  711. {
  712. // Can_Msg_Type CanTxMsg;
  713. // uint32 CanAnsId = 0;
  714. // uint8 SendData[8] = {0};
  715. // static uint8 SendStep = 0;
  716. // static uint8 SendCounter = 0;
  717. // switch (SendStep)
  718. // {
  719. // case 0x00:
  720. // {
  721. // SendStep++;
  722. // break;
  723. // }
  724. // case 0x01:
  725. // {
  726. // CanAnsId = 0x1C01EAED;
  727. // SendData[0] = battHeatState;
  728. // SendData[1] = battFanState;
  729. // SendData[2] = battRelayState;
  730. // SendData[3] = battConverState;
  731. // SendStep++;
  732. // break;
  733. // }
  734. // case 0x02:
  735. // {
  736. // uint16 ErrorTemp ;
  737. // ErrorTemp = GetErrorNum(ErrorArray,sizeof(ErrorArray)/2);
  738. // CanAnsId = 0x1C09EAED;
  739. // SendData[0] = battWorkState;
  740. // SendData[1] = ErrorTemp>>8;
  741. // SendData[2] = ErrorTemp;
  742. // SendData[3] = 0;
  743. // SendData[4] = 0;
  744. // SendData[5] = 0;
  745. // SendData[6] = 0;
  746. // SendData[7] = 0;
  747. // SendStep++;
  748. // break;
  749. // }
  750. // case 0x03:
  751. // {
  752. // CanAnsId = 0x1C0AEAED;
  753. // uint16 SocTemp = battSOC*10;
  754. // SendData[0] = battI>>8;
  755. // SendData[1] = battI;
  756. // SendData[2] = battPackVol>>8;
  757. // SendData[3] = battPackVol;
  758. // SendData[4] = SocTemp>>8;
  759. // SendData[5] = SocTemp;
  760. // SendData[6] = battSOH;
  761. // SendData[7] = battMOSSwitchState;
  762. // SendStep++;
  763. // break;
  764. // }
  765. // case 0x04:
  766. // {
  767. // CanAnsId = 0x1C10EAED + (SendCounter<<16);
  768. // if((SendCounter*8 + 7)>BMS_TEMPNUM)
  769. // {
  770. // SendCounter = 0;
  771. // SendStep++;
  772. // break;
  773. // }
  774. // else
  775. // {
  776. // SendData[0] = battCellTemp[SendCounter*8 + 0];
  777. // SendData[1] = battCellTemp[SendCounter*8 + 1];
  778. // SendData[2] = battCellTemp[SendCounter*8 + 2];
  779. // SendData[3] = battCellTemp[SendCounter*8 + 3];
  780. // SendData[4] = battCellTemp[SendCounter*8 + 4];
  781. // SendData[5] = battCellTemp[SendCounter*8 + 5];
  782. // SendData[6] = battCellTemp[SendCounter*8 + 6];
  783. // SendData[7] = battCellTemp[SendCounter*8 + 7];
  784. // }
  785. // break;
  786. // }
  787. // case 0x05:
  788. // {
  789. // CanAnsId = 0x1CA0EAED + (SendCounter<<16);
  790. // if((SendCounter*4 + 3)>BMS_CELLNUM)
  791. // {
  792. // SendCounter = 0;
  793. // SendStep++;
  794. // break;
  795. // }
  796. // else
  797. // {
  798. // SendData[0] = battCellU[SendCounter*4 + 0]>>8;
  799. // SendData[1] = battCellU[SendCounter*4 + 0];
  800. // SendData[2] = battCellU[SendCounter*4 + 1]>>8;
  801. // SendData[3] = battCellU[SendCounter*4 + 1];
  802. // SendData[4] = battCellU[SendCounter*4 + 2]>>8;
  803. // SendData[5] = battCellU[SendCounter*4 + 2];
  804. // SendData[6] = battCellU[SendCounter*4 + 3]>>8;
  805. // SendData[7] = battCellU[SendCounter*4 + 3];
  806. // }
  807. // break;
  808. // }
  809. // default:
  810. // {
  811. // SendStep = 0;
  812. // BattSendFlg = 0;
  813. // return;
  814. // break;
  815. // }
  816. // }
  817. // CanTxMsg.id = CanAnsId;
  818. // CanTxMsg.idFrame = CAN_EXTENDED_ID_TYPE;
  819. // CanTxMsg.sdu = SendData;
  820. // CanTxMsg.length = 8;
  821. // CanIf_SendMessage(CAN1, CanTxMsg);
  822. }
  823. void BcuRxDiagnose(void) // 100ms调用一次
  824. {
  825. static UINT32 TimeCounter = 0; // ms
  826. TimeCounter = TimeCounter + 10; //
  827. for (UINT8 i = 0; i < sizeof(BcuInTable) / 4; i++)
  828. {
  829. if (BcuRxFlag[i] == 1) // received msg, and clear the error conter
  830. {
  831. BcuRxErrorCounter[i] = 0;
  832. BcuRxFlag[i] = 0;
  833. continue;
  834. }
  835. if (BcuRxErrorCounter[i] < 3)
  836. {
  837. BcuRxShortError[i] = 0;
  838. BcuRxLongError[i] = 0;
  839. }
  840. else if (BcuRxErrorCounter[i] >= 3 && BcuRxErrorCounter[i] < 13)
  841. {
  842. BcuRxShortError[i] = 1;
  843. BcuRxLongError[i] = 0;
  844. }
  845. else if (BcuRxErrorCounter[i] >= 13)
  846. {
  847. BcuRxShortError[i] = 0;
  848. BcuRxLongError[i] = 1;
  849. BcuRxMsgSetInvalidValue(BcuInTable[i]);
  850. BcuRxErrorCounter[i] = 0;
  851. }
  852. else if (BcuRxErrorCounter[i] == 0xFF)
  853. {
  854. BcuRxErrorCounter[i] = 0xFE;
  855. }
  856. }
  857. if (TimeCounter % 100 == 0) // period <=100ms
  858. {
  859. BcuRxErrorCounter[0]++; // can msg 0x1801D0F3
  860. // if(BcuRxErrorCounter[0]>=13)
  861. BcuRxErrorCounter[2]++; // can msg 0x1880D0F3
  862. // if(BcuRxErrorCounter[2]>=13)
  863. BcuRxErrorCounter[3]++; // can msg 0x1881D0F3
  864. // if(BcuRxErrorCounter[3]>=13)
  865. BcuRxErrorCounter[4]++; // can msg 0x1882D0F3
  866. // if(BcuRxErrorCounter[4]>=13)
  867. BcuRxErrorCounter[5]++; // can msg 0x1883D0F3
  868. // if(BcuRxErrorCounter[5]>=13)
  869. BcuRxErrorCounter[6]++; // can msg 0x1884D0F3
  870. // if(BcuRxErrorCounter[6]>=13)
  871. BcuRxErrorCounter[7]++; // can msg 0x1885D0F3
  872. // if(BcuRxErrorCounter[7]>=13)
  873. BcuRxErrorCounter[8]++; // can msg 0x1886D0F3
  874. // if(BcuRxErrorCounter[8]>=13)
  875. BcuRxErrorCounter[9]++; // can msg 0x1887D0F3
  876. // if(BcuRxErrorCounter[9]>=13)
  877. BcuRxErrorCounter[10]++; // can msg 0x1888D0F3
  878. // if(BcuRxErrorCounter[10]>=13)
  879. BcuRxErrorCounter[13]++; // can msg 0x18C1D0F3
  880. // if(BcuRxErrorCounter[13]>=13)
  881. BcuRxErrorCounter[14]++; // can msg 0x18C2D0F3
  882. // if(BcuRxErrorCounter[14]>=13)
  883. BcuRxErrorCounter[19]++; // can msg 0x18E5D0F3
  884. // if(BcuRxErrorCounter[19]>=13)
  885. BcuRxErrorCounter[20]++; // can msg 0x18E6D0F3
  886. // if(BcuRxErrorCounter[20]>=13)
  887. }
  888. if (TimeCounter % 1000 == 0) // period ==1000ms
  889. {
  890. BcuRxErrorCounter[11]++; // can msg 0x1889D0F3
  891. // if(BcuRxErrorCounter[11]>=13)
  892. // printf("can msg 0x%x lost,cycle time1000ms\n",COMInTable[11]);
  893. BcuRxErrorCounter[12]++; // can msg 0x188AD0F3
  894. // if(BcuRxErrorCounter[12]>=13)
  895. // printf("can msg 0x%x lost,cycle time1000ms\n",COMInTable[12]);
  896. BcuRxErrorCounter[15]++; // can msg 0x18E1D0F3
  897. // if(BcuRxErrorCounter[15]>=13)
  898. // printf("can msg 0x%x lost,cycle time1000ms\n",COMInTable[15]);
  899. BcuRxErrorCounter[16]++; // can msg 0x18E2D0F3
  900. // if(BcuRxErrorCounter[16]>=13)
  901. // printf("can msg 0x%x lost,cycle time1000ms\n",COMInTable[16]);
  902. BcuRxErrorCounter[17]++; // can msg 0x18E3D0F3
  903. // if(BcuRxErrorCounter[17]>=13)
  904. // printf("can msg 0x%x lost,cycle time1000ms\n",COMInTable[17]);
  905. BcuRxErrorCounter[18]++; // can msg 0x18E4D0F3
  906. // if(BcuRxErrorCounter[18]>=13)
  907. // printf("can msg 0x%x lost,cycle time1000ms\n",COMInTable[18]);
  908. BcuRxErrorCounter[26]++; // can msg 0x18FF45F4
  909. // if(BcuRxErrorCounter[26]>=13)
  910. // printf("can msg 0x%x lost,cycle time1000ms\n",COMInTable[26]);
  911. BcuRxErrorCounter[27]++; // can msg 0x18FFC13A
  912. // if(BcuRxErrorCounter[27]>=13)
  913. // printf("can msg 0x%x lost,cycle time1000ms\n",COMInTable[27]);
  914. }
  915. if (TimeCounter % 30000 == 0) // period ==30000ms
  916. {
  917. BcuRxErrorCounter[1]++; // can msg 0x1801D8F3
  918. // if(BcuRxErrorCounter[1]>=13)
  919. // printf("can msg 0x%x lost,cycle time30000ms\n",COMInTable[1]);
  920. }
  921. }
  922. void BcuRxMsgSetInvalidValue(uint32 ID)
  923. {
  924. switch (ID)
  925. {
  926. case 0x1801D0F3:
  927. BMS_ReqVIN = 0xFF;
  928. BMS_ReqHVOff = 0xFF;
  929. break;
  930. case 0x1801D8F3:
  931. BMS_SoftwareVersion = 0xFFFF;
  932. BMS_HardwareVersion = 0xFFFF;
  933. BMS_ProtocolEditionH = 0xFF;
  934. BMS_ProtocolEditionL = 0xFF;
  935. break;
  936. case 0x1880D0F3:
  937. BMS_CharDevNum = 0xFF;
  938. BMS_FtPosRly = 0xFF;
  939. BMS_FtNegRly = 0xFF;
  940. BMS_FtPosCharRly1 = 0xFF;
  941. BMS_FtNegCharRly1 = 0xFF;
  942. BMS_FtPosCharRly2 = 0xFF;
  943. BMS_FtNegCharRly2 = 0xFF;
  944. BMS_FtHeatRly1 = 0xFF;
  945. BMS_FtHeatRly2 = 0xFF;
  946. BMS_StPosRly = 0xFF;
  947. BMS_StNegRly = 0xFF;
  948. BMS_StPreCharRly = 0xFF;
  949. BMS_StPosCharRly1 = 0xFF;
  950. BMS_StNegCharRly1 = 0xFF;
  951. BMS_StPosCharRly2 = 0xFF;
  952. BMS_StNegCharRly2 = 0xFF;
  953. BMS_FtAuxRelayWeld = 0xFF;
  954. BMS_BraOpenCirc = 0xFF;
  955. BMS_FtBackCharCurrOutLim = 0xFF;
  956. BMS_FtPosRlyOpen = 0xFF;
  957. BMS_FtNegRlyOpen = 0xFF;
  958. BMS_FtPosCharRly1Open = 0xFF;
  959. BMS_FtPosCharRly2Open = 0xFF;
  960. BMS_FtNegCharRly1Open = 0xFF;
  961. BMS_FtNegCharRly2Open = 0xFF;
  962. BMS_FtTMSContClose = 0xFF;
  963. BMS_FtTMSContOpen = 0xFF;
  964. BMS_FtTMS = 0xFF;
  965. BMS_Ft24VSpy = 0xFF;
  966. BMS_FtPACKSelfProt = 0xFF;
  967. BMS_FtCharSockTempOver = 0xFF;
  968. BMS_FtTempOutCtrl = 0xFF;
  969. BMS_StPosHeatRly = 0xFF;
  970. BMS_StNegHeatRly = 0xFF;
  971. BMS_CharSysNum = 0xFF;
  972. BMS_FtCode = 0xFF;
  973. break;
  974. case 0x1881D0F3:
  975. BMS_ST1CheckSum = 0xFF;
  976. BMS_ST1Counter = 0xFF;
  977. BMS_Mode = 0xFF;
  978. BMS_AuxRlySt = 0xFF;
  979. BMS_BattBalaSt = 0xFF;
  980. BMS_CharGunSt = 0xFF;
  981. BMS_CharMode = 0xFF;
  982. BMS_CharSt = 0xFF;
  983. BMS_FtLvl = 0xFF;
  984. BMS_FtCellTempDiff = 0xFF;
  985. BMS_FtCellTempHigh = 0xFF;
  986. BMS_FtPACKOverVolt = 0xFF;
  987. BMS_FtPACKUndeVolt = 0xFF;
  988. BMS_FtSOCLow = 0xFF;
  989. BMS_FtCellOverVolt = 0xFF;
  990. BMS_FtCellUndeVolt = 0xFF;
  991. BMS_FtIns = 0xFF;
  992. BMS_FtCellOverVoltDiff = 0xFF;
  993. BMS_FtCharCurrOver = 0xFF;
  994. BMS_FtDisCharCurrOver = 0xFF;
  995. BMS_FtCellTempLow = 0xFF;
  996. BMS_FtBranVoltDifOver = 0xFF;
  997. BMS_FtBMSHardWare = 0xFF;
  998. BMS_FtSOCHigh = 0xFF;
  999. BMS_FtSOCJump = 0xFF;
  1000. BMS_FtInCom = 0xFF;
  1001. BMS_FtSysMism = 0xFF;
  1002. BMS_FtHvIntLock = 0xFF;
  1003. BMS_FtSmoke = 0xFF;
  1004. BMS_FtFire = 0xFF;
  1005. BMS_FtNum = 0xFF;
  1006. break;
  1007. case 0x1882D0F3:
  1008. BMS_PackSOC = 0xFF;
  1009. BMS_PackSOH = 0xFF;
  1010. BMS_PackCurr = 0xFFFF;
  1011. BMS_MaxCharCurr = 0xFFFF;
  1012. BMS_MaxDisCharCurr = 0xFFFF;
  1013. break;
  1014. case 0x1883D0F3:
  1015. BMS_PosIns = 0xFFFF;
  1016. BMS_NegIns = 0xFFFF;
  1017. BMS_BattVolt = 0xFFFF;
  1018. BMS_LinkVolt = 0xFFFF;
  1019. break;
  1020. case 0x1884D0F3:
  1021. BMS_MaxCellTemp = 0xFF;
  1022. BMS_MinCellTemp = 0xFF;
  1023. BMS_AverCellTemp = 0xFF;
  1024. BMS_MaxCellTempCSC = 0xFF;
  1025. BMS_MaxCellTempNum = 0xFF;
  1026. BMS_MinCellTempCSC = 0xFF;
  1027. BMS_MinCellTempNum = 0xFF;
  1028. break;
  1029. case 0x1885D0F3:
  1030. BMS_MaxCellVolt = 0xFFFF;
  1031. BMS_MaxCellVoltCSC = 0xFF;
  1032. BMS_MaxCellVoltNum = 0xFF;
  1033. BMS_AverCellVolt = 0xFFFF;
  1034. break;
  1035. case 0x1886D0F3:
  1036. BMS_MinCellVolt = 0xFFFF;
  1037. BMS_MinCellVoltCSC = 0xFF;
  1038. BMS_MinCellVoltNum = 0xFF;
  1039. BMS_ContChrgCurr = 0xFFFF;
  1040. BMS_ContDisCharCurr = 0xFFFF;
  1041. break;
  1042. case 0x1887D0F3:
  1043. BMS_CharReqVolt = 0xFFFF;
  1044. BMS_CharReqCurr = 0xFFFF;
  1045. BMS_SysInsRes = 0xFFFF;
  1046. BMS_InsDeteSt = 0xFF;
  1047. BMS_FtCharInsLow = 0xFF;
  1048. BMS_FtCurrSenr = 0xFF;
  1049. BMS_FtHeatingFilm = 0xFF;
  1050. BMS_FtMainLoopPreChar = 0xFF;
  1051. BMS_FtAuxLoopPreChar = 0xFF;
  1052. BMS_FtACANLost = 0xFF;
  1053. BMS_FtDCDC = 0xFF;
  1054. BMS_FtSOCDif = 0xFF;
  1055. BMS_FtCellOverDisChar = 0xFF;
  1056. BMS_FtCharOver = 0xFF;
  1057. BMS_FtContDisCharCurrOverLoad = 0xFF;
  1058. BMS_FtContCharCurrOverLoad = 0xFF;
  1059. break;
  1060. case 0x1888D0F3:
  1061. BMS_MaxDisCharPwr = 0xFFFF;
  1062. BMS_MaxCharPwr = 0xFFFF;
  1063. BMS_ContDisCharPwr = 0xFFFF;
  1064. BMS_ContCharPwr = 0xFFFF;
  1065. break;
  1066. case 0x1889D0F3:
  1067. BMS_InstEngyCons = 0xFFFF;
  1068. BMS_TotalEngyCons = 0xFFFF;
  1069. BMS_SOE = 0xFFFF;
  1070. BMS_RmanCharTime = 0xFFFF;
  1071. break;
  1072. case 0x188AD0F3:
  1073. BMS_Gun1DCNegTemp = 0xFF;
  1074. BMS_Gun1DCPosTemp = 0xFF;
  1075. BMS_Gun2DCNegTemp = 0xFF;
  1076. BMS_Gun2DCPosTemp = 0xFF;
  1077. BMS_CurrHeatSt = 0xFF;
  1078. BMS_CurrCoolSt = 0xFF;
  1079. BMS_FtCharCnct = 0xFF;
  1080. BMS_FtOverDisCharCurrDuringChar = 0xFF;
  1081. BMS_FtCharNTC = 0xFF;
  1082. BMS_FtELock = 0xFF;
  1083. BMS_CharNum = 0xFFFF;
  1084. break;
  1085. case 0x18C1D0F3:
  1086. BMS_CellVoltFramNum = 0xFF;
  1087. for (UINT16 i = 0; i < sizeof(BMS_CellVolt) / 2; i++)
  1088. {
  1089. BMS_CellVolt[i] = 0xFFFF;
  1090. }
  1091. break;
  1092. case 0x18C2D0F3:
  1093. BMS_CellTempFramNum = 0xFF;
  1094. BMS_CSC_Code = 0xFF;
  1095. for (UINT8 i = 0; i < sizeof(BMS_CellTemp); i++)
  1096. {
  1097. BMS_CellTemp[i] = 0xFF;
  1098. }
  1099. break;
  1100. case 0x18E1D0F3:
  1101. BMS_Checksum = 0xFF;
  1102. BMS_PackComp = 0xFF;
  1103. BMS_BattCodeLeng = 0xFF;
  1104. BMS_SN[0] = 0xFF;
  1105. BMS_SN[1] = 0xFF;
  1106. BMS_SN[2] = 0xFF;
  1107. BMS_SN[3] = 0xFF;
  1108. BMS_SN[4] = 0xFF;
  1109. BMS_SN[5] = 0xFF;
  1110. break;
  1111. case 0x18E2D0F3:
  1112. BMS_Checksum = 0xFF;
  1113. BMS_SN[6] = 0xFF;
  1114. BMS_SN[7] = 0xFF;
  1115. BMS_SN[8] = 0xFF;
  1116. BMS_SN[9] = 0xFF;
  1117. BMS_SN[10] = 0xFF;
  1118. BMS_SN[11] = 0xFF;
  1119. BMS_SN[12] = 0xFF;
  1120. break;
  1121. case 0x18E3D0F3:
  1122. BMS_Checksum = 0xFF;
  1123. BMS_SN[13] = 0xFF;
  1124. BMS_SN[14] = 0xFF;
  1125. BMS_SN[15] = 0xFF;
  1126. BMS_SN[16] = 0xFF;
  1127. BMS_SN[17] = 0xFF;
  1128. BMS_SN[18] = 0xFF;
  1129. BMS_SN[19] = 0xFF;
  1130. break;
  1131. case 0x18E4D0F3:
  1132. BMS_Checksum = 0xFF;
  1133. BMS_SN[20] = 0xFF;
  1134. BMS_SN[21] = 0xFF;
  1135. BMS_SN[22] = 0xFF;
  1136. BMS_SN[23] = 0xFF;
  1137. BMS_SN[24] = 0xFF;
  1138. BMS_SN[25] = 0xFF;
  1139. BMS_SN[26] = 0xFF;
  1140. break;
  1141. case 0x18E5D0F3:
  1142. BMS_BattRateCap = 0xFFFF;
  1143. BMS_BattRateVolt = 0xFFFF;
  1144. BMS_BattRateEngy = 0xFFFF;
  1145. BMS_BattType = 0xFF;
  1146. BMS_CoolType = 0xFF;
  1147. break;
  1148. case 0x18E6D0F3:
  1149. BMS_CSC_Total = 0xFF;
  1150. // BMS_CellTotal = BMS_CELL_MAX_NUM;
  1151. // BMS_TempTotal = BMS_TEMP_MAX_NUM;
  1152. BMS_CellVoltLevel = 0xFF;
  1153. BMS_CellMinVolt = 0xFF;
  1154. BMS_CellMaxVolt = 0xFF;
  1155. break;
  1156. case 0x18F1D0F3:
  1157. BMS_TotalCharEngy = 0xFFFFFFFF;
  1158. BMS_TotalDisCharEngy = 0xFFFFFFFF;
  1159. BMS_SingleCharEngy = 0xFFFF;
  1160. break;
  1161. case 0x18F2D0F3:
  1162. BMS_TotalBackCharEngy = 0xFFFFFFFF;
  1163. BMS_TotalStaCharEngy = 0xFFFFFFFF;
  1164. break;
  1165. case 0x18F3D0F3:
  1166. BMS_TotalGunCharEngy = 0xFFFFFFFF;
  1167. BMS_TotalGunCharCapy = 0xFFFFFFFF;
  1168. break;
  1169. case 0x18F4D0F3:
  1170. BMS_TotalCharCapy = 0xFFFFFFFF;
  1171. BMS_TotalDisCharCapy = 0xFFFFFFFF;
  1172. BMS_SingleCharCapy = 0xFFFF;
  1173. break;
  1174. case 0x18F5D0F3:
  1175. BMS_TotalBackCharCapy = 0xFFFFFFFF;
  1176. BMS_TotalStaCharCapy = 0xFFFFFFFF;
  1177. BMS_HVBranNum = 0xFF;
  1178. BMS_SingleHVBranchCellNum = 0xFF;
  1179. break;
  1180. case 0x18FF45F4:
  1181. BMS_ReqMode = 0xFF;
  1182. BMS_HVCmd = 0xFF;
  1183. BMS_ChgSts = 0xFF;
  1184. BMS_HVRelaySts = 0xFF;
  1185. BMS_HVVolt = 0xFFFF;
  1186. BMS_SetTemp = 0xFF;
  1187. BMS_Life = 0xFF;
  1188. BMS_CRC = 0xFF;
  1189. break;
  1190. case 0x18FFC13A:
  1191. TMS_WorkStatus = 0xFF;
  1192. TMS_HVRelayST = 0xFF;
  1193. TMS_OutletTemp = 0xFF;
  1194. TMS_InletTemp = 0xFF;
  1195. TMS_ReqPow = 0xFFFF;
  1196. TMS_ErrCode = 0xFF;
  1197. TMS_FaultLevel = 0xFF;
  1198. break;
  1199. default:
  1200. break;
  1201. }
  1202. }
  1203. #endif