STM32 overrun 问题

2650阅读 0评论2020-08-17 iibull
分类:其他平台

几天凑巧调试了个 485的设备. 使用了 stm32F405 的 异步接收方式. 

点击(此处)折叠或打开

  1. /* UARTx 接收管理 */
  2. static void JC_start_Receive_IT(void) //启用中断管理.
  3. {
  4.     uint8_t idx = 0;
  5.     HAL_StatusTypeDef result;
  6.   
  7.     do {
  8.         result = HAL_UART_Receive_IT(JCHander, rx_buffer, rx_len);  //这里总是返回 Busy状态.
  9.         if ((HAL_OK != result)) {
  10.           HAL_Delay(1);
  11.           idx++;
  12.         }
  13.     } while ((HAL_OK != result) && (idx < 5));
  14. }

  15. void init_JC_env(void)
  16. {
  17.   //启用异步接收模式.
  18.   enable_rx_tx_JC(true); // RX mode;
  19.   JC_start_Receive_IT();
  20. }

  21. void HAL_UART_ErrorCallback(UART_HandleTypeDef *huart)
  22. {
  23.   __HAL_UART_CLEAR_OREFLAG(huart); //这里经常被调用到, 实际查找调用时, 出现的错误码为
  24.             //HAL_UART_ERROR_ORE               0x00000008U   /*!< Overrun error       */
  25. }

  26. void HAL_UART_RxCpltCallback(UART_HandleTypeDef *huart)
  27. {
  28.   if (huart == JCHander)
  29.   {
  30.     bRxOK = true;
  31.   }
  32. }

  33. void HAL_UART_TxCpltCallback(UART_HandleTypeDef *huart)
  34. {
  35.   if (huart == JCHander)
  36.   {
  37.     enable_rx_tx_JC(true); // RX mode;
  38.     JC_start_Receive_IT();
  39.   }
  40. }

  41. bool load_JC_data(uint32_t timeout)
  42. {
  43.     HAL_StatusTypeDef result;
  44.   
  45.     enable_rx_tx_JC(false); // TX mode;
  46.     bRxOK = false;
  47.     rx_len = sizeof(JC_DATA_T);
  48.   
  49.     result = HAL_UART_Transmit_IT(JCHander, (uint8_t *)frame_qry_data, ARRAYSIZE(frame_qry_data));
  50.     if (HAL_OK != result ) {
  51.       enable_rx_tx_JC(true); // RX mode;
  52.       return false;
  53.     }
  54.        
  55.     uint32_t tick_now = HAL_GetTick();
  56.     while ((HAL_GetTick() - tick_now) < timeout) {
  57.         if (bRxOK) {
  58.             if (proc_JC_data()) {
  59.               
  60.               return true;
  61.             }
  62.         }
  63.         HAL_Delay(100);
  64.     }
  65.     return false;
  66. }

从 行 8 / 25 最终确定的原因是: rx_len的字节数应该是设小了, 最终没有收完. 后面看一下, 果然是结构体设置错误, 低级错误啊, 白白浪费半小时


上一篇:ROS2 编程注意事项
下一篇:ROS2 摄像头校准