Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
RT-Thread一般讨论
线程堆栈使用异常,程序死机,不知如何排查问题
发布于 2021-10-25 10:33:49 浏览:2669
订阅该版
问题描述: - 最近程序容易死机,调试的时候么有发信啊明显的程序问题,但是有个异常现象,发现有个线程的堆栈使用很高 ``` 00> thread pri status sp stack size max used left tick error 00> ---------- --- ------- ---------- ---------- ------ ---------- --- 00> thd_usbd_m 5 suspend 0x00000180 0x00000600 36% 0x0000000a 000 00> thd_usbd_r 5 suspend 0x00000088 0x00000600 08% 0x00000001 000 00> thd_usbd_s 4 suspend 0x00000088 0x00000400 13% 0x00000001 000 00> thd_usbh_m 5 suspend 0x00000080 0x00000400 32% 0x0000000a 000 00> thd_voc_s1 8 suspend 0x00000088 0x00000400 28% 0x0000000a 000 00> thd_voc_m1 8 suspend 0x00000188 0x00000400 63% 0x00000009 000 00> thd_voc_s0 8 suspend 0x00000088 0x00000400 28% 0x0000000a 000 00> thd_voc_m0 8 suspend 0x00000188 0x00000400 63% 0x00000009 000 00> thd_dtq_s 3 suspend 0x000000a4 0x00000200 32% 0x00000001 000 00> thd_dtq_r 2 suspend 0x000000ac 0x00001000 35% 0x00000001 000 00> thd_dtq_m3 5 suspend 0x00000194 0x00000800 39% 0x0000000a 000 00> thd_dtq_m2 5 suspend 0x00000194 0x00000800 44% 0x0000000a 000 00> thd_dtq_m1 5 suspend 0x00000194 0x00000800 45% 0x00000008 000 00> thd_dtq_m0 5 suspend 0x00000194 0x00000800 47% 0x0000000a 000 00> thd_card 6 suspend 0x000000ac 0x00000800 16% 0x00000006 000 00> thd_spi_s 5 suspend 0x0000007c 0x00000400 12% 0x00000001 000 00> thd_lcd_m 19 suspend 0x000000a4 0x00000a00 97% 0x00000032 000 [栈使用高到98%] 00> thd_bee_d 4 suspend 0x000000a4 0x00000400 16% 0x0000000a 000 00> tshell 20 running 0x00000198 0x00000800 27% 0x00000008 000 00> tidle0 31 ready 0x000000b0 0x00000400 17% 0x00000018 000 00> main 10 suspend 0x0000010c 0x00000800 23% 0x00000005 000 ``` - 增大堆栈测试,同样较高 ``` 00> thread pri status sp stack size max used left tick error 00> ---------- --- ------- ---------- ---------- ------ ---------- --- 00> thd_usbd_m 5 suspend 0x00000180 0x00000600 36% 0x0000000a 000 00> thd_usbd_r 5 suspend 0x00000088 0x00000600 08% 0x00000001 000 00> thd_usbd_s 4 suspend 0x00000088 0x00000400 13% 0x00000001 000 00> thd_usbh_m 5 suspend 0x00000080 0x00000400 32% 0x0000000a 000 00> thd_voc_s1 8 suspend 0x00000088 0x00000400 28% 0x0000000a 000 00> thd_voc_m1 8 suspend 0x00000188 0x00000400 63% 0x00000009 000 00> thd_voc_s0 8 suspend 0x00000088 0x00000400 28% 0x0000000a 000 00> thd_voc_m0 8 suspend 0x00000188 0x00000400 63% 0x00000009 000 00> thd_dtq_s 3 suspend 0x000000a4 0x00000200 32% 0x00000001 000 00> thd_dtq_r 2 suspend 0x000000ac 0x00001000 35% 0x00000001 000 00> thd_dtq_m3 5 suspend 0x00000194 0x00000800 39% 0x0000000a 000 00> thd_dtq_m2 5 suspend 0x00000194 0x00000800 44% 0x00000009 000 00> thd_dtq_m1 5 suspend 0x00000194 0x00000800 44% 0x0000000a 000 00> thd_dtq_m0 5 suspend 0x00000194 0x00000800 44% 0x00000009 000 00> thd_card 6 suspend 0x000000ac 0x00000800 16% 0x0000000a 000 00> thd_spi_s 5 suspend 0x0000007c 0x00000400 12% 0x00000001 000 00> thd_lcd_m 19 suspend 0x000000a4 0x00001000 98% 0x0000001d 000 [栈使用高到98%] 00> thd_bee_d 4 suspend 0x000000a4 0x00000400 16% 0x0000000a 000 00> tshell 20 running 0x00000198 0x00000800 28% 0x00000006 000 00> tidle0 31 ready 0x000000b0 0x00000400 17% 0x00000018 000 00> main 10 suspend 0x0000010c 0x00000800 20% 0x00000005 000 ``` - 再次增大,同样较高 ``` 00> thread pri status sp stack size max used left tick error 00> ---------- --- ------- ---------- ---------- ------ ---------- --- 00> thd_usbd_m 5 suspend 0x00000180 0x00000600 36% 0x0000000a 000 00> thd_usbd_r 5 suspend 0x00000088 0x00000600 08% 0x00000001 000 00> thd_usbd_s 4 suspend 0x00000088 0x00000400 13% 0x00000001 000 00> thd_usbh_m 5 suspend 0x00000080 0x00000400 32% 0x0000000a 000 00> thd_voc_s1 8 suspend 0x00000088 0x00000400 28% 0x0000000a 000 00> thd_voc_m1 8 suspend 0x00000188 0x00000400 63% 0x00000009 000 00> thd_voc_s0 8 suspend 0x00000088 0x00000400 28% 0x0000000a 000 00> thd_voc_m0 8 suspend 0x00000188 0x00000400 63% 0x00000009 000 00> thd_dtq_s 3 suspend 0x000000a4 0x00000200 32% 0x00000001 000 00> thd_dtq_r 2 suspend 0x000000ac 0x00001000 35% 0x00000001 000 00> thd_dtq_m3 5 suspend 0x00000194 0x00000800 39% 0x0000000a 000 00> thd_dtq_m2 5 suspend 0x00000194 0x00000800 44% 0x0000000a 000 00> thd_dtq_m1 5 suspend 0x00000194 0x00000800 44% 0x00000009 000 00> thd_dtq_m0 5 suspend 0x00000194 0x00000800 44% 0x0000000a 000 00> thd_card 6 suspend 0x000000ac 0x00000800 16% 0x00000009 000 00> thd_spi_s 5 suspend 0x0000007c 0x00000400 12% 0x00000001 000 00> thd_lcd_m 19 suspend 0x000000a4 0x00001800 98% 0x00000007 000 00> thd_bee_d 4 suspend 0x000000a4 0x00000400 16% 0x0000000a 000 00> tshell 20 running 0x00000230 0x00000800 27% 0x00000007 000 00> tidle0 31 ready 0x000000b0 0x00000400 17% 0x0000001b 000 00> main 10 suspend 0x0000010c 0x00000800 20% 0x00000005 000 ``` - 于是屏蔽线程函数的操作,再次测试,还是高 ```c void fun_lcd_m(void *param) { rt_uint32_t e; while (1) { // if (rt_event_recv(&dat_event, 1, RT_EVENT_FLAG_OR | RT_EVENT_FLAG_CLEAR, // RT_WAITING_FOREVER, &e) == RT_EOK) // { // /* s0: LCD ½çÃæˢР*/ // switch (sys_tcb_val.work_mode) // { // case SERVICE_MODE: // άÐÞģʽ // drv_lcd_service_mode(); // break; // default: // drv_lcd_normal_mode(); // break; // } // /* s1: LCD ´íÎó¼ì²â */ // app_usb_err_check(); // app_port_err_check(); // app_card_err_check(); // /* s2: LCD Ë¢ÐÂÊý¾Ý */ // if (drv_lcd_uc1617_show()) // { // LOG_D("LCD: uc1617 flash error"); // drv_lcd_uc1617_init(); // drv_lcd_uc1617_show(); // } // /* s3: Ë¢¿¨Ë²Ì¬·µ»Ø */ // if ((lcd_tcb.card_cnt == card_tcb.card_cnt) && (lcd_tcb.card_s == 1)) // { // lcd_tcb.card_s = 0; // rt_event_send(&dat_event, 1); // } // /* s4: ·äÃùÌáʾ */ // if ((bee_tcb.s > 0) && (sys_tcb_val.sys_swd.flg == 0)) // { // rt_event_send(&bee_event, bee_tcb.s); // bee_tcb.s = 0; // } // } rt_thread_mdelay(200); } } ``` ``` 00> thread pri status sp stack size max used left tick error 00> ---------- --- ------- ---------- ---------- ------ ---------- --- 00> thd_usbd_m 5 suspend 0x00000180 0x00000600 36% 0x0000000a 000 00> thd_usbd_r 5 suspend 0x00000088 0x00000600 08% 0x00000001 000 00> thd_usbd_s 4 suspend 0x00000088 0x00000400 13% 0x00000001 000 00> thd_usbh_m 5 suspend 0x00000080 0x00000400 32% 0x0000000a 000 00> thd_voc_s1 8 suspend 0x00000088 0x00000400 28% 0x0000000a 000 00> thd_voc_m1 8 suspend 0x00000188 0x00000400 63% 0x00000009 000 00> thd_voc_s0 8 suspend 0x00000088 0x00000400 28% 0x0000000a 000 00> thd_voc_m0 8 suspend 0x00000188 0x00000400 63% 0x00000009 000 00> thd_dtq_s 3 suspend 0x000000a4 0x00000200 32% 0x00000001 000 00> thd_dtq_r 2 suspend 0x000000ac 0x00001000 35% 0x00000001 000 00> thd_dtq_m3 5 suspend 0x00000194 0x00000800 39% 0x0000000a 000 00> thd_dtq_m2 5 suspend 0x00000194 0x00000800 44% 0x0000000a 000 00> thd_dtq_m1 5 suspend 0x00000194 0x00000800 44% 0x00000009 000 00> thd_dtq_m0 5 suspend 0x00000194 0x00000800 44% 0x0000000a 000 00> thd_card 6 suspend 0x000000ac 0x00000800 16% 0x0000000a 000 00> thd_spi_s 5 suspend 0x0000007c 0x00000400 12% 0x00000001 000 00> thd_lcd_m 19 suspend 0x0000007c 0x00001800 98% 0x00000032 000 [栈使用高到98%] 00> thd_bee_d 4 suspend 0x000000a4 0x00000400 16% 0x0000000a 000 00> tshell 20 running 0x00000210 0x00000800 27% 0x00000007 000 00> tidle0 31 ready 0x000000b0 0x00000400 17% 0x0000001e 000 00> main 10 suspend 0x0000010c 0x00000800 23% 0x00000005 000 ``` 我是否触发了rtt的隐藏BUG,这个统计感觉错的?,这个问题如何排查,总感觉有个系统级别的问题在,即使程序一会儿不死,也不放心
查看更多
2
个回答
默认排序
按发布时间排序
aozima
2021-10-25
调网络不抓包,调I2C等时序不上逻辑分析仪,就像电工不用万用表!多用整理的好的文字,比截图更省流量,还能在整理过程中思考。
直接看下栈上面的数据,应该是写穿造成的!从被写的数据来看是否有线索。
出出啊
2021-10-25
恃人不如自恃,人之为己者不如己之自为也
到我的文章里去找链接,用那个工具查看一下线程栈内存。有可能线程栈内存有被非法写的情况,导致中间部分数据不是 ‘#’ 了。
撰写答案
登录
注册新账号
关注者
0
被浏览
2.7k
关于作者
懒洋洋
这家伙很懒,什么也没写!
提问
9
回答
0
被采纳
0
关注TA
发私信
相关问题
1
有关动态模块加载的一篇论文
2
最近的调程序总结
3
晕掉了,这么久都不见layer2的踪影啊
4
继续K9ii的历程
5
[GUI相关] FreeType 2
6
[GUI相关]嵌入式系统中文输入法的设计
7
20081101 RT-Thread开发者聚会总结
8
嵌入式系统基础
9
linux2.4.19在at91rm9200 上的寄存器设置
10
[转]基于嵌入式Linux的通用触摸屏校准程序
推荐文章
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-Thread】【ci】【scons】将ci.attachconfig.yml和scons结合使用
2
Rt-thread中OTA下载后,bootloader不搬程序
3
ulog 日志 LOG_HEX 输出时间改为本地日期时间
4
在RT-Thread Studio中构建前执行python命令
5
研究一了一段时间RTT,直接标准版上手太难,想用nano,但又舍不得组件
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
USB
DMA
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
FAL
rt-smart
I2C_IIC
ESP8266
UART
WIZnet_W5500
ota在线升级
PWM
cubemx
flash
freemodbus
BSP
packages_软件包
潘多拉开发板_Pandora
定时器
ADC
flashDB
GD32
socket
编译报错
中断
Debug
rt_mq_消息队列_msg_queue
SFUD
msh
keil_MDK
ulog
C++_cpp
MicroPython
本月问答贡献
xusiwei1236
8
个答案
2
次被采纳
踩姑娘的小蘑菇
1
个答案
2
次被采纳
用户名由3_15位
7
个答案
1
次被采纳
bernard
4
个答案
1
次被采纳
RTT_逍遥
3
个答案
1
次被采纳
本月文章贡献
聚散无由
2
篇文章
15
次点赞
catcatbing
2
篇文章
5
次点赞
Wade
2
篇文章
3
次点赞
Ghost_Girls
1
篇文章
6
次点赞
YZRD
1
篇文章
2
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部