Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
Kernel
timer_thread的rt_thread_timeout执行时,出现断言错误
发布于 2018-06-13 19:01:41 浏览:2713
订阅该版
如题:timer_thread的rt_thread_timeout执行时,出现了RT_ASSERT((thread->stat & RT_THREAD_STAT_MASK) == RT_THREAD_SUSPEND)的断言错误;通过打log的方式发现,rt_timer_start在如下位置被重入,导致被重入的rt_timer_start函数恢复执行时,将timer_thread的状态修改为了ready,而后timer_thread的rt_thread_timeout执行时,就出现了断言错误。 不知分析的对不对,请帮忙分析一下。 rt_err_t rt_timer_start(rt_timer_t timer) { ........ #ifdef RT_USING_TIMER_SOFT if (timer->parent.flag & RT_TIMER_FLAG_SOFT_TIMER) { /* check whether timer thread is ready */ if ((timer_thread.stat & RT_THREAD_STAT_MASK) != RT_THREAD_READY) { /* resume timer thread to check soft timer */ rt_thread_resume(&timer_thread); rt_schedule(); } } #endif return -RT_EOK; } rt_err_t rt_thread_resume(rt_thread_t thread) { ......... rt_timer_stop(&thread->thread_timer); /* enable interrupt */ rt_hw_interrupt_enable(temp); (在此处被重入) /* insert to schedule ready list */ rt_schedule_insert_thread(thread); RT_OBJECT_HOOK_CALL(rt_thread_resume_hook, (thread)); return RT_EOK; } RTM_EXPORT(rt_thread_resume);
查看更多
6
个回答
默认排序
按发布时间排序
简简单
2018-06-14
这家伙很懒,什么也没写!
顶
简简单
2018-06-14
这家伙很懒,什么也没写!
顶
简简单
2018-06-14
这家伙很懒,什么也没写!
顶
Tyrion
2018-06-20
这家伙很懒,什么也没写!
顶顶顶
747lulu747
2019-11-27
这家伙很懒,什么也没写!
很可能是编译器优化的问题。 复现环境: 编译器ARM_GCC,MDK5,优化等级level 2 就会出现如题的断言失败 如果将优化等级改为level 0,则不会出现问题。 实际上,从代码的角度而言,rt_thread_resume是在systick_handle上下文中执行的,这个时候已经关闭了中断; 因此,我猜测应该是编译优化等级引起的错误,至于编译器优化了哪些代码,我这边没有去验证。 期待后面有时间做个验证。
guanxionghui
2020-02-26
这家伙很懒,什么也没写!
[i=s] 本帖最后由 guanxionghui 于 2020-2-26 19:24 编辑 [/i] >很可能是编译器优化的问题。 > >复现环境: --- 我的优化等级为level0也会复现呢:Q 不过后来一查看是keil的OneElfS 被选中了。去掉OneElfS选项好像可以正常。
撰写答案
登录
注册新账号
关注者
0
被浏览
2.7k
关于作者
简简单
这家伙很懒,什么也没写!
提问
4
回答
6
被采纳
1
关注TA
发私信
相关问题
1
请教cpu使用率分析
2
选择FreeRTOS, 还是RT-Thread。
3
thread heap stack overflow ?
4
rtt消息队列delay问题
5
释放被删除线程的内存地方在哪里啊
6
请教:各线程结束后,释放其中的内存的连续性问题
7
STM32F103中断关于信号量、邮箱问题
8
RTT中的线程栈大小如何控制
9
关于线程由执行态变为挂起态的代码实现,,,
10
rt_malloc(rt_size_t size)内存分配函数最小分配尺寸问题
推荐文章
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
ART-Pi2移植CMSIS-DAP(基于CherryUSB协议栈)
2
RT-thred的stm32h723对应bsp包CubeMX添加其他外设报错
3
RT-Thread中的time溢出问题,时间戳溢出,解决方法
4
ART-PI使用env驱动ETH网卡,pc和板子可以ping通
5
SystemView线程名字不显示
热门标签
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
次被采纳
xiaorui
3
个答案
2
次被采纳
winfeng
2
个答案
2
次被采纳
三世执戟
8
个答案
1
次被采纳
KunYi
8
个答案
1
次被采纳
本月文章贡献
catcatbing
2
篇文章
5
次点赞
swet123
1
篇文章
4
次点赞
Days
1
篇文章
4
次点赞
YZRD
1
篇文章
2
次点赞
lizimu
1
篇文章
2
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部