soft_update.c 29 KB

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