can_app.c 11 KB

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