Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
RT-Thread一般讨论
求助 关于stack overflow问题
发布于 2012-01-18 17:10:48 浏览:6055
订阅该版
小弟现在用Nios-II的MCU进行RT-Thread的开发常常碰到stack overflow的问题想要请教各位新进 开发环境 : Nios-II IDE 9.0版 设备 : 黑金开发版 cyclone II 程序内容: 1.使用RT-thread 1.0.0版本的bps加上example中的timer_timerout.c, semaphore_buffer_worker.c, semaphore_producer_consumer.c三个范例 2.将Finsh开启,使用终端机输入指令 问题 若我将timer_timerout.c中的timer的timeout速度调到100 tick以上,那就可以正常运行,不会发生问题 若我将timer_timerout.c中的timer的timeout速度调到1 tick时,从UART输入一个字符之后就很容易出现 thread stack overflow的现象,造成系统重新启动 使用list_thread观察时发现 正常情况下 ```finsh>>list_thread thread pri status sp stack size max used left tick error -------- ---- ------- ---------- ---------- ---------- ---------- --- tidle 0x1f ready 0x00000124 0x00000400 0x000001b4 0x00000010 000 tshell 0x0a ready 0x0000009c 0x00000800 0x00000240 0x00000004 000 worker 0x19 ready 0x000000c0 0x00000200 0x000000f8 0x00000004 -02 semT 0x19 ready 0x000000bc 0x00000800 0x000000bc 0x00000005 -02 t 0x1a ready 0x000000fc 0x00001000 0x0000019c 0x00000004 -02 t2 0x19 ready 0x000000a4 0x00000200 0x000000a4 0x00000005 -02 t1 0x19 ready 0x00000098 0x00000200 0x000000a0 0x00000005 -02 led2 0x14 suspend 0x00000098 0x00000400 0x00000098 0x00000005 000 led1 0x14 suspend 0x00000098 0x00000400 0x00000098 0x00000005 000``` 错误发生时(只输入l 一个字) ```finsh>>lthread:semT stack overflow thread pri status sp stack size max used left tick error -------- ---- ------- ---------- ---------- ---------- ---------- --- tidle 0x1f ready 0x00000068 0x00000400 0x000001b4 0x00000016 000 tshell 0x0a suspend 0x0000009c 0x00000800 0x00000154 0x00000008 000 worker 0x19 ready 0x000000c0 0x00000200 0x000000c0 0x00000005 -02 semT 0x19 ready 0x00002474 0x00000800 0x000000bc 0x00000005 -02 t 0x1a ready 0x000000fc 0x00001000 0x00000160 0x00000002 -02 t2 0x19 ready 0x000000a4 0x00000200 0x000000e4 0x00000004 -02 t1 0x19 ready 0x00000098 0x00000200 0x000000a0 0x00000005 -02 led2 0x14 suspend 0x00000098 0x00000400 0x00000098 0x00000005 000 led1 0x14 suspend 0x00000098 0x00000400 0x00000098 0x00000005 000``` 可以看出 semT的SP 发生错误 请问要如何处理?可能的问题点在哪里? Sincerely Liwei Chour in OFFICe
查看更多
7
个回答
默认排序
按发布时间排序
bernard
2012-01-19
这家伙很懒,什么也没写!
nios-ii的问题还得nios-ii分支维护人来解决,有可能的问题会是与nios-ii移植相关的。
chour
2012-01-19
这家伙很懒,什么也没写!
经过一天的测试发现问题所在 在shell.c中的finsh_thread_entry的 ``` if( rt_sem_take(&shell->rx_sem, RT_WAITING_FOREVER) != RT_EOK) continue; ``` 会导致stack overflow。 我将shell中用的Semaphore改成一个字符旗标之后就可以正常工作,不知道这样的问题是出在哪里?
chour
2012-02-08
这家伙很懒,什么也没写!
加入網路之後更容易發生 thread stack overflow,問題都是出在 thread的sp發生異常。 經過反覆的測試,在處理timer的中斷函式 rt_hw_timer_handler中 將中斷處理(rt_interrupt_enter與rt_interrupt_leave)改成Critical session(rt_enter_critical與rt_leave_critical)就可以正常工作。經過12小時的測試並沒有發生stack overflow的問題。 不知道這樣的修改是否有任何潛在的問題?
bernard
2012-02-08
这家伙很懒,什么也没写!
nios-ii分支,因为目前栈处理得并不好,中断栈是在线程栈中开辟存放的,所以有的时候会出现栈over flow或栈乱掉的情况。 这也是目前未正式发布nios-ii移植分支的原因。你可以多从分支移植的角度出发,看看系统移植的情况,这里面应该是存在bug。
aozima
2012-02-08
调网络不抓包,调I2C等时序不上逻辑分析仪,就像电工不用万用表!多用整理的好的文字,比截图更省流量,还能在整理过程中思考。
Nios II 9.0不支持添加自定义section, 不知道楼主的finsh是如何添加的? 9.1以后才可以支持。 以下是当时的一些记录: >因为9.0不支持添加自定义section,于是升级成9.1 >结果发现9.1只认.s的汇编文件,而GCC一般是.S >9.0也是.S > >fuck... 那文件又不是一般的大,因为这个,刚好下决心换块新500G来. > >================================================== >经测试, 10.0的头文件搜索目录设置与9.1一样. >同时10.0也是认.S的汇编文件. ^_^ 以后就用这个版本了. ---
chour
2012-02-09
这家伙很懒,什么也没写!
我沒有用finsh,只是在shell中利用字串比對方式執行一些finsh的指令(如 list_thread, list_timer...)
撰写答案
登录
注册新账号
关注者
0
被浏览
6.1k
关于作者
chour
这家伙很懒,什么也没写!
提问
3
回答
4
被采纳
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中OTA下载后,bootloader不搬程序
2
ulog 日志 LOG_HEX 输出时间改为本地日期时间
3
在RT-Thread Studio中构建前执行python命令
4
研究一了一段时间RTT,直接标准版上手太难,想用nano,但又舍不得组件
5
CherryUSB开发笔记(一):FSDEV USB IP核的 HID Remote WakeUp (USB HID 远程唤醒) 2025-01-18 V1.1
热门标签
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
5
个答案
2
次被采纳
踩姑娘的小蘑菇
1
个答案
2
次被采纳
用户名由3_15位
7
个答案
1
次被采纳
bernard
4
个答案
1
次被采纳
张世争
1
个答案
1
次被采纳
本月文章贡献
聚散无由
2
篇文章
15
次点赞
catcatbing
2
篇文章
5
次点赞
Wade
2
篇文章
2
次点赞
Ghost_Girls
1
篇文章
6
次点赞
YZRD
1
篇文章
2
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部