can_app.c 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477
  1. /**
  2. ******************************************************************************
  3. * @file can_app.c
  4. * @author Vincent
  5. * @version V1.0.0
  6. * @date 23-12-2015
  7. * @brief
  8. ******************************************************************************
  9. *
  10. * COPYRIGHT(c) 2015 STMicroelectronics
  11. *
  12. * Redistribution and use in source and binary forms, with or without modification,
  13. * are permitted provided that the following conditions are met:
  14. * 1. Redistributions of source code must retain the above copyright notice,
  15. * this list of conditions and the following disclaimer.
  16. * 2. Redistributions in binary form must reproduce the above copyright notice,
  17. * this list of conditions and the following disclaimer in the documentation
  18. * and/or other materials provided with the distribution.
  19. * 3. Neither the name of STMicroelectronics nor the names of its contributors
  20. * may be used to endorse or promote products derived from this software
  21. * without specific prior written permission.
  22. *
  23. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
  24. * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  25. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
  26. * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
  27. * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  28. * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
  29. * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
  30. * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
  31. * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
  32. * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  33. *
  34. ******************************************************************************
  35. */
  36. /* Includes ------------------------------------------------------------------*/
  37. #include "can_app.h"
  38. #include "RefreshMenu.h"
  39. #include "protocol.h"
  40. //#include "FLASH_Block_Api.h"
  41. #include "string.h"
  42. #include "flash_if.h"
  43. #include "crc_cal.h"
  44. #include "bin_check.h"
  45. /* Private variables ---------------------------------------------------------*/
  46. /*******************************************************************************
  47. * Function: void CAN_RxData_Process(CAN_Buf_TypeDef*ptCANRx)
  48. * Discrible:
  49. * Input:
  50. * Output:
  51. * Return:
  52. * Others:
  53. * date version author record
  54. * -----------------------------------------------
  55. * 20151107 V1.0 VINCENT Create
  56. *********************************************************************************/
  57. void CA_RxData_Process(CAN_Buf_TypeDef*ptCANRx)
  58. {
  59. CD_UINT8 ucHeadHighByte,ucHeadLowByte,ucFrameMode;
  60. //CD_UINT8 file_headTail[PACKET_128B_SIZE]={0},file_body[PACKET_1K_SIZE]={0};
  61. CD_UINT16 i ;
  62. CD_UINT8 ucFrameLength,ucTrail;
  63. CD_UINT16 ucKeyCmd;
  64. CD_UINT32 ucCRCSum,CrcTemp;
  65. static CD_UINT8 frameCrcBuff[FRAME_DATA_SIZE+2];
  66. if((*ptCANRx).ucBufCnt > 8)
  67. {
  68. /*清除超时标志*/
  69. update.TimeCounter_Update = 0;
  70. ucHeadHighByte = cd_ReadChar(ptCANRx,0); //帧头1
  71. ucHeadLowByte = cd_ReadChar(ptCANRx,1); //帧头2
  72. if((PRO_HEAD1 == ucHeadHighByte)&&(PRO_HEAD2 == ucHeadLowByte))
  73. {
  74. ucFrameMode = cd_ReadChar(ptCANRx,2);
  75. ucFrameLength = cd_ReadChar(ptCANRx,3);
  76. ucKeyCmd = ((CD_UINT16)cd_ReadChar(ptCANRx,4) << 8 ) + ((CD_UINT16)cd_ReadChar(ptCANRx,5));
  77. if( FRAME_MODE_WRITE != ucFrameMode) return;
  78. if((*ptCANRx).ucBufCnt <(ucFrameLength + 4 + 5 )) return;
  79. frameCrcBuff[0] = FRAME_HEAD1;
  80. frameCrcBuff[1] = FRAME_HEAD2;
  81. frameCrcBuff[2] = 0x07;
  82. frameCrcBuff[3] = 0x51;
  83. ucTrail = cd_ReadChar(ptCANRx,ucFrameLength + 4 + 4 );
  84. if(PRO_TAIL != ucTrail)
  85. {
  86. /*帧尾错误*/
  87. cd_DelChar(ptCANRx, 1);
  88. update.AckEnable = ENABLE;
  89. downLoad.userCmd = CMD_ACK_ERR;
  90. downLoad.step = 0xf0;
  91. return ;
  92. }
  93. ucCRCSum = (cd_ReadChar(ptCANRx,ucFrameLength + 4 ) << 24) + \
  94. (cd_ReadChar(ptCANRx,ucFrameLength + 4 + 1 ) << 16) + \
  95. (cd_ReadChar(ptCANRx,ucFrameLength + 4 + 2 ) << 8) + \
  96. cd_ReadChar(ptCANRx,ucFrameLength + 4 + 3 ) ;
  97. for(i=2; i< ( ucFrameLength + 4 ); i++)
  98. {
  99. frameCrcBuff[i+2] = cd_ReadChar(ptCANRx,i);
  100. }
  101. /*CRC 校验*/
  102. CrcTemp = CRC32_Calculate( (CD_UINT8 *)frameCrcBuff, (ucFrameLength + 4 + 2 ) );
  103. if( ucCRCSum != CrcTemp)
  104. {
  105. update.AckEnable = ENABLE;
  106. downLoad.userCmd = CMD_ACK_ERR;
  107. downLoad.step = 0xf1;
  108. cd_DelChar(ptCANRx, (ucFrameLength + 4 + 5 ));
  109. return ;
  110. }
  111. cd_DelChar(ptCANRx, (ucFrameLength + 4 + 5 ));
  112. switch(ucKeyCmd)
  113. {
  114. case CMD_UPDATA: //升级指令
  115. //准备升级
  116. if(downLoad.step != 1)
  117. {
  118. downLoad.step = 1;
  119. update.AckEnable = ENABLE;
  120. downLoad.userCmd = CMD_ACK_REQ;
  121. downLoad.packageSize = *(uint32_t *)(frameCrcBuff + 15);
  122. /*清除超时标志*/
  123. update.TimeCounter_Startup = 0;
  124. }
  125. break;
  126. case CMD_PACKAGE_DATA: //数据包
  127. //第一包数据为bin文件校验信息
  128. if(CheckFlag == 0)
  129. {
  130. CheckFlag = 1;
  131. CheckInfo = (CD_UINT8 *)frameCrcBuff + FRAME_HEAD + PACKAGE_DATA_HEAD + 2;
  132. //比较文件头
  133. if(Check_CompareHead(CheckInfo, Check_UUID) == 0)
  134. {
  135. //解密获取bin文件crc32
  136. Check_CalCrc32(CheckInfo, Crc32_Cal);
  137. //比较加密信息
  138. if(Check_CompareEncryptInfo(CheckInfo) == 0)
  139. {
  140. //比较自定义信息
  141. if(Check_OptionInfo(CheckInfo, OPTIONAL_ADDRESS) == 0)
  142. {
  143. //比较校验
  144. if(Check_CompareXor(CheckInfo) == 0)
  145. {
  146. //文件头检验正确
  147. CheckFlag = 2;
  148. /*擦除FLASH,剩余最后8k没有擦除,保留其他功能使用**/
  149. FLASH_If_Erase(APPLICATION_ADDRESS); //擦除时间约120ms
  150. /*清空flash写标志*/
  151. for(i=0;i<1024;i++)
  152. {
  153. flag_FlashWR[i] = 0;
  154. }
  155. sendUpdateAck(0xC202, 0x0001);
  156. }
  157. else
  158. {
  159. //文件头检验异常
  160. CheckFlag = 3;
  161. sendUpdateAck(0xC302, 0x0001);
  162. }
  163. }
  164. else
  165. {
  166. //文件头检验异常
  167. CheckFlag = 3;
  168. sendUpdateAck(0xC302, 0x0001);
  169. }
  170. }
  171. else
  172. {
  173. //文件头检验异常
  174. CheckFlag = 3;
  175. sendUpdateAck(0xC302, 0x0001);
  176. }
  177. }
  178. else
  179. {
  180. //文件头检验异常
  181. CheckFlag = 3;
  182. sendUpdateAck(0xC302, 0x0001);
  183. }
  184. }
  185. else if(CheckFlag == 2)
  186. {
  187. //校验正确时按照正常流程接收数据
  188. downLoad.step = 2;
  189. downLoad.dataBuff_128B = (CD_UINT8 *)frameCrcBuff + FRAME_HEAD + PACKAGE_DATA_HEAD + 2;//帧头(2bytes)+ID(2bytes)+Mode(1bytes)+长度(1byte)+命令字(2bytes)+数据标签(5bytes)
  190. downLoad.packagecount = (frameCrcBuff[10] << 8) + frameCrcBuff[9] - 1; //文件头占用1包,需要减掉
  191. if(downLoad.packagecount >= 1024)
  192. {
  193. downLoad.packagecount = 0;
  194. }
  195. downLoad.userCmd = CMD_ACK_OK;
  196. downLoad.wrenable = ENABLE;
  197. }
  198. break;
  199. case CMD_UPDATA_END: //结束包
  200. downLoad.step = 3;
  201. update.AckEnable = ENABLE;
  202. downLoad.userCmd = CMD_ACK_EOT;
  203. break;
  204. case 0x2505:
  205. downLoad.step = 5;
  206. update.AckEnable = ENABLE;
  207. break;
  208. default:
  209. cd_DelChar(ptCANRx, 1);
  210. break;
  211. }
  212. }
  213. else
  214. {
  215. cd_DelChar(ptCANRx, 1);
  216. }
  217. }
  218. }
  219. void sendBootInfo(void)
  220. {
  221. #if defined CAN_125K
  222. static CD_UINT8 bootInfoBuff[22]={ FRAME_HEAD1,FRAME_HEAD2,0x07,0x15,0x0C,0x0B,0xC1,0x09,'M','C',' ','V','1','.','5','.','0',0x00,0x00,0x00,0x00,0xF0 };//版本号: MC V2.0.0
  223. #elif defined CAN_250K
  224. static CD_UINT8 bootInfoBuff[22]={ FRAME_HEAD1,FRAME_HEAD2,0x07,0x15,0x0C,0x0B,0xC1,0x09,'M','C',' ','V','2','.','5','.','0',0x00,0x00,0x00,0x00,0xF0 };//版本号: MC V2.0.0
  225. #endif
  226. CD_UINT32 crc32Ret;
  227. //static CD_UINT8 ucInit_flag = 0;
  228. uint8_t i;
  229. crc32Ret = CRC32_Calculate( (CD_UINT8 *)bootInfoBuff,17 );
  230. bootInfoBuff[17] = (CD_UINT8)( crc32Ret >> 24 );
  231. bootInfoBuff[18] = (CD_UINT8)( crc32Ret >> 16 );
  232. bootInfoBuff[19] = (CD_UINT8)( crc32Ret >> 8 );
  233. bootInfoBuff[20] = (CD_UINT8)( crc32Ret );
  234. /*发送第1包数据*/
  235. hcan.pTxMsg->StdId = CAN_RxBuf_Struct1.ID;
  236. hcan.pTxMsg->DLC = 8;
  237. hcan.pTxMsg->Data[0] = bootInfoBuff[0];
  238. hcan.pTxMsg->Data[1] = bootInfoBuff[1];
  239. for( i=2;i<8;i++)
  240. {
  241. hcan.pTxMsg->Data[i] = bootInfoBuff[i+2];
  242. }
  243. if(HAL_CAN_Transmit(&hcan,20) == HAL_ERROR)
  244. {
  245. MX_CAN_Init();
  246. }
  247. /*发送第2包数据*/
  248. hcan.pTxMsg->DLC = 8;
  249. for( i=0;i<8;i++)
  250. {
  251. hcan.pTxMsg->Data[i] = bootInfoBuff[i+10];
  252. }
  253. if(HAL_CAN_Transmit(&hcan,20) == HAL_ERROR)
  254. {
  255. MX_CAN_Init();
  256. }
  257. /*发送第3包数据*/
  258. hcan.pTxMsg->DLC = 4;
  259. for( i=0;i<4;i++)
  260. {
  261. hcan.pTxMsg->Data[i] = bootInfoBuff[i+18];
  262. }
  263. if(HAL_CAN_Transmit(&hcan,20) == HAL_ERROR)
  264. {
  265. MX_CAN_Init();
  266. }
  267. }
  268. void sendAck(void)
  269. {
  270. static CD_UINT8 ackBuff_2[16]={ FRAME_HEAD1,FRAME_HEAD2,0x07,0x15,0x0C,0x05,0xA9,0x03,'A','C','K',0x00,0x00,0x00,0x00,0xF0 };
  271. CD_UINT32 crc32Ret;
  272. uint8_t i;
  273. crc32Ret = CRC32_Calculate( (CD_UINT8 *)ackBuff_2,11 );
  274. ackBuff_2[11] = (CD_UINT8)( crc32Ret >> 24 );
  275. ackBuff_2[12] = (CD_UINT8)( crc32Ret >> 16 );
  276. ackBuff_2[13] = (CD_UINT8)( crc32Ret >> 8 );
  277. ackBuff_2[14] = (CD_UINT8)( crc32Ret );
  278. hcan.pTxMsg->StdId = CAN_RxBuf_Struct1.ID;
  279. hcan.pTxMsg->RTR = CAN_RTR_DATA;
  280. hcan.pTxMsg->IDE = CAN_ID_STD;
  281. /*发送第1包数据*/
  282. hcan.pTxMsg->DLC = 8;
  283. hcan.pTxMsg->Data[0] = ackBuff_2[0];
  284. hcan.pTxMsg->Data[1] = ackBuff_2[1];
  285. for( i=2;i<8;i++)
  286. {
  287. hcan.pTxMsg->Data[i] = ackBuff_2[i+2];
  288. }
  289. if(HAL_CAN_Transmit(&hcan,20) == HAL_ERROR)
  290. {
  291. MX_CAN_Init();
  292. }
  293. /*发送第2包数据*/
  294. hcan.pTxMsg->DLC = 6;
  295. for( i=0;i<6;i++)
  296. {
  297. hcan.pTxMsg->Data[i] = ackBuff_2[i+10];
  298. }
  299. if(HAL_CAN_Transmit(&hcan,20) == HAL_ERROR)
  300. {
  301. MX_CAN_Init();
  302. }
  303. }
  304. void sendUpdateAck( CD_UINT16 cmd ,CD_UINT16 packageNum )
  305. {
  306. static CD_UINT8 ackBuff[15]={ FRAME_HEAD1,FRAME_HEAD2,0x07,0x15,0x0C,0x04,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0xF0 };
  307. CD_UINT32 crc32Ret;
  308. //static CD_UINT8 ucInit_flag = 0;
  309. uint8_t i;
  310. ackBuff[6] = (CD_UINT8)(cmd >>8);
  311. ackBuff[7] = (CD_UINT8)cmd;
  312. ackBuff[8] = (CD_UINT8)packageNum;
  313. ackBuff[9] = (CD_UINT8)(packageNum>>8);
  314. crc32Ret = CRC32_Calculate( (CD_UINT8 *)ackBuff, 10);
  315. ackBuff[10] = (CD_UINT8)( crc32Ret >> 24 );
  316. ackBuff[11] = (CD_UINT8)( crc32Ret >> 16 );
  317. ackBuff[12] = (CD_UINT8)( crc32Ret >> 8 );
  318. ackBuff[13] = (CD_UINT8)( crc32Ret );
  319. hcan.pTxMsg->RTR = CAN_RTR_DATA;
  320. hcan.pTxMsg->IDE = CAN_ID_STD;
  321. /*发送第1包数据*/
  322. hcan.pTxMsg->StdId = CAN_RxBuf_Struct1.ID;
  323. hcan.pTxMsg->DLC = 8;
  324. hcan.pTxMsg->Data[0] = ackBuff[0];
  325. hcan.pTxMsg->Data[1] = ackBuff[1];
  326. for( i=2;i<8;i++)
  327. {
  328. hcan.pTxMsg->Data[i] = ackBuff[i+2];
  329. }
  330. if(HAL_CAN_Transmit(&hcan,20) == HAL_ERROR)
  331. {
  332. MX_CAN_Init();
  333. }
  334. /*发送第2包数据*/
  335. hcan.pTxMsg->DLC = 5;
  336. for( i=0;i<5;i++)
  337. {
  338. hcan.pTxMsg->Data[i] = ackBuff[i+10];
  339. }
  340. if(HAL_CAN_Transmit(&hcan,20) == HAL_ERROR)
  341. {
  342. MX_CAN_Init();
  343. }
  344. }
  345. ///*******************************************************************************
  346. //* Function: void A_(uint8_t ucStep,uint8_t ucPackagNum,uint8_t ucAck)
  347. //* Discrible:
  348. //* Input:
  349. //* Output:
  350. //* Return:
  351. //* Others:
  352. //* date version author record
  353. //* -----------------------------------------------
  354. //* 20151107 V1.0 VINCENT Create
  355. //*********************************************************************************/
  356. //void A_(uint8_t ucStep,uint8_t ucPackagNum,uint8_t ucAck)
  357. //{
  358. // static CD_UINT8 ucInit_flag = 0;
  359. // static CD_UINT8 ucAckBuf[9] ={'U','P',0x04,0x00,0x02,0x00,0x00,0x00,0xF0};
  360. //
  361. // CD_UINT8 ucXor = 0x00;
  362. //
  363. // ucXor ^= ucAckBuf[2];
  364. // ucAckBuf[3] = ucStep;
  365. // ucXor ^= ucStep;
  366. // ucXor ^= ucAckBuf[4];
  367. // ucAckBuf[5] = ucPackagNum;
  368. // ucXor ^= ucPackagNum;
  369. // ucAckBuf[6] = ucAck;
  370. // ucXor ^= ucAck;
  371. // ucAckBuf[7] = ucXor;
  372. //
  373. // if(ucInit_flag == 0)
  374. // {
  375. // ucInit_flag = 1;
  376. // hcan.pTxMsg->ExtId = 0x01;
  377. // hcan.pTxMsg->RTR = CAN_RTR_DATA;
  378. // hcan.pTxMsg->IDE = CAN_ID_STD;
  379. // }
  380. //
  381. // hcan.pTxMsg->StdId = CAN_RxBuf_Struct1.ID;
  382. // hcan.pTxMsg->DLC = 8;
  383. // memset(hcan.pTxMsg->Data,0,8);
  384. // for(uint8_t i=0;i<hcan.pTxMsg->DLC;i++)
  385. // {
  386. // hcan.pTxMsg->Data[i] = ucAckBuf[i];
  387. // }
  388. //
  389. // if(HAL_CAN_Transmit(&hcan,20) == HAL_ERROR)
  390. // {
  391. // MX_CAN_Init();
  392. // }
  393. // memset(hcan.pTxMsg->Data,0,8);
  394. // hcan.pTxMsg->DLC = 1;
  395. // hcan.pTxMsg->Data[0] = ucAckBuf[8];
  396. //
  397. // if(HAL_CAN_Transmit(&hcan,20) == HAL_ERROR)
  398. // {
  399. // MX_CAN_Init();
  400. // }
  401. //}
  402. /************************ (C) END OF FILE *********************************/