Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
问题求助
线程无法接受队列消息,如何排查问题
发布于 2024-12-08 15:39:10 浏览:135
订阅该版
- 必现情况;但需要挂测一周才可复现; - 出现时异常情况表现为某一线程不在运行;不固定是哪个线程,但该线程都是使用队列一直接收阻塞的队列. - 使用RTTV5.1.0的代码,芯片为STM32F407;队列都创建为最大消息数为48 - 由于需要持续挂测才可复现,没办法使用debug方式进行排查; - 所以只有在异常时,打印日志观察当前状态;目前看出来的问题点是异常的线程的状态会变成running,且error变为ok;其他正常的线程在打印时,是挂起状态,且error是EINTRPT. - 目前仅能分析到队列有发送出去,且已经将队列接收的线程塞入系统的准备运行队列中;但不知道是否接收线程真的唤醒执行了;然后接收的线程还是说是一直没被唤醒,导致队列一直发送,直到最大消息数不在发送 - 出现问题时的状态如下,查看过内存情况,并未出现内存异常 ```log msh >ps thread pri status sp stack size max used left tick error tcb addr ------------------ --- ------- ---------- ---------- ------ ---------- ------- ---------- lTask3 4 suspend 0x0000019c 0x00000800 37% 0x00000005 EINTRPT 0x2000f224 lTask2 4 suspend 0x0000019c 0x00000800 38% 0x00000005 EINTRPT 0x2000e94c lTask1 4 suspend 0x0000019c 0x00000800 38% 0x00000002 EINTRPT 0x2000e074 TxTask 3 running 0x0000010c 0x00000400 69% 0x00000004 OK 0x2000da7c olTask 4 suspend 0x000000d4 0x00000400 33% 0x00000005 EINTRPT 0x2000d22c uTask 4 suspend 0x000000d4 0x00000400 22% 0x00000002 EINTRPT 0x2000cd54 RxTask 2 suspend 0x0000015c 0x00002000 04% 0x00000005 EINTRPT 0x200097ac tshell 20 running 0x000002ec 0x00001000 24% 0x00000001 OK 0x20007f38 tidle0 31 ready 0x0000005c 0x00000100 82% 0x0000001b OK 0x200037d4 timer 4 suspend 0x000000a4 0x00000200 42% 0x00000009 EINTRPT 0x20003b18 msh >list msgqueue msgqueue entry suspend thread ------------------ ---- -------------- canTxQueue 0048 0 Queue06 0000 0 Queue05 0000 0 Queue04 0000 0 Queue03 0000 1:lTask3 Queue02 0000 1:lTask2 Queue01 0000 1:lTask1 ```
查看更多
1
个回答
默认排序
按发布时间排序
张世争
2024-12-09
学以致用
tshell 线程优先级太低了,打印的线程信息不一定是准确的 idle 线程栈可以加大,确保资源的释放操作能顺利进行 task1 task2 task3 优先级可以改下,比如不一样,否则可能会造成两个线程切来切去,另一个无法工作的现象(FIFO->LIFO(小范围))
撰写答案
登录
注册新账号
关注者
0
被浏览
135
关于作者
用户名由3_15位
这家伙很懒,什么也没写!
提问
63
回答
245
被采纳
34
关注TA
发私信
相关问题
1
关于RT-Thread Studio切换芯片的问题
2
ESP8266-01S不支持AT+CIPDNS_CUR?
3
persimmon UI中如何将Button上的文字传递到Label上
4
让page2上的label控件的内容在page1中的的label上也显示出来
5
续数据回传至page1的问题
6
assert_param()的编译问题?
7
如何在柿饼派UI中实现通过不同按键左右选择不同label和改变label内的值?
8
第一次在新电脑上安装系统,但不能创建工程
9
关于mdk下软、硬仿真的问题?
10
在Rt-thread中安装PICO的SDK资源报错
推荐文章
1
RT-Thread应用项目汇总
2
玩转RT-Thread系列教程
3
国产MCU移植系列教程汇总,欢迎查看!
4
机器人操作系统 (ROS2) 和 RT-Thread 通信
5
五分钟玩转RT-Thread新社区
6
【技术三千问】之《玩转ART-Pi》,看这篇就够了!干货汇总
7
关于STM32H7开发板上使用SDIO接口驱动SD卡挂载文件系统的问题总结
8
STM32的“GPU”——DMA2D实例详解
9
RT-Thread隐藏的宝藏之completion
10
【ART-PI】RT-Thread 开启RTC 与 Alarm组件
最新文章
1
RT-thred的stm32h723对应bsp包CubeMX添加其他外设报错
2
RT-Thread中的time溢出问题,时间戳溢出,解决方法
3
ART-PI使用env驱动ETH网卡,pc和板子可以ping通
4
SystemView线程名字不显示
5
只用网页也能跑RT-Smart 无门槛腾讯Cloud studio + smart-build快速构建
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
DMA
USB
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
rt-smart
FAL
I2C_IIC
UART
ESP8266
cubemx
WIZnet_W5500
ota在线升级
PWM
BSP
flash
freemodbus
packages_软件包
潘多拉开发板_Pandora
定时器
ADC
GD32
flashDB
socket
编译报错
中断
Debug
rt_mq_消息队列_msg_queue
keil_MDK
ulog
SFUD
msh
C++_cpp
MicroPython
本月问答贡献
RTT_逍遥
9
个答案
2
次被采纳
三世执戟
8
个答案
1
次被采纳
KunYi
8
个答案
1
次被采纳
winfeng
2
个答案
1
次被采纳
YZRD
2
个答案
1
次被采纳
本月文章贡献
catcatbing
2
篇文章
5
次点赞
swet123
1
篇文章
4
次点赞
Days
1
篇文章
4
次点赞
YZRD
1
篇文章
2
次点赞
阳光的掌控者
1
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部