Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
RT-Thread一般讨论
timer超时回调函数栈溢出了 请问应修改何处的栈大小
发布于 2010-10-28 23:34:56 浏览:6366
订阅该版
[s:166] 俺初始化了一个timer rt_timer_init(&(update_timer), "t1", // timer name timeout_update_buffer, // timeout callback p_buf, // timeout callback args UPDATE_TIMER_OV, // timeout os_ticks RT_TIMER_FLAG_PERIODIC); // periodic timer 可是 一旦启动该timer 执行回调函数后 指定宕机 跟踪进去是挂在 _rt_scheduler_stack_check() stack overflow那里了 如果我把超时回调函数换成 简单的 仅仅打印一行文字的语句 就不会有溢出了 所以 我猜测应该是调整某处定义的栈大小就可以了 那么 应该是调整哪个值呢? [s:188]
查看更多
7
个回答
默认排序
按发布时间排序
bernard
2010-10-29
这家伙很懒,什么也没写!
你的rtconfig.h头文件是如何配置的呢?还有你的硬件平台、RT-Thread的版本。
mail2li
2010-10-29
这家伙很懒,什么也没写!
处理器是 STM32F103CB 20K ram 稍微有点小 [s:191] —— 3合1的小板上就只有这个 [s:193] rtt 是SVN抓的0.3.2的最新的branch 编译器是keil arm 4.1 rtconfig.h如下: ========================================================= /* RT_NAME_MAX*/ #define RT_NAME_MAX 8 /* RT_ALIGN_SIZE*/ #define RT_ALIGN_SIZE 4 /* PRIORITY_MAX */ #define RT_THREAD_PRIORITY_MAX 32 /* Tick per Second */ #define RT_TICK_PER_SECOND 1000 #define RT_USING_OVERFLOW_CHECK /* Using Hook */ #define RT_USING_HOOK /* SECTION: RT_DEBUG -------------------------------------------------------*/ #define RT_DEBUG /* Thread Debug */ #define RT_THREAD_DEBUG /* SECTION: Software Timer -------------------------------------------------*/ /* Using Software Timer */ #define RT_USING_TIMER_SOFT #define RT_TIMER_THREAD_PRIO 4 #define RT_TIMER_THREAD_STACK_SIZE 512 #define RT_TIMER_TICK_PER_SECOND 10 /* SECTION: IPC ------------------------------------------------------------*/ /* Using Semaphore*/ #define RT_USING_SEMAPHORE /* Using Mutex */ #define RT_USING_MUTEX /* Using Event */ #define RT_USING_EVENT /* Using MailBox */ #define RT_USING_MAILBOX /* Using Message Queue */ #define RT_USING_MESSAGEQUEUE /* SECTION: Memory Management ----------------------------------------------*/ /* Using Memory Pool Management*/ #define RT_USING_MEMPOOL /* Using Dynamic Heap Management */ #define RT_USING_HEAP /* Using Small MM */ #define RT_USING_SMALL_MEM /* Using SLAB Allocator*/ //#define RT_USING_SLAB /* SECTION: Device System --------------------------------------------------*/ /* Using Device System */ #define RT_USING_DEVICE #define RT_USING_UART1 #define RT_USING_UART2 #define RT_USING_UART3 /* SECTION: Console options ------------------------------------------------*/ /* the buffer size of console*/ #define RT_CONSOLEBUF_SIZE 128 /* SECTION: finsh, a C-Express shell ---------------------------------------*/ /* Using FinSH as Shell*/ #define RT_USING_FINSH /* Using symbol table */ #define FINSH_USING_SYMTAB #define FINSH_USING_DESCRIPTION #define FINSH_THREAD_STACK_SIZE 1024 /* SECTION: a runtime libc library -----------------------------------------*/ /* a runtime libc library*/ // #define RT_USING_NEWLIB #define RT_USING_MINILIBC /* SECTION: C++ support ----------------------------------------------------*/ /* Using C++ support*/ // #define RT_USING_CPLUSPLUS /* SECTION: DFS options ----------------------------------------------------*/ #define RT_USING_DFS // #define RT_USING_DFS_EFSL /* byte alignment for EFSL */ #define BYTE_ALIGNMENT #define RT_USING_DFS_ELMFAT #define RT_DFS_ELM_WORD_ACCESS #define RT_DFS_ELM_DRIVES 1 #define RT_DFS_ELM_USE_LFN 0 #define RT_DFS_ELM_MAX_LFN 255 /* the max number of mounted filesystem */ #define DFS_FILESYSTEMS_MAX 1 /* the max number of opened files */ #define DFS_FD_MAX 2 /* the max number of cached sector */ #define DFS_CACHE_MAX_NUM 4 ========================================================= 编译结果 RW-data=848 ZI-data=13820
bernard
2010-10-29
这家伙很懒,什么也没写!
感觉有些不像是栈溢出,因为timer的超时处理函数是在systick的中断上下文中进行处理的,除非你的中断栈太小了,然后越界访问到其他线程栈去了。 中断栈在start_rvds.S中由stack_size定义。 比较可能的情况是,你的一些代码直接发生了越界,然后访问到其他线程栈。你可以把timer超时时,前后的线程拿来分析下,另外就是,出现了overflow check时,是哪个线程。
mail2li
2010-10-29
这家伙很懒,什么也没写!
诡异的是 overflow check时候的 thread->name 是"(-" 似乎那个时候thread指向了错误的位置 [s:170]
bernard
2010-10-29
这家伙很懒,什么也没写!
典型的内存越界,仔细跟踪下,找出原因出来。
mail2li
2010-11-03
这家伙很懒,什么也没写!
[s:182] [s:182] [s:182] 原因找到了 是回调函数中某处使用了rt_thread_delay()所致 低级错误 [s:191]
撰写答案
登录
注册新账号
关注者
0
被浏览
6.4k
关于作者
mail2li
这家伙很懒,什么也没写!
提问
10
回答
38
被采纳
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
次被采纳
张世争
1
个答案
1
次被采纳
本月文章贡献
聚散无由
2
篇文章
15
次点赞
catcatbing
2
篇文章
5
次点赞
Wade
2
篇文章
2
次点赞
Ghost_Girls
1
篇文章
6
次点赞
YZRD
1
篇文章
2
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部