can_app.c 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431
  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. /* Private variables ---------------------------------------------------------*/
  45. /*******************************************************************************
  46. * Function: void CAN_RxData_Process(CAN_Buf_TypeDef*ptCANRx)
  47. * Discrible:
  48. * Input:
  49. * Output:
  50. * Return:
  51. * Others:
  52. * date version author record
  53. * -----------------------------------------------
  54. * 20151107 V1.0 VINCENT Create
  55. *********************************************************************************/
  56. void CA_RxData_Process(CAN_Buf_TypeDef*ptCANRx)
  57. {
  58. CD_UINT8 ucHeadHighByte,ucHeadLowByte,ucFrameMode;
  59. //CD_UINT8 file_headTail[PACKET_128B_SIZE]={0},file_body[PACKET_1K_SIZE]={0};
  60. CD_UINT16 i ;
  61. CD_UINT8 ucFrameLength,ucTrail;
  62. CD_UINT16 ucKeyCmd;
  63. CD_UINT32 ucCRCSum,CrcTemp;
  64. static CD_UINT8 frameCrcBuff[FRAME_DATA_SIZE+2];
  65. if((*ptCANRx).ucBufCnt > 11)
  66. {
  67. ucHeadHighByte = cd_ReadChar(ptCANRx,0); //帧头1
  68. ucHeadLowByte = cd_ReadChar(ptCANRx,1); //帧头2
  69. if((PRO_HEAD1 == ucHeadHighByte)&&(PRO_HEAD2 == ucHeadLowByte))
  70. {
  71. ucFrameMode = cd_ReadChar(ptCANRx,2);
  72. ucFrameLength = cd_ReadChar(ptCANRx,3);
  73. ucKeyCmd = ((CD_UINT16)cd_ReadChar(ptCANRx,4) << 8 ) + ((CD_UINT16)cd_ReadChar(ptCANRx,5));
  74. if( FRAME_MODE_WRITE != ucFrameMode)
  75. {
  76. cd_DelChar(ptCANRx, 1);
  77. return;
  78. }
  79. if((*ptCANRx).ucBufCnt <(ucFrameLength + 4 + 5 )) return;
  80. frameCrcBuff[0] = FRAME_HEAD1;
  81. frameCrcBuff[1] = FRAME_HEAD2;
  82. frameCrcBuff[2] = 0x07;
  83. frameCrcBuff[3] = 0x51;
  84. ucTrail = cd_ReadChar(ptCANRx,ucFrameLength + 4 + 4 );
  85. if(PRO_TAIL != ucTrail)
  86. {
  87. /*帧尾错误*/
  88. cd_DelChar(ptCANRx, 1);
  89. update.AckEnable = ENABLE;
  90. downLoad.userCmd = CMD_ACK_ERR;
  91. downLoad.step = 0xf0;
  92. return ;
  93. }
  94. ucCRCSum = (cd_ReadChar(ptCANRx,ucFrameLength + 4 ) << 24) + \
  95. (cd_ReadChar(ptCANRx,ucFrameLength + 4 + 1 ) << 16) + \
  96. (cd_ReadChar(ptCANRx,ucFrameLength + 4 + 2 ) << 8) + \
  97. cd_ReadChar(ptCANRx,ucFrameLength + 4 + 3 ) ;
  98. for(i=2; i< ( ucFrameLength + 4 ); i++)
  99. {
  100. frameCrcBuff[i+2] = cd_ReadChar(ptCANRx,i);
  101. }
  102. /*CRC 校验*/
  103. CrcTemp = CRC32_Calculate( (CD_UINT8 *)frameCrcBuff, (ucFrameLength + 4 + 2 ) );
  104. if( ucCRCSum != CrcTemp)
  105. {
  106. update.AckEnable = ENABLE;
  107. downLoad.userCmd = CMD_ACK_ERR;
  108. downLoad.step = 0xf1;
  109. cd_DelChar(ptCANRx, (ucFrameLength + 4 + 5 ));
  110. return ;
  111. }
  112. cd_DelChar(ptCANRx, (ucFrameLength + 4 + 5 ));
  113. /*清除超时标志*/
  114. update.TimeCounter_Update = 0;
  115. switch(ucKeyCmd)
  116. {
  117. case CMD_UPDATA: //升级指令
  118. //准备升级
  119. if(downLoad.step != 1)
  120. {
  121. downLoad.step = 1;
  122. update.AckEnable = ENABLE;
  123. downLoad.userCmd = CMD_ACK_REQ;
  124. // /********************test*******************************/
  125. // downLoad.userCmd = CMD_ACK_ERR;
  126. downLoad.packageSize = *(uint32_t *)(frameCrcBuff + 15);
  127. /*擦除FLASH,剩余最后8k没有擦除,保留其他功能使用**/
  128. FLASH_If_Erase(APPLICATION_ADDRESS); //擦除时间约120ms
  129. /*清空flash写标志*/
  130. for(i=0;i<1024;i++)
  131. {
  132. flag_FlashWR[i] = 0;
  133. }
  134. /*清除超时标志*/
  135. update.TimeCounter_Startup = 0;
  136. }
  137. break;
  138. case CMD_PACKAGE_DATA: //数据包
  139. downLoad.step = 2;
  140. downLoad.dataBuff_128B = (CD_UINT8 *)frameCrcBuff + FRAME_HEAD + PACKAGE_DATA_HEAD + 2;
  141. downLoad.packagecount = (frameCrcBuff[10] << 8) + frameCrcBuff[9];
  142. if(downLoad.packagecount >= 1024)
  143. {
  144. downLoad.packagecount = 0;
  145. }
  146. downLoad.userCmd = CMD_ACK_OK;
  147. downLoad.wrenable = ENABLE;
  148. // /********************test*******************************/
  149. // if(downLoad.packagecount == 2)
  150. // {
  151. // downLoad.userCmd = CMD_ACK_ERR;
  152. // }
  153. break;
  154. case CMD_UPDATA_END: //结束包
  155. downLoad.step = 3;
  156. update.AckEnable = ENABLE;
  157. downLoad.userCmd = CMD_ACK_EOT;
  158. break;
  159. case 0x2505:
  160. downLoad.step = 5;
  161. update.AckEnable = ENABLE;
  162. break;
  163. default:
  164. cd_DelChar(ptCANRx, 1);
  165. break;
  166. }
  167. }
  168. else
  169. {
  170. cd_DelChar(ptCANRx, 1);
  171. }
  172. }
  173. }
  174. void sendBootInfo(void)
  175. {
  176. static CD_UINT8 bootInfoBuff[22]={ FRAME_HEAD1,FRAME_HEAD2,0x07,0x15,0x0C,0x0B,0xC1,0x09,'M','C',' ','V','2','.','2','.','0',0x00,0x00,0x00,0x00,0xF0 };//版本号: MC V2.1.0
  177. CD_UINT32 crc32Ret;
  178. //static CD_UINT8 ucInit_flag = 0;
  179. uint8_t i;
  180. crc32Ret = CRC32_Calculate( (CD_UINT8 *)bootInfoBuff,17 );
  181. bootInfoBuff[17] = (CD_UINT8)( crc32Ret >> 24 );
  182. bootInfoBuff[18] = (CD_UINT8)( crc32Ret >> 16 );
  183. bootInfoBuff[19] = (CD_UINT8)( crc32Ret >> 8 );
  184. bootInfoBuff[20] = (CD_UINT8)( crc32Ret );
  185. /*发送第1包数据*/
  186. hcan.pTxMsg->StdId = CAN_RxBuf_Struct1.ID;
  187. hcan.pTxMsg->DLC = 8;
  188. hcan.pTxMsg->Data[0] = bootInfoBuff[0];
  189. hcan.pTxMsg->Data[1] = bootInfoBuff[1];
  190. for( i=2;i<8;i++)
  191. {
  192. hcan.pTxMsg->Data[i] = bootInfoBuff[i+2];
  193. }
  194. if(HAL_CAN_Transmit(&hcan,20) == HAL_ERROR)
  195. {
  196. MX_CAN_Init();
  197. }
  198. /*发送第2包数据*/
  199. hcan.pTxMsg->DLC = 8;
  200. for( i=0;i<8;i++)
  201. {
  202. hcan.pTxMsg->Data[i] = bootInfoBuff[i+10];
  203. }
  204. if(HAL_CAN_Transmit(&hcan,20) == HAL_ERROR)
  205. {
  206. MX_CAN_Init();
  207. }
  208. /*发送第3包数据*/
  209. hcan.pTxMsg->DLC = 4;
  210. for( i=0;i<4;i++)
  211. {
  212. hcan.pTxMsg->Data[i] = bootInfoBuff[i+18];
  213. }
  214. if(HAL_CAN_Transmit(&hcan,20) == HAL_ERROR)
  215. {
  216. MX_CAN_Init();
  217. }
  218. }
  219. void sendAck(void)
  220. {
  221. static CD_UINT8 ackBuff_2[16]={ FRAME_HEAD1,FRAME_HEAD2,0x07,0x15,0x0C,0x05,0xA9,0x03,'A','C','K',0x00,0x00,0x00,0x00,0xF0 };
  222. CD_UINT32 crc32Ret;
  223. uint8_t i;
  224. crc32Ret = CRC32_Calculate( (CD_UINT8 *)ackBuff_2,11 );
  225. ackBuff_2[11] = (CD_UINT8)( crc32Ret >> 24 );
  226. ackBuff_2[12] = (CD_UINT8)( crc32Ret >> 16 );
  227. ackBuff_2[13] = (CD_UINT8)( crc32Ret >> 8 );
  228. ackBuff_2[14] = (CD_UINT8)( crc32Ret );
  229. hcan.pTxMsg->StdId = CAN_RxBuf_Struct1.ID;
  230. hcan.pTxMsg->RTR = CAN_RTR_DATA;
  231. hcan.pTxMsg->IDE = CAN_ID_STD;
  232. /*发送第1包数据*/
  233. hcan.pTxMsg->DLC = 8;
  234. hcan.pTxMsg->Data[0] = ackBuff_2[0];
  235. hcan.pTxMsg->Data[1] = ackBuff_2[1];
  236. for( i=2;i<8;i++)
  237. {
  238. hcan.pTxMsg->Data[i] = ackBuff_2[i+2];
  239. }
  240. if(HAL_CAN_Transmit(&hcan,20) == HAL_ERROR)
  241. {
  242. MX_CAN_Init();
  243. }
  244. /*发送第2包数据*/
  245. hcan.pTxMsg->DLC = 6;
  246. for( i=0;i<6;i++)
  247. {
  248. hcan.pTxMsg->Data[i] = ackBuff_2[i+10];
  249. }
  250. if(HAL_CAN_Transmit(&hcan,20) == HAL_ERROR)
  251. {
  252. MX_CAN_Init();
  253. }
  254. }
  255. void sendUpdateAck( CD_UINT16 cmd ,CD_UINT16 packageNum )
  256. {
  257. static CD_UINT8 ackBuff[15]={ FRAME_HEAD1,FRAME_HEAD2,0x07,0x15,0x0C,0x04,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0xF0 };
  258. CD_UINT32 crc32Ret;
  259. //static CD_UINT8 ucInit_flag = 0;
  260. uint8_t i;
  261. ackBuff[6] = (CD_UINT8)(cmd >>8);
  262. ackBuff[7] = (CD_UINT8)cmd;
  263. ackBuff[8] = (CD_UINT8)packageNum;
  264. ackBuff[9] = (CD_UINT8)(packageNum>>8);
  265. crc32Ret = CRC32_Calculate( (CD_UINT8 *)ackBuff, 10);
  266. ackBuff[10] = (CD_UINT8)( crc32Ret >> 24 );
  267. ackBuff[11] = (CD_UINT8)( crc32Ret >> 16 );
  268. ackBuff[12] = (CD_UINT8)( crc32Ret >> 8 );
  269. ackBuff[13] = (CD_UINT8)( crc32Ret );
  270. hcan.pTxMsg->RTR = CAN_RTR_DATA;
  271. hcan.pTxMsg->IDE = CAN_ID_STD;
  272. /*发送第1包数据*/
  273. hcan.pTxMsg->StdId = CAN_RxBuf_Struct1.ID;
  274. hcan.pTxMsg->DLC = 8;
  275. hcan.pTxMsg->Data[0] = ackBuff[0];
  276. hcan.pTxMsg->Data[1] = ackBuff[1];
  277. for( i=2;i<8;i++)
  278. {
  279. hcan.pTxMsg->Data[i] = ackBuff[i+2];
  280. }
  281. if(HAL_CAN_Transmit(&hcan,20) == HAL_ERROR)
  282. {
  283. MX_CAN_Init();
  284. }
  285. /*发送第2包数据*/
  286. hcan.pTxMsg->DLC = 5;
  287. for( i=0;i<5;i++)
  288. {
  289. hcan.pTxMsg->Data[i] = ackBuff[i+10];
  290. }
  291. if(HAL_CAN_Transmit(&hcan,20) == HAL_ERROR)
  292. {
  293. MX_CAN_Init();
  294. }
  295. }
  296. ///*******************************************************************************
  297. //* Function: void A_(uint8_t ucStep,uint8_t ucPackagNum,uint8_t ucAck)
  298. //* Discrible:
  299. //* Input:
  300. //* Output:
  301. //* Return:
  302. //* Others:
  303. //* date version author record
  304. //* -----------------------------------------------
  305. //* 20151107 V1.0 VINCENT Create
  306. //*********************************************************************************/
  307. //void A_(uint8_t ucStep,uint8_t ucPackagNum,uint8_t ucAck)
  308. //{
  309. // static CD_UINT8 ucInit_flag = 0;
  310. // static CD_UINT8 ucAckBuf[9] ={'U','P',0x04,0x00,0x02,0x00,0x00,0x00,0xF0};
  311. //
  312. // CD_UINT8 ucXor = 0x00;
  313. //
  314. // ucXor ^= ucAckBuf[2];
  315. // ucAckBuf[3] = ucStep;
  316. // ucXor ^= ucStep;
  317. // ucXor ^= ucAckBuf[4];
  318. // ucAckBuf[5] = ucPackagNum;
  319. // ucXor ^= ucPackagNum;
  320. // ucAckBuf[6] = ucAck;
  321. // ucXor ^= ucAck;
  322. // ucAckBuf[7] = ucXor;
  323. //
  324. // if(ucInit_flag == 0)
  325. // {
  326. // ucInit_flag = 1;
  327. // hcan.pTxMsg->ExtId = 0x01;
  328. // hcan.pTxMsg->RTR = CAN_RTR_DATA;
  329. // hcan.pTxMsg->IDE = CAN_ID_STD;
  330. // }
  331. //
  332. // hcan.pTxMsg->StdId = CAN_RxBuf_Struct1.ID;
  333. // hcan.pTxMsg->DLC = 8;
  334. // memset(hcan.pTxMsg->Data,0,8);
  335. // for(uint8_t i=0;i<hcan.pTxMsg->DLC;i++)
  336. // {
  337. // hcan.pTxMsg->Data[i] = ucAckBuf[i];
  338. // }
  339. //
  340. // if(HAL_CAN_Transmit(&hcan,20) == HAL_ERROR)
  341. // {
  342. // MX_CAN_Init();
  343. // }
  344. // memset(hcan.pTxMsg->Data,0,8);
  345. // hcan.pTxMsg->DLC = 1;
  346. // hcan.pTxMsg->Data[0] = ucAckBuf[8];
  347. //
  348. // if(HAL_CAN_Transmit(&hcan,20) == HAL_ERROR)
  349. // {
  350. // MX_CAN_Init();
  351. // }
  352. //}
  353. /************************ (C) END OF FILE *********************************/