soft_uart.c 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510
  1. #include "soft_uart.h"
  2. #include "usart.h"
  3. #include "stdbool.h"
  4. #include "soft_timer.h"
  5. #include "soft_adc.h"
  6. #include "soft_flow.h"
  7. #include "soft_crc.h"
  8. #include <string.h>
  9. #include "stdbool.h"
  10. #include "tim.h"
  11. #include "hard_led.h"
  12. #include "soft_can.h"
  13. #include "stdio.h"
  14. #include "soft_bms.h"
  15. #include "soft_terrain.h"
  16. #include "soft_obstacle.h"
  17. #include "soft_okcell.h"
  18. #include "soft_adc.h"
  19. #include "soft_p_2_c.h"
  20. #include "soft_engine.h"
  21. #include "stm32f1xx_it.h"
  22. #include "bsp_serial.h"
  23. #include "rkfifo.h"
  24. #include "stm32f1xx_hal_def.h"
  25. #include "soft_update.h"
  26. #include "common.h"
  27. #include "soft_water_device.h"
  28. #include "config.h"
  29. uint8_t Update_buf[150] = {0};
  30. Vk_protocol vk_protocol;
  31. rkfifo_t send_uart_rkfifo;
  32. bool radar_update_flag = false; //雷达升级标志
  33. Uart uart_info = {.vk_dev_pack_num = 1};
  34. /**
  35. * @file printf
  36. * @brief 串口发送重定向
  37. * @param
  38. * @details
  39. * @author Zhang Sir
  40. **/
  41. int _write(int fd, char *pBuffer, int size)
  42. {
  43. uint32_t uart3_send_count_time = HAL_GetTick();
  44. while (__HAL_UART_GET_FLAG(&huart3, UART_FLAG_TC) == 0 &&
  45. HAL_GetTick() - uart3_send_count_time < 5)
  46. ;
  47. HAL_UART_Transmit(&huart3, (uint8_t *)pBuffer, size, 0xff);
  48. return size;
  49. }
  50. /**
  51. * @file uart_send_is_ok
  52. * @brief 检测串口是否可用
  53. * @param uart_num 串口号
  54. * @details
  55. * @author Zhang Sir
  56. **/
  57. bool uart_send_is_ok(uint8_t uart_num)
  58. {
  59. //设备升级不发送
  60. //if(radar_update_flag == true)
  61. // return false;
  62. // if(uart_info.vk_dev_update_flag == true)
  63. // return false;
  64. if (uart_num == USART_2)
  65. {
  66. if (huart2.gState == HAL_UART_STATE_READY && (__HAL_UART_GET_FLAG(&huart2, UART_FLAG_TC) != RESET && __HAL_UART_GET_FLAG(&huart2, UART_FLAG_TXE) != RESET))
  67. {
  68. }
  69. else
  70. {
  71. return false;
  72. }
  73. //延迟1ms发送,防止如果是空闲中断接收,连续发送变成一包
  74. if(HAL_GetTick() - uart2_send_delay_time <= 1)
  75. {
  76. return false;
  77. }
  78. }
  79. else if (uart_num == USART_3)
  80. {
  81. if (huart3.gState == HAL_UART_STATE_READY && (__HAL_UART_GET_FLAG(&huart3, UART_FLAG_TC) != RESET && __HAL_UART_GET_FLAG(&huart3, UART_FLAG_TXE) != RESET))
  82. {
  83. }
  84. else
  85. {
  86. return false;
  87. }
  88. if(HAL_GetTick() - uart3_send_delay_time <= 1)
  89. {
  90. return false;
  91. }
  92. }
  93. return true;
  94. }
  95. /**
  96. * @file uart2_send_msg
  97. * @brief 串口2发送
  98. * @param
  99. * @details
  100. * @author Zhang Sir
  101. **/
  102. uint32_t uart2_send_delay_time = 0;
  103. uint32_t uart3_send_delay_time = 0;
  104. void uart2_send_msg(uint8_t *data, uint8_t size)
  105. {
  106. // static uint32_t send_time = 0;
  107. // send_time = HAL_GetTick();
  108. // //防止连续发送使多个数据变成一个
  109. // while (HAL_GetTick() - send_time <= 1)
  110. // ;
  111. rkfifo_in(&send_uart_rkfifo,data,size);
  112. // HAL_UART_Transmit_DMA(&huart2, data, size);
  113. // uart2_send_delay_time = HAL_GetTick();
  114. //bspSerialWrite(&serial2,data,size);
  115. }
  116. uint8_t send_uart_buf[256] = {0};
  117. void send_uartfifo_msg(void)
  118. {
  119. uint16_t len = 0;
  120. if(uart_send_is_ok(USART_2) == true)
  121. {
  122. len = rkfifo_out(&send_uart_rkfifo, &send_uart_buf, 256);
  123. if(len > 0)
  124. {
  125. HAL_UART_Transmit_DMA(&huart2, send_uart_buf, len);
  126. uart2_send_delay_time = HAL_GetTick();
  127. }
  128. }
  129. }
  130. //uart3 发送调用函数
  131. void uart3_send_msg(uint8_t *data, uint8_t size)
  132. {
  133. static uint32_t send_time3 = 0;
  134. send_time3 = HAL_GetTick();
  135. while (HAL_GetTick() - send_time3 <= 1)
  136. ;
  137. HAL_UART_Transmit_DMA(&huart3, data, size);
  138. uart3_send_delay_time = HAL_GetTick();
  139. }
  140. /**
  141. * @file UART_Init
  142. * @brief UART23初始化接收空闲中断 开起DMA
  143. * @param
  144. * @details
  145. * @author Zhang Sir
  146. **/
  147. void UART_Init(void)
  148. {
  149. //uart2
  150. //__HAL_UART_ENABLE_IT(&huart2, UART_IT_RXNE); //接收到一个字节产生一次中断
  151. //HAL_UART_Receive_IT(&huart2, &test_buf, 1);
  152. __HAL_UART_ENABLE_IT(&huart2, UART_IT_IDLE); //uart2 空闲中断
  153. HAL_UART_Receive_DMA(&huart2, (uint8_t *)uart_info.uart2_recv_buf, MAX_UART_BUF);
  154. //开启错误处理机制
  155. __HAL_UART_ENABLE_IT(&huart2, UART_IT_ERR);
  156. //uart3
  157. //HAL_UART_Receive_IT(&huart3, (uint8_t *)uart_info.uart3_recv_buf, 1);
  158. __HAL_UART_ENABLE_IT(&huart3, UART_IT_IDLE);
  159. HAL_UART_Receive_DMA(&huart3, (uint8_t *)uart_info.uart3_recv_buf, MAX_UART_BUF/2);
  160. //开启错误处理机制
  161. __HAL_UART_ENABLE_IT(&huart3, UART_IT_ERR);
  162. }
  163. /**
  164. * @file USER_UART_IRQHandler
  165. * @brief user用户中断函数
  166. * @param
  167. * @details
  168. * @author Zhang Sir
  169. **/
  170. uint32_t read_DR;
  171. rkfifo_t recv_rkfifo;
  172. void USER_UART_IRQHandler(UART_HandleTypeDef *huart)
  173. {
  174. if (huart == &huart2)
  175. {
  176. if (RESET != __HAL_UART_GET_FLAG(&huart2, UART_FLAG_IDLE))
  177. {
  178. read_DR = huart2.Instance->DR;
  179. __HAL_UART_CLEAR_IDLEFLAG(&huart2);
  180. HAL_UART_AbortReceive(&huart2);//HAL_UART_DMAStop 有问题
  181. uart_info.uart_dma_recv_counts = MAX_UART_BUF - __HAL_DMA_GET_COUNTER(huart->hdmarx);
  182. for(uint8_t i = 0;i<uart_info.uart_dma_recv_counts;i++)
  183. {
  184. if(uart_info.uart2_recv_buf[i] == 0xfe && uart_info.uart2_recv_buf[i+5] == 27)
  185. {
  186. time_heart[0] = HAL_GetTick();
  187. time_count[0]++;
  188. }
  189. }
  190. rkfifo_in(&recv_rkfifo,uart_info.uart2_recv_buf,uart_info.uart_dma_recv_counts);
  191. memset(uart_info.uart2_recv_buf,0,MAX_UART_BUF);
  192. HAL_UART_Receive_DMA(&huart2, uart_info.uart2_recv_buf, MAX_UART_BUF);
  193. }
  194. }
  195. if(huart == &huart3)
  196. {
  197. if (RESET != __HAL_UART_GET_FLAG(&huart3, UART_FLAG_IDLE))
  198. {
  199. read_DR = huart3.Instance->DR;
  200. __HAL_UART_CLEAR_IDLEFLAG(&huart3); //清除中断标志位,不清除一直在中断里
  201. HAL_UART_AbortReceive(&huart3);
  202. uart_info.uart_dma_recv_counts = MAX_UART_BUF - __HAL_DMA_GET_COUNTER(huart->hdmarx);
  203. //串口三接奥安,上飞发动机
  204. if (aoan_engine_Link.connect_status != COMP_NOEXIST)
  205. {
  206. decode_aoan_engine(uart_info.uart3_recv_buf, uart_info.uart_dma_recv_counts);
  207. }
  208. else if (vkv3_engine_link.connect_status != COMP_NOEXIST)
  209. {
  210. decode_vkv3_engine(uart_info.uart3_recv_buf, uart_info.uart_dma_recv_counts);
  211. }
  212. else
  213. {
  214. //根据协议选择设备
  215. decode_vkv3_engine(uart_info.uart3_recv_buf, uart_info.uart_dma_recv_counts);
  216. decode_aoan_engine(uart_info.uart3_recv_buf, uart_info.uart_dma_recv_counts);
  217. }
  218. HAL_UART_Receive_DMA(&huart3, (uint8_t *)uart_info.uart3_recv_buf, MAX_UART_BUF/2);
  219. }
  220. }
  221. }
  222. /**
  223. * @file HAL_UART_ErrorCallback
  224. * @brief uart错误中断回调函数
  225. * @param
  226. * @details
  227. * @author Zhang Sir
  228. **/
  229. void HAL_UART_ErrorCallback(UART_HandleTypeDef *huart)
  230. {
  231. if (__HAL_UART_GET_FLAG(huart, UART_FLAG_ORE) != RESET) //接收溢出检测
  232. {
  233. __HAL_UART_CLEAR_OREFLAG(huart);
  234. }
  235. if (__HAL_UART_GET_FLAG (huart, UART_FLAG_RXNE) != RESET)//接收数据
  236. {
  237. __HAL_UART_CLEAR_FLAG (huart, UART_FLAG_RXNE);
  238. }
  239. __HAL_UART_CLEAR_PEFLAG (huart);
  240. if (huart == &huart2)
  241. {
  242. HAL_UART_Receive_DMA(&huart2, (uint8_t *)uart_info.uart2_recv_buf, MAX_UART_BUF);
  243. }
  244. else if (huart == &huart3)
  245. {
  246. HAL_UART_Receive_DMA(&huart3, (uint8_t *)uart_info.uart3_recv_buf, MAX_UART_BUF/2);
  247. }
  248. }
  249. /**
  250. * @file HAL_UART_TxCpltCallback
  251. * @brief uart发送回调
  252. * @param
  253. * @details
  254. * @author Zhang Sir
  255. **/
  256. void HAL_UART_TxCpltCallback(UART_HandleTypeDef *huart)
  257. {
  258. if (huart == &huart2)
  259. {
  260. }
  261. }
  262. /**
  263. * @file check_uart_data
  264. * @brief 接收数据组包解析
  265. * @param
  266. * @details
  267. * @author Zhang Sir
  268. **/
  269. Msg_Rx_Stage recv_step;
  270. Vk_protocol fcu_protocol;
  271. Vk_protocol vk_data = {.head = 0XFE,
  272. .system_id = 0,
  273. .head_bytes = 6,
  274. .check_bytes = 2};
  275. void check_uart_data(rkfifo_t *fifo)
  276. {
  277. uint8_t c = 0;
  278. static uint32_t vk_recv_time = 0;
  279. static uint8_t i = 0;
  280. while (rkfifo_out(fifo, &c, 1) != 0)
  281. {
  282. if(recv_step != RX_HEAD && HAL_GetTick() - vk_recv_time > 200)
  283. {
  284. recv_step = RX_HEAD;
  285. }
  286. //解析出一包完整的数据
  287. switch (recv_step)
  288. {
  289. case RX_HEAD:
  290. if(c == vk_data.head)
  291. {
  292. vk_recv_time = HAL_GetTick();
  293. recv_step = RX_PAYLOAD_LEN;
  294. }
  295. break;
  296. case RX_PAYLOAD_LEN:
  297. vk_data.len = c;
  298. recv_step = RX_SEQ;
  299. break;
  300. case RX_SEQ:
  301. vk_data.seq = c;
  302. recv_step = RX_SYSID;
  303. break;
  304. case RX_SYSID:
  305. if(c == vk_data.system_id)
  306. {
  307. recv_step = RX_GROUPID;
  308. }
  309. else
  310. {
  311. recv_step = RX_HEAD;
  312. }
  313. break;
  314. case RX_GROUPID:
  315. if(c == GROUP_ID_FCU || c == GROUP_ID_PMU_UPDATE || c == GROUP_ID_F_UPDATE ||
  316. c == GROUP_ID_B_UPDATE || c == GROUP_ID_T_UPDATE|| c == GROUP_ID_WEIGHT_UPDATE)
  317. {
  318. vk_data.group_id = c;
  319. recv_step = RX_MSGID;
  320. }
  321. else
  322. {
  323. recv_step = RX_HEAD;
  324. }
  325. break;
  326. case RX_MSGID:
  327. vk_data.msg_id = c;
  328. if(c == 27)
  329. {
  330. time_heart[2] = HAL_GetTick();
  331. time_count[2]++;
  332. }
  333. recv_step = RX_PAYLOAD;
  334. i = 0;
  335. break;
  336. case RX_PAYLOAD:
  337. vk_data.payload[vk_data.head_bytes + i] = c;
  338. i++;
  339. if(i == vk_data.len)
  340. {
  341. recv_step = RX_CHECK_LOW;
  342. }
  343. else if(vk_data.len == 0) //没有payload
  344. {
  345. recv_step = RX_CHECK_HIGH;
  346. }
  347. break;
  348. case RX_CHECK_LOW:
  349. vk_data.payload[vk_data.head_bytes + i] = c;
  350. i++;
  351. recv_step = RX_CHECK_HIGH;
  352. break;
  353. case RX_CHECK_HIGH:
  354. vk_data.payload[vk_data.head_bytes + i] = c;
  355. vk_data.payload[0] = vk_data.head;
  356. vk_data.payload[1] = vk_data.len;
  357. vk_data.payload[2] = vk_data.seq;
  358. vk_data.payload[3] = vk_data.system_id;
  359. vk_data.payload[4] = vk_data.group_id;
  360. vk_data.payload[5] = vk_data.msg_id;
  361. if(0 == Get_Crc16(&vk_data.payload[0],vk_data.len + vk_data.head_bytes + vk_data.check_bytes))
  362. {
  363. if(vk_data.group_id == GROUP_ID_FCU || vk_data.group_id == GROUP_ID_PMU_UPDATE)
  364. {
  365. fcu_protocol.msg_id = vk_data.msg_id;
  366. memcpy(&fcu_protocol.payload[0],&vk_data.payload[0],vk_data.len + vk_data.head_bytes + vk_data.check_bytes);
  367. uart_info.fcu_buf_flag = true;
  368. }
  369. //莫之比雷达升级
  370. else if((vk_data.group_id == GROUP_ID_F_UPDATE && uavr11_info.Link.connect_status != COMP_NOEXIST) ||
  371. (vk_data.group_id == GROUP_ID_B_UPDATE && uavr12_info.Link.connect_status != COMP_NOEXIST) ||
  372. (vk_data.group_id == GROUP_ID_T_UPDATE && uavr56_info.Link.connect_status != COMP_NOEXIST))
  373. {
  374. if(uart_info.use_update_buf_flag == false)
  375. {
  376. uart_info.update_time = HAL_GetTick();
  377. memcpy(&Update_buf[0],&vk_data.payload[0],vk_data.len + vk_data.head_bytes + vk_data.check_bytes);
  378. uart_info.use_update_buf_flag = true;
  379. if (vk_data.msg_id == 200)
  380. {
  381. {
  382. radar_update_flag = true;
  383. update_count = 0;
  384. }
  385. }
  386. }
  387. else
  388. {
  389. if(HAL_GetTick() - uart_info.update_time > 3000)
  390. {
  391. uart_info.use_update_buf_flag = false;
  392. }
  393. }
  394. }
  395. //VK协议设备升级
  396. else if (vk_data.group_id == GROUP_ID_WEIGHT_UPDATE ||
  397. (vk_data.group_id == GROUP_ID_F_UPDATE /*&& mimo_f_info.Link.connect_status != COMP_NOEXIST*/) || //mimo
  398. (vk_data.group_id == GROUP_ID_B_UPDATE /*&& mimo_b_info.Link.connect_status != COMP_NOEXIST*/) || //mimo
  399. (vk_data.group_id == GROUP_ID_T_UPDATE /*&& mimo_ter_info.Link.connect_status != COMP_NOEXIST*/)) //mimo
  400. {
  401. #ifdef mimo_update
  402. if(vk_data.msg_id == 200)
  403. {
  404. if(EZup_par.step == STEP_DEFAULT)//mimo
  405. {//mimo
  406. memset(&EZup_par,0,sizeof(ez_update));//mimo
  407. memset(&uart_info.fcu_buf_flag,0,sizeof(Uart));
  408. memcpy(&uart_info.bin_size,&vk_data.payload[6],4);
  409. uart_info.vk_dev_pack_num = 1;
  410. uart_info.vk_dev_update_flag = true;
  411. EZup_par.update_flag = true;//mimo
  412. EZup_par.step = STEP_FIND_NODE;//mimo
  413. }
  414. }
  415. #else
  416. if(vk_data.msg_id == 200)
  417. {
  418. memset(&uart_info.fcu_buf_flag,0,sizeof(Uart));
  419. memcpy(&uart_info.bin_size,&vk_data.payload[6],4);
  420. uart_info.vk_dev_pack_num = 1;
  421. uart_info.vk_dev_update_flag = true;
  422. }
  423. #endif
  424. //if(uart_info.use_update_buf_flag == false)
  425. //{
  426. memcpy(&Update_buf[0],&vk_data.payload[0],vk_data.len + vk_data.head_bytes + vk_data.check_bytes);
  427. //判断是否是需要的包序号
  428. if(uart_info.vk_dev_pack_num > (Update_buf[PACK_NUM] + Update_buf[PACK_NUM + 1] * 256) &&
  429. vk_data.msg_id == 201)
  430. {
  431. Update_ack_func(Update_buf[DEVICE],201,&Update_buf[PACK_NUM]);
  432. }
  433. uart_info.use_update_buf_flag = true;
  434. //}
  435. }
  436. }
  437. else
  438. {
  439. //vk_protocol_test[4]++;
  440. }
  441. recv_step = RX_HEAD;
  442. break;
  443. default:
  444. recv_step = RX_HEAD;
  445. //vk_protocol_test[5]++;
  446. break;
  447. }
  448. if( uart_info.fcu_buf_flag == true)
  449. break;
  450. }
  451. }