soft_update.c 28 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909
  1. #include "soft_update.h"
  2. #include "soft_obstacle.h"
  3. #include "soft_terrain.h"
  4. #include "string.h"
  5. #include "soft_usart.h"
  6. #include "soft_device.h"
  7. #include "soft_can.h"
  8. #include "main_task.h"
  9. #include "soft_crc.h"
  10. #include "usart_data_handle.h"
  11. #include "config.h"
  12. bool radar_update_flag = false;
  13. Radar Rupdate;
  14. /**
  15. * @file can_recv_mocib_updata_read_set_hookfunction
  16. * @brief 莫之比协议升级
  17. * @param
  18. * @details
  19. * @author Zhang Sir
  20. **/
  21. bool uavrhup_getr1_ack = false;
  22. void can_recv_mocib_updata_read_set_hookfunction(uint32_t cellCanID, uint8_t data[])
  23. {
  24. //AG代码 和雷达升级不兼容,优先升级
  25. if (Rupdate.update_flag == true)
  26. {
  27. //避障雷达升级
  28. if (Rupdate.buf_flag == false)
  29. {
  30. memcpy(Rupdate.update_buf, data, 8);
  31. Rupdate.buf_flag = true;
  32. switch (cellCanID)
  33. {
  34. case 0x7E1:
  35. Rupdate.U7E1 = true;
  36. break;
  37. case 0x7E3:
  38. Rupdate.U7E3 = true;
  39. break;
  40. case 0x7E6:
  41. Rupdate.U7E6 = true;
  42. break;
  43. default:
  44. break;
  45. }
  46. }
  47. }
  48. else
  49. {
  50. switch (cellCanID)
  51. {
  52. //莫之比雷达反馈版本信息
  53. case 0X7E1:
  54. uavrhup_getr1_ack = true;
  55. break;
  56. //莫之比雷达设置灵敏度及反馈
  57. case CAN_UAVRH_SENSI_SA:
  58. if (data[0] == 0x11)
  59. {
  60. uavr11_info.set_radar_sensi_ack = true;
  61. //莫之比大端模式
  62. uavr11_info.get_radar_sensi = ((data[1] << 8) & 0xff00) + data[2];
  63. }
  64. else if (data[0] == 0x12)
  65. {
  66. uavr12_info.set_radar_sensi_ack = true;
  67. //莫之比大端模式
  68. uavr12_info.get_radar_sensi = ((data[1] << 8) & 0xff00) + data[2];
  69. }
  70. else if(data[0] == 0x0B)
  71. {
  72. uavr56_info.set_radar_sensi_ack = true;
  73. uavr56_info.get_radar_sensi = ((data[1] << 8) & 0xff00) + data[2];
  74. }
  75. break;
  76. //莫之比雷达读取灵敏度及反馈
  77. case CAN_UAVRH_SENSI_RA:
  78. if (data[0] == 0x11)
  79. {
  80. uavr11_info.get_radar_sensi_flag = true;
  81. //莫之比大端模式
  82. uavr11_info.get_radar_sensi = ((data[1] << 8) & 0xff00) + data[2];
  83. }
  84. else if (data[0] == 0x12)
  85. {
  86. uavr12_info.get_radar_sensi_flag = true; //莫之比大端模式
  87. uavr12_info.get_radar_sensi = ((data[1] << 8) & 0xff00) + data[2];
  88. }
  89. else if(data[0] == 0x0B)
  90. {
  91. uavr56_info.get_radar_sensi_flag = true;
  92. uavr56_info.get_radar_sensi = ((data[1] << 8) & 0xff00) + data[2];
  93. }
  94. default:
  95. break;
  96. }
  97. }
  98. }
  99. /**
  100. * @file Vk_Update_Device_Protocol
  101. * @brief VK协议设备升级
  102. * @param
  103. * @details
  104. * @author Zhang Sir
  105. **/
  106. uint8_t Factory_DevId[3] = {0};
  107. Update update_info;
  108. void Vk_Update_Device_Protocol(void)
  109. {
  110. static uint32_t send_msgtime_2HZ = 0;
  111. if(uart_send_is_ok(USART_1) == true)
  112. {
  113. if(update_info.step_200_flag == true )
  114. {
  115. Update_ack_func(update_info.buf[DEVICE],200,&update_info.buf[PACK_NUM]);
  116. update_info.step_200_flag = false;
  117. }
  118. else if(update_info.step_201_flag == true)
  119. {
  120. Update_ack_func(update_info.buf[DEVICE],201,&update_info.buf[PACK_NUM]);
  121. update_info.step_201_flag = false;
  122. }
  123. else if(update_info.step_202_flag == true)
  124. {
  125. Update_ack_func(update_info.buf[DEVICE],202,&update_info.buf[PACK_NUM]);
  126. update_info.step_202_flag = false;
  127. }
  128. }
  129. if(update_info.vk_dev_update_flag == false)
  130. return;
  131. if(HAL_GetTick() - send_msgtime_2HZ < 100)
  132. return;
  133. send_msgtime_2HZ = HAL_GetTick();
  134. uint16_t crc = 0;
  135. uint8_t can_buf[8] = {0};
  136. uint8_t i = 0;
  137. uint8_t dev_id = 0;
  138. //FMUPMU协议ID号10进制,设备升级协议16进制
  139. if(update_info.buf[DEVICE] == 56)
  140. dev_id = 0x56;
  141. else if(update_info.buf[DEVICE] == 51)
  142. dev_id = 0x11;
  143. else if(update_info.buf[DEVICE] == 52)
  144. dev_id = 0x12;
  145. else
  146. dev_id = update_info.buf[DEVICE];
  147. switch (update_info.buf[UPDATE_STEP])
  148. {
  149. case UPDATE_START:
  150. can_buf[0] = dev_id;
  151. memcpy(&can_buf[1],&update_info.buf[PAYLOAD - 2],4);
  152. switch (can_buf[0])
  153. {
  154. case UPDATE_OBS_F:
  155. if(Dev.Radar.facid_F == FAC_MIMO_RF || Dev.Part_radarF.facid == FAC_MIMO_RF)
  156. {
  157. memcpy(&can_buf[5],"TR0",3);
  158. }
  159. break;
  160. case UPDATE_OBS_B:
  161. if(Dev.Radar.facid_B == FAC_MIMO_RB || Dev.Part_radarB.facid == FAC_MIMO_RB)
  162. {
  163. memcpy(&can_buf[5],"TR0",3);
  164. }
  165. break;
  166. case UPDATE_TERAIN:
  167. if(Dev.Radar.facid_T == FAC_MIMO_RT || Dev.Part_radarT.facid == FAC_MIMO_RT)
  168. {
  169. memcpy(&can_buf[5],"TR0",3);
  170. }
  171. break;
  172. case UPDATE_OBS360:
  173. break;
  174. case UPDATE_SEED:
  175. break;
  176. case UPDATE_FLOW:
  177. break;
  178. case UPDATE_BMS:
  179. break;
  180. case UPDATE_DISTOR:
  181. break;
  182. case UPDATE_WEIGHT:
  183. if(Dev.Weight.facid == FAC_VK)
  184. {
  185. memcpy(&can_buf[5],"VK1",3);
  186. }
  187. break;
  188. default:
  189. break;
  190. }
  191. Can_Send_Msg_Func(CANID1, can_buf, 8, 0x381400, CAN_ID_EXT);
  192. break;
  193. case UPDATE_ING:
  194. while (i < (update_info.buf[LEN] - 2 + 8) && update_info.vk_dev_pack_num == (update_info.buf[PACK_NUM] + update_info.buf[PACK_NUM + 1] * 256))
  195. {
  196. if(i == 0)
  197. {
  198. crc = Get_Crc16( &update_info.buf[PAYLOAD],update_info.buf[LEN] - 2);
  199. can_buf[0] = 0xFE;
  200. can_buf[1] = 0xFE;
  201. can_buf[2] = dev_id;
  202. can_buf[3] = update_info.buf[LEN] - 2;
  203. can_buf[4] = update_info.buf[PACK_NUM];
  204. can_buf[5] = update_info.buf[PACK_NUM + 1];
  205. can_buf[6] = crc & 0xff;
  206. can_buf[7] = (crc >> 8) & 0xff;
  207. }
  208. else
  209. {
  210. memcpy(&can_buf[0],&update_info.buf[i],8);
  211. }
  212. i += 8;
  213. Can_Send_Msg_Func(CANID1, can_buf, 8, 0x401400, CAN_ID_EXT);
  214. memset(&can_buf[0],0,8);
  215. }
  216. break;
  217. case UPDATE_END:
  218. can_buf[0] = dev_id;
  219. Can_Send_Msg_Func(CANID1, can_buf, 8, 0x481400, CAN_ID_EXT);
  220. update_info.vk_dev_update_flag = false;
  221. break;
  222. default:
  223. break;
  224. }
  225. }
  226. void Update_Dev_Bootversion_Function(uint8_t data[])
  227. {
  228. if(data[4] != 0x01)
  229. return;
  230. pmu_send = PMU_SEND_VERSION;
  231. switch (data[0])
  232. {
  233. case UPDATE_OBS_F:
  234. if(memcmp((char *)&data[1],"TR0",3) == 0)
  235. {
  236. mimo_f_info.Link.connect_status = COMP_NORMAL;
  237. mimo_f_info.Link.recv_time = HAL_GetTick();
  238. mimo_f_info.Link.boot_flag = true;
  239. Dev.Radar.facid_F = FAC_MIMO_RF;
  240. }
  241. break;
  242. case UPDATE_OBS_B:
  243. if(memcmp((char *)&data[1],"TR0",3) == 0)
  244. {
  245. mimo_b_info.Link.connect_status = COMP_NORMAL;
  246. mimo_b_info.Link.recv_time = HAL_GetTick();
  247. mimo_b_info.Link.boot_flag = true;
  248. Dev.Radar.facid_B = FAC_MIMO_RB;
  249. }
  250. break;
  251. case UPDATE_TERAIN:
  252. if(memcmp((char *)&data[1],"TR0",3) == 0)
  253. {
  254. mimo_ter_info.Link.connect_status = COMP_NORMAL;
  255. mimo_ter_info.Link.recv_time = HAL_GetTick();
  256. mimo_ter_info.Link.boot_flag = true;
  257. Dev.Radar.facid_T = FAC_MIMO_RT;
  258. }
  259. break;
  260. case UPDATE_OBS360:
  261. break;
  262. case UPDATE_SEED:
  263. break;
  264. case UPDATE_FLOW:
  265. break;
  266. case UPDATE_BMS:
  267. break;
  268. case UPDATE_DISTOR:
  269. break;
  270. case UPDATE_WEIGHT:
  271. if(memcmp((char *)&data[1],"VK1",3) == 0)
  272. {
  273. }
  274. break;
  275. default:
  276. break;
  277. }
  278. }
  279. /**
  280. * @file Can_obstacle_update
  281. * @brief 莫之比雷达CAN口在线升级函数
  282. * @param 0=发送升级请求 1=接收请求升级状态 2=发送格式化指令
  283. * 3=接收格式化状态 4=向雷达发送升级包 5=发送校验和 6=接收雷达固件更新状态
  284. * @details
  285. * @author Zhang Sir
  286. **/
  287. uint32_t update_count = 0;
  288. void Can_obstacle_update()
  289. {
  290. static uint32_t update_i = 0;
  291. static uint32_t check_sum = 0;
  292. static uint16_t pack_count = 1;
  293. uint16_t size_count = 0;
  294. uint32_t for_i = 0;
  295. uint8_t obstacle_buf[8] = {0};
  296. switch (update_count)
  297. {
  298. case 0:
  299. //向雷达发送请求升级
  300. if (update_info.buf[4] == 51)
  301. {
  302. obstacle_buf[0] = 0x11; // 前雷达
  303. }
  304. else if (update_info.buf[4] == 52)
  305. {
  306. obstacle_buf[0] = 0x12; //后雷达
  307. }
  308. else if (update_info.buf[4] == 56)
  309. {
  310. obstacle_buf[0] = 0x0B;
  311. }
  312. HAL_Delay(100);
  313. Can_Send_Msg_Func(CANID1, obstacle_buf, 1, 0x7E0, CAN_ID_EXT);
  314. update_count = 1;
  315. break;
  316. case 1:
  317. if (Rupdate.buf_flag == true && Rupdate.U7E1 == true)
  318. {
  319. if (Rupdate.update_buf[1] == 0x00) //radar_update_buf[0] 0x11 0x12
  320. {
  321. //雷达进入刷写模式
  322. update_count = 2;
  323. }
  324. else if (Rupdate.update_buf[1] == 0x01)
  325. { //退出刷写模式
  326. radar_update_flag = false; //关闭升级
  327. update_count = 0;
  328. }
  329. Rupdate.U7E1 = false;
  330. Rupdate.buf_flag = false;
  331. memset(Rupdate.update_buf,0,8);
  332. }
  333. break;
  334. case 2:
  335. memset(obstacle_buf, 0, 8);
  336. obstacle_buf[0] = 0x01;
  337. obstacle_buf[1] = 0x09;
  338. obstacle_buf[2] = 0x09;
  339. obstacle_buf[3] = 0x04;
  340. obstacle_buf[4] = 0x00;
  341. obstacle_buf[5] = 0x09;
  342. obstacle_buf[6] = 0x02;
  343. obstacle_buf[7] = 0x06;
  344. HAL_Delay(100);
  345. Can_Send_Msg_Func(CANID1, obstacle_buf, 8, 0x7E2, CAN_ID_EXT);
  346. update_count = 3;
  347. break;
  348. case 3:
  349. if (Rupdate.buf_flag == true && Rupdate.U7E3 == true)
  350. {
  351. if (Rupdate.update_buf[0] == 0xA6)
  352. { //格式化成功
  353. update_count = 4;
  354. update_i = 16;
  355. Update_ack_func(update_info.buf[4], 200, &update_info.buf[6]);
  356. update_info.use_update_buf_flag = false;
  357. //防止连续升级
  358. check_sum = 0;
  359. }
  360. else if (Rupdate.update_buf[0] == 0xA8)
  361. { //格式化失败
  362. radar_update_flag = false;
  363. Rupdate.update_flag = false;
  364. update_count = 0;
  365. }
  366. Rupdate.U7E3 = false;
  367. Rupdate.buf_flag = false;
  368. }
  369. break;
  370. case 4:
  371. if (update_info.use_update_buf_flag == true)
  372. {
  373. if (update_info.buf[5] == 201)
  374. {
  375. memcpy(&size_count, &update_info.buf[6], 2);
  376. if (pack_count == size_count)
  377. { //防止发送相同包
  378. // 第一包前8字节不要 第二包开始发送全部128字节
  379. Can_Send_Msg_Func(CANID1, &update_info.buf[update_i], 8, 0x7E4, CAN_ID_EXT);
  380. for (for_i = 0; for_i < 8; for_i++) // 计算校验
  381. {
  382. check_sum += update_info.buf[update_i + for_i];
  383. }
  384. update_i += 8;
  385. if (update_i >= 136)
  386. {
  387. update_i = 8;
  388. pack_count++;
  389. Update_ack_func(update_info.buf[4], 201, &update_info.buf[6]);
  390. memset(&update_info.buf[0], 0, 150);
  391. update_info.use_update_buf_flag = false;
  392. }
  393. }
  394. else if(pack_count > size_count)
  395. {
  396. Update_ack_func(update_info.buf[4], 201, &update_info.buf[6]);
  397. update_info.use_update_buf_flag = false;
  398. }
  399. }
  400. else if (update_info.buf[5] == 202)
  401. {
  402. //串口结束标志
  403. Update_ack_func(update_info.buf[4], 202, &update_info.buf[6]);
  404. update_count = 5;
  405. update_info.use_update_buf_flag = false;
  406. }
  407. else if (update_info.buf[5] == 200)
  408. {
  409. Update_ack_func(update_info.buf[4], 200, &update_info.buf[6]);
  410. update_info.use_update_buf_flag = false;
  411. }
  412. else
  413. {
  414. update_info.use_update_buf_flag = false;
  415. }
  416. }
  417. break;
  418. case 5:
  419. memset(obstacle_buf, 0, 8);
  420. obstacle_buf[0] = (check_sum >> 24) & 0xff;
  421. obstacle_buf[1] = (check_sum >> 16) & 0xff;
  422. obstacle_buf[2] = (check_sum >> 8) & 0xff;
  423. obstacle_buf[3] = (check_sum)&0xff;
  424. Can_Send_Msg_Func(CANID1, obstacle_buf, 4, 0x7E5, CAN_ID_EXT);
  425. update_count = 6;
  426. break;
  427. case 6:
  428. if (Rupdate.buf_flag == true && Rupdate.U7E6 == true)
  429. {
  430. if (Rupdate.update_buf[0] == 0x66)
  431. {
  432. update_count = 0; //更新成功
  433. }
  434. else if (Rupdate.update_buf[0] == 0x88)
  435. {
  436. update_count = 0; //校验失败
  437. }
  438. else if (Rupdate.update_buf[0] == 0xff)
  439. {
  440. update_count = 0; //表示固件超出最大存储空间, bootloader将重新格式化扇区,并将版本回退到出厂固件??
  441. }
  442. pack_count = 1;
  443. Rupdate.buf_flag = false;
  444. radar_update_flag = false;
  445. Rupdate.update_flag = false;
  446. Rupdate.U7E6 = false;
  447. //重新发送版本信息
  448. uavr11_info.get_radar_ver_flag = false;
  449. uavr12_info.get_radar_ver_flag = false;
  450. uavr56_info.get_radar_ver_flag = false;
  451. }
  452. break;
  453. default:
  454. break;
  455. }
  456. }
  457. /**
  458. * @file mimo_obs_update_func
  459. * @brief EZ雷达升级
  460. * @param
  461. * @details
  462. * @author Zhang Sir
  463. **/
  464. uint8_t radar_node_id = 0;
  465. ez_update EZup_par;
  466. void mimo_obs_update_func(void)
  467. {
  468. static uint32_t send_msgtime_5HZ = 0;
  469. if(uart_send_is_ok(USART_1) == true)
  470. {
  471. if(update_info.step_200_flag == true )
  472. {
  473. Update_ack_func(update_info.buf[DEVICE],200,&update_info.buf[PACK_NUM]);
  474. update_info.step_200_flag = false;
  475. }
  476. else if(update_info.step_201_flag == true)
  477. {
  478. Update_ack_func(update_info.buf[DEVICE],201,&update_info.buf[PACK_NUM]);
  479. update_info.step_201_flag = false;
  480. }
  481. else if(update_info.step_202_flag == true)
  482. {
  483. Update_ack_func(update_info.buf[DEVICE],202,&update_info.buf[PACK_NUM]);
  484. update_info.step_202_flag = false;
  485. }
  486. }
  487. if(EZup_par.update_flag != true)
  488. return;
  489. if(Check_Timer_Ready(&send_msgtime_5HZ,_20_HZ_) != true)
  490. return;
  491. uint8_t ez_can[8] = {0};
  492. static uint8_t frame_i = 1;
  493. static uint16_t data_count = 0,ez_crc = 0;
  494. if(UPDATE_END == update_info.buf[UPDATE_STEP])
  495. {
  496. EZup_par.step = STEP_ENDING;
  497. update_info.step_202_flag = true;
  498. }
  499. switch (EZup_par.step)
  500. {
  501. case STEP_FIND_NODE:
  502. for(uint8_t i = 0;i < 126;i++)
  503. {
  504. put_date_to_can(ez_can,i,0x06,0xB2,0X80,0XFF,0XFF,0XFF,0XFF);
  505. Can_Send_Msg_Func(CANID1, ez_can, 8, 0x3c, CAN_ID_STD);
  506. }
  507. break;
  508. case STEP_JUMP_BOOT:
  509. put_date_to_can(ez_can,EZup_par.node_id,0x06,0xB3,0XC1,0X42,0X4F,0X4F,0X54);
  510. Can_Send_Msg_Func(CANID1, ez_can, 8, 0x3c, CAN_ID_STD);
  511. put_date_to_can(ez_can,EZup_par.node_id,0x06,0xB2,0X80,0XFF,0XFF,0XFF,0XFF); //确定雷达所在区域
  512. Can_Send_Msg_Func(CANID1, ez_can, 8, 0x3c, CAN_ID_STD);
  513. break;
  514. case STEP_EASER_FLASH:
  515. HAL_Delay(500);
  516. put_date_to_can(ez_can,EZup_par.node_id,0x06,0xB4,0X42,0X00,0X00,0X00,0X00);
  517. ez_can[4] = (update_info.bin_size >> 24) & 0xff;
  518. ez_can[5] = (update_info.bin_size >> 16) & 0xff;
  519. ez_can[6] = (update_info.bin_size >> 8) & 0xff;
  520. ez_can[7] = update_info.bin_size & 0xff;
  521. Can_Send_Msg_Func(CANID1, ez_can, 8, 0x3c, CAN_ID_STD);
  522. break;
  523. case STEP_SET_OFFSET_ADR:
  524. put_date_to_can(ez_can,EZup_par.node_id,0x06,0xB4,0X03,0X00,0X01,0X17,0X3C);
  525. ez_can[4] = (EZup_par.adr_offset>> 24) & 0xff;
  526. ez_can[5] = (EZup_par.adr_offset >> 16) & 0xff;
  527. ez_can[6] = (EZup_par.adr_offset >> 8) & 0xff;
  528. ez_can[7] = EZup_par.adr_offset & 0xff;
  529. Can_Send_Msg_Func(CANID1, ez_can, 8, 0x3c, CAN_ID_STD);
  530. break;
  531. case STEP_SEND_DATE:
  532. while (update_info.vk_dev_pack_num == (update_info.buf[PACK_NUM] + update_info.buf[PACK_NUM + 1] * 256) &&
  533. EZup_par.pack_content != PACK_WAIT)
  534. {
  535. switch (EZup_par.pack_content)
  536. {
  537. case PACK_HEAD:
  538. EZup_par.frame_pci = 0x10 + (((128 + 2) >> 8) & 0x7);
  539. EZup_par.frame_len = (128+2) & 0xff;
  540. put_date_to_can(ez_can,EZup_par.node_id,EZup_par.frame_pci,EZup_par.frame_len,0XB4,0XC4,0X00,0X00,0X00);
  541. memcpy(&ez_can[5],&update_info.buf[PAYLOAD],3);
  542. EZup_par.pack_content = PACK_CONT;
  543. data_count += 3;
  544. break;
  545. case PACK_CONT:
  546. EZup_par.frame_pci = 0x20 + frame_i;
  547. ez_can[0] = EZup_par.node_id;
  548. ez_can[1] = EZup_par.frame_pci;
  549. frame_i++;
  550. memcpy(&ez_can[2],&update_info.buf[PAYLOAD + data_count],6);
  551. data_count += 6;
  552. if(data_count >= 128)
  553. {
  554. EZup_par.pack_content = PACK_CRC;
  555. ez_can[7] = 0xff;
  556. }
  557. if(frame_i > 15)
  558. frame_i = 0;
  559. break;
  560. case PACK_TAIL:
  561. EZup_par.pack_content = PACK_CRC;
  562. break;
  563. case PACK_CRC:
  564. data_count = 0;
  565. frame_i = 1;
  566. ez_crc = crc16_ccitt(&update_info.buf[PAYLOAD],128);
  567. put_date_to_can(ez_can,EZup_par.node_id,0X06,0xB4,0X85,(ez_crc >> 8) & 0xff,(ez_crc & 0xff),0XFF,0XFF);
  568. EZup_par.pack_content = PACK_WAIT; //只发一次
  569. break;
  570. default:
  571. break;
  572. }
  573. Can_Send_Msg_Func(CANID1, ez_can, 8, 0x3c, CAN_ID_STD);
  574. HAL_Delay(1);
  575. }
  576. break;
  577. case STEP_ENDING:
  578. put_date_to_can(ez_can,EZup_par.node_id,0x06,0xB4,0X06,0X41,0X50,0X50,0XFF);
  579. Can_Send_Msg_Func(CANID1, ez_can, 8, 0x3c, CAN_ID_STD);
  580. EZup_par.step = STEP_DEFAULT;
  581. EZup_par.update_flag = false;
  582. mimo_f_info.get_radar_ver_flag = false;
  583. mimo_b_info.get_radar_ver_flag = false;
  584. mimo_ter_info.get_radar_ver_flag = false;
  585. break;
  586. default:
  587. break;
  588. }
  589. }
  590. void EZ_Radar_UpdateCanRecvHookFunction(uint32_t CanID, uint8_t data[], uint8_t len)
  591. {
  592. if(data[1] == 0x06 && data[2] == 0xF2 && data[3] == 0xAA) //搜索节点
  593. {
  594. EZup_par.node_id = data[0];
  595. EZup_par.step = STEP_JUMP_BOOT;
  596. }
  597. else if(data[1] == 0x06 && data[2] == 0xF2 && data[3] == 0x55) //确定在boot
  598. {
  599. EZup_par.node_id = data[0];
  600. EZup_par.step = STEP_EASER_FLASH;
  601. }
  602. else if(data[0] == EZup_par.node_id && data[1] == 0x06 && data[2] == 0xF4 && //擦FLASH //CRC校验回复一样?
  603. data[3] == 0x00 && data[4] == 0xFF && data[5] == 0xFF && data[6] == 0xFF && data[7] == 0xFF)
  604. {
  605. if(EZup_par.step == STEP_EASER_FLASH )
  606. {
  607. EZup_par.step = STEP_SET_OFFSET_ADR;
  608. update_info.step_200_flag = true;
  609. }
  610. else if(EZup_par.step == STEP_SEND_DATE || EZup_par.step == STEP_WAIT)
  611. {
  612. EZup_par.adr_offset += 128;
  613. update_info.vk_dev_pack_num++;
  614. EZup_par.step = STEP_SET_OFFSET_ADR;
  615. update_info.step_201_flag = true;
  616. }
  617. }
  618. else if(data[0] == EZup_par.node_id && data[1] == 0x06 && data[2] == 0xF4 &&
  619. data[3] == 0x00 && (data[4] == 0x04 || data[4] == 0x08) && data[5] == 0x00 && data[6] == 0xFF && data[7] == 0xFF) //设置地址偏移
  620. {
  621. EZup_par.step = STEP_SEND_DATE;
  622. EZup_par.pack_content = PACK_HEAD;
  623. }
  624. else if(data[0] == EZup_par.node_id && data[1] == 0x06 && data[2] == 0xF4 && //校验错误
  625. data[3] == 0x07 && data[4] == 0xFF && data[5] == 0xFF && data[6] == 0xFF && data[7] == 0xFF)
  626. {
  627. EZup_par.step = STEP_SET_OFFSET_ADR;
  628. }
  629. }
  630. uint8_t WordXorCrc(uint8_t *pData, uint32_t len)
  631. {
  632. uint8_t crc = 0;
  633. for (uint32_t i = 0; i < len; i++)
  634. {
  635. crc ^= pData[i];
  636. }
  637. return crc;
  638. }
  639. /**
  640. * @file eft_dev_update_func
  641. * @brief efg设备升级
  642. * @param
  643. * @details
  644. * @author Zhang Sir
  645. **/
  646. _eft_update eft_update = {.pack_num = 1};
  647. void eft_dev_update_func(void)
  648. {
  649. if(uart_send_is_ok(USART_1) == true)
  650. {
  651. if(eft_update.step_200_flag == true )
  652. {
  653. Update_ack_func(eft_update.buf[DEVICE],200,&eft_update.buf[PACK_NUM]);
  654. eft_update.step_200_flag = false;
  655. }
  656. else if(eft_update.step_201_flag == true)
  657. {
  658. Update_ack_func(eft_update.buf[DEVICE],201,&eft_update.buf[PACK_NUM]);
  659. eft_update.step_201_flag = false;
  660. }
  661. else if(eft_update.step_202_flag == true)
  662. {
  663. Update_ack_func(eft_update.buf[DEVICE],202,&eft_update.buf[PACK_NUM]);
  664. eft_update.step_202_flag = false;
  665. }
  666. }
  667. static uint32_t send_msgtime_5HZ = 0;
  668. if(eft_update.update_flag != true)
  669. return;
  670. if(Check_Timer_Ready(&send_msgtime_5HZ,_20_HZ_) != true)
  671. return;
  672. uint8_t canN = 0;
  673. uint8_t can_buf[8] = {0};
  674. int can_id = 0;
  675. if(eft_update.dev_id == GROUP_ID_EFTFB_UPDATE)
  676. {
  677. canN = CANID1;
  678. }
  679. else if(eft_update.dev_id == GROUP_ID_EFTPUMP1_UPDATE || eft_update.dev_id == GROUP_ID_EFTPUMP2_UPDATE ||
  680. eft_update.dev_id == GROUP_ID_EFTNOZZLE1_UPDATE || eft_update.dev_id == GROUP_ID_EFTNOZZLE2_UPDATE ||
  681. eft_update.dev_id == GROUP_ID_EFTNOZZLE3_UPDATE || eft_update.dev_id == GROUP_ID_EFTNOZZLE4_UPDATE ||
  682. eft_update.dev_id == GROUP_ID_EFTSEED_UPDATE || eft_update.dev_id == GROUP_ID_Z70FB_UPDATE || GROUP_ID_Z70FBLIFTING_UPDATE ||
  683. eft_update.dev_id == GROUP_ID_EFT_TURNMOTOR || eft_update.dev_id == GROUP_ID_EFT_CHURN || eft_update.dev_id == GROUP_ID_EFT_CHURNTURN)
  684. {
  685. canN = CANID2;
  686. }
  687. if(eft_update.dev_id == GROUP_ID_EFTPUMP1_UPDATE)
  688. can_id = 0x8811;
  689. else if(eft_update.dev_id == GROUP_ID_EFTPUMP2_UPDATE)
  690. can_id = 0x8822;
  691. else if(eft_update.dev_id == GROUP_ID_EFTNOZZLE1_UPDATE)
  692. can_id = 0x8833;
  693. else if(eft_update.dev_id == GROUP_ID_EFTNOZZLE2_UPDATE)
  694. can_id = 0x8844;
  695. else if(eft_update.dev_id == GROUP_ID_EFTNOZZLE3_UPDATE)
  696. can_id = 0x8855;
  697. else if(eft_update.dev_id == GROUP_ID_EFTNOZZLE4_UPDATE)
  698. can_id = 0x8866;
  699. else if(eft_update.dev_id == GROUP_ID_EFTFB_UPDATE)
  700. can_id = 0x8877;
  701. else if(eft_update.dev_id == GROUP_ID_EFTSEED_UPDATE)
  702. can_id = 0x8899;
  703. else if(eft_update.dev_id == GROUP_ID_Z70FB_UPDATE)
  704. can_id = 0x7011;
  705. else if(eft_update.dev_id == GROUP_ID_Z70FBLIFTING_UPDATE)
  706. can_id = 0x88BB;
  707. else if(eft_update.dev_id == GROUP_ID_EFT_TURNMOTOR)
  708. can_id = 0x7733;
  709. else if(eft_update.dev_id == GROUP_ID_EFT_TURNMOTOR)
  710. can_id = 0x7711;
  711. else if(eft_update.dev_id == GROUP_ID_EFT_TURNMOTOR)
  712. can_id = 0x7722;
  713. switch (eft_update.step)
  714. {
  715. case STEP_START:
  716. put_date_to_can(can_buf,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF); //停止广播
  717. Can_Send_Msg_Func(canN, can_buf, 8, 0x88FF, CAN_ID_EXT);
  718. put_date_to_can(can_buf,0xEB,0x90,0xEB,0x90,0xEB,0x90,0x10,0x06);
  719. Can_Send_Msg_Func(canN,can_buf, 8, can_id, CAN_ID_EXT);
  720. memcpy(&can_buf,&eft_update.bin_size,4);
  721. memcpy(&can_buf[4],&eft_update.bin_crc,4);
  722. Can_Send_Msg_Func(canN,can_buf, 8, can_id, CAN_ID_EXT);
  723. if(eft_update.bin_size % 128 > 0)
  724. eft_update.totol_packNum = (eft_update.bin_size / 128) + 1;
  725. else if(eft_update.bin_size % 128 == 0)
  726. eft_update.totol_packNum = eft_update.bin_size / 128;
  727. break;
  728. case STEP_UPDATING:
  729. if(eft_update.pack_num == (eft_update.buf[PACK_NUM] + eft_update.buf[PACK_NUM + 1] * 256) &&
  730. eft_update.send_pack_complete == false && eft_update.buf[UPDATE_STEP] == 201)
  731. {
  732. uint8_t i = 0;
  733. //首帧
  734. put_date_to_can(can_buf,0xEB,0x90,0xEB,0x90,0xEB,0x90,128+10,0x2B);
  735. Can_Send_Msg_Func(canN, can_buf, 8, can_id, CAN_ID_EXT);
  736. //第二帧
  737. if(eft_update.pack_num != eft_update.totol_packNum)
  738. can_buf[0] = 1;
  739. else
  740. can_buf[0] = 0;
  741. memcpy(&can_buf[1],&eft_update.buf[PAYLOAD + i],7);
  742. i += 7;
  743. Can_Send_Msg_Func(canN, can_buf, 8, can_id, CAN_ID_EXT);
  744. //中间帧
  745. while( i < 127)
  746. {
  747. memcpy(can_buf,&eft_update.buf[PAYLOAD + i],8);
  748. Can_Send_Msg_Func(canN, can_buf, 8, can_id, CAN_ID_EXT);
  749. i += 8;
  750. }
  751. //结束 帧
  752. eft_update.pack_crc = WordXorCrc(&eft_update.buf[PAYLOAD],128);
  753. can_buf[0] = eft_update.buf[PAYLOAD + i];
  754. can_buf[1] = eft_update.pack_crc;
  755. can_buf[2] = 0xFF;
  756. can_buf[3] = 0xFF;
  757. can_buf[4] = 0xFF;
  758. can_buf[5] = 0xFF;
  759. can_buf[6] = 0xFF;
  760. can_buf[7] = 0xFF;
  761. Can_Send_Msg_Func(canN, can_buf, 8, can_id, CAN_ID_EXT);
  762. eft_update.send_pack_complete = true;
  763. }
  764. break;
  765. case STEP_END:
  766. put_date_to_can(can_buf,0xEE,0xEE,0xEE,0xEE,0xEE,0xEE,0xEE,0xEE); //开始广播
  767. Can_Send_Msg_Func(canN, can_buf, 8, 0x88FF, CAN_ID_EXT);
  768. eft_update.update_flag = false;
  769. eft_update.step_202_flag = true;
  770. break;
  771. case STEP_WAIT_ACK:
  772. break;
  773. default:
  774. break;
  775. }
  776. }
  777. void eft_dev_update_wait_ereseflash(uint8_t data[])
  778. {
  779. if(data[0] == 0xEB && data[1] == 0x90 && data[2] == 0xEB && data[3] == 0x90 &&
  780. data[4] == 0xEB && data[5] == 0x90 && data[6] == 0x08 && data[7] == 0x07)
  781. {
  782. eft_update.step = STEP_WAIT_ACK;
  783. }
  784. else if(data[0] == 0xEB && data[1] == 0x90 && data[2] == 0xEB && data[3] == 0x90 &&
  785. data[4] == 0xEB && data[5] == 0x90 && data[6] == 0x08 && data[7] == 0x17)
  786. {
  787. eft_update.step_200_flag = true;
  788. if(eft_update.step != STEP_UPDATING)
  789. {
  790. eft_update.step = STEP_UPDATING;
  791. eft_update.pack_num++;
  792. }
  793. }
  794. //下一包数据
  795. else if(data[0] == 0xEB && data[1] == 0x90 && data[2] == 0xEB && data[3] == 0x90 &&
  796. data[4] == 0xEB && data[5] == 0x90 && data[6] == 0x08 && data[7] == 0x0B)
  797. {
  798. eft_update.pack_num++;
  799. eft_update.send_pack_complete = false;
  800. eft_update.step_201_flag = true;
  801. }
  802. //重新发送此包
  803. else if(data[0] == 0xEB && data[1] == 0x90 && data[2] == 0xEB && data[3] == 0x90 &&
  804. data[4] == 0xEB && data[5] == 0x90 && data[6] == 0x08 && data[7] == 0x09)
  805. {
  806. eft_update.send_pack_complete = false;
  807. }
  808. //升级成功
  809. else if(data[0] == 0xEB && data[1] == 0x90 && data[2] == 0xEB && data[3] == 0x90 &&
  810. data[4] == 0xEB && data[5] == 0x90 && data[6] == 0x08 && data[7] == 0x0C)
  811. {
  812. eft_update.step = STEP_END;
  813. }
  814. //重新升级
  815. else if(data[0] == 0xEB && data[1] == 0x90 && data[2] == 0xEB && data[3] == 0x90 &&
  816. data[4] == 0xEB && data[5] == 0x90 && data[6] == 0x08 && data[7] == 0x0D)
  817. {
  818. }
  819. }