can_app.c 13 KB

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