硬汉嵌入式论坛

 找回密码
 立即注册
查看: 740|回复: 3
收起左侧

[FreeRTOS] RTOS多线程任务卡死

[复制链接]

4

主题

5

回帖

17

积分

新手上路

积分
17
发表于 2023-10-18 09:33:55 | 显示全部楼层 |阅读模式
最近在使用stm32F7系列产品在做一个数据中转,使用的串口有点多,然后使用了FreeRTOS进行多任务管理,现在RTOS中有一个UDP数据交互,两个串口数据交互,遇到的问题为一个串口进行IMU数据的接收,在裸机中可以不停的接收,但是在RTOS中接收几十次就会停止接收或者同时使用UDP数据交互时,串口接收会立马停止,然后UDP接收数据会明显滞后,发送过后0.5-1s后才会有反馈。

首先怀疑的是堆栈问题,将堆栈设置到8k仍然会出现这种问题,经过测试,当串口接收数据停止后,接收函数进入timeout状态,之后在RTOS中只留下一个线程,这样子每一个线程都没有问题。求大佬解答
回复

使用道具 举报

1万

主题

6万

回帖

10万

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
106660
QQ
发表于 2023-10-18 09:53:17 | 显示全部楼层
是串口中断方式吗,每次通过消息队列发送给任务?串口里面的代码量是否比较大。

另外每次消息队列传递多少字节数据。

方便的话,贴下中断代码和任务处理代码。
回复

使用道具 举报

4

主题

5

回帖

17

积分

新手上路

积分
17
 楼主| 发表于 2023-10-18 10:13:48 | 显示全部楼层
您好,串口接收是使用的hal_uart_receive函数,因为imu可以不停的发送数据,然后每次接收的数据为67字节,在任务中只使用了串口的接收和发送。下边是线程的代码
void IMU_TASK(void const * argument)
{
  for(;;)
  {
           IMUData imu_data;
                HAL_UART_Receive(&huart5,IMU_Rx,sizeof(IMU_Rx),1000);
//                if(HAL_UART_Receive(&huart5,IMU_Rx,sizeof(IMU_Rx),1000) == HAL_OK){
//                ttt = 3;
//                }else if (HAL_UART_Receive(&huart5,IMU_Rx,sizeof(IMU_Rx),1000) == HAL_BUSY){
//                ttt = 5 ;
//                }else if (HAL_UART_Receive(&huart5,IMU_Rx,sizeof(IMU_Rx),1000) == HAL_ERROR){
//                ttt = 7 ;
//                }else if (HAL_UART_Receive(&huart5,IMU_Rx,sizeof(IMU_Rx),1000) == HAL_TIMEOUT){
//                ttt = 9 ;
//                }else{
//                ttt = -1 ;
//                }
                parseAndStoreIMUData(IMU_Rx, &imu_data);
                if((IMU_Rx[0] == 0x59) && (IMU_Rx[1] == 0x53)) {
                HAL_UART_Transmit(&huart2, (uint8_t *)&imu_data, sizeof(IMUData), HAL_MAX_DELAY);
                }
    osDelay(1);
  }
  /* USER CODE END IMU_TASK */
}
回复

使用道具 举报

4

主题

5

回帖

17

积分

新手上路

积分
17
 楼主| 发表于 2023-10-18 10:21:55 | 显示全部楼层
根据您的提示,我将普通接收修改为中断接收解决了这个问题,虽然不知道原理是什么,但是最终还是解决了,感谢您的回复,如果您乐意指点一下,感激不尽。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|小黑屋|Archiver|手机版|硬汉嵌入式论坛

GMT+8, 2024-4-29 03:31 , Processed in 0.163444 second(s), 26 queries .

Powered by Discuz! X3.4 Licensed

Copyright © 2001-2023, Tencent Cloud.

快速回复 返回顶部 返回列表