Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
线程调度死机
rt_thread_delay_until函数运行几个小时后线程不再被执行
发布于 2024-07-30 15:24:03 浏览:409
订阅该版
使用函数进行1秒钟的延迟,运行十几个小时后,线程没有阻塞,但不再被执行。 `thread->thread_timer`也不在定时器链表中。 ```c now_tick = rt_tick_get(); for( ;; ){ rt_thread_delay_until(&now_tick, RT_TICK_PER_SECOND); }/*for(;;)*/ ```
查看更多
1
个回答
默认排序
按发布时间排序
liuyue9793
2024-08-06
这家伙很懒,什么也没写!
经过几天的调试发现rt_thread_delay_until函数存在问题,下面是问题的一个简单分析。 ```c rt_err_t rt_thread_delay_until(rt_tick_t *tick, rt_tick_t inc_tick) { rt_base_t level; struct rt_thread *thread; rt_tick_t cur_tick; RT_ASSERT(tick != RT_NULL); /* set to current thread */ thread = rt_thread_self(); RT_ASSERT(thread != RT_NULL); RT_ASSERT(rt_object_get_type((rt_object_t)thread) == RT_Object_Class_Thread); /* disable interrupt */ level = rt_spin_lock_irqsave(&(thread->spinlock)); /* reset thread error */ thread->error = RT_EOK; cur_tick = rt_tick_get(); if (cur_tick - *tick < inc_tick) { thread->user_data = 1; rt_tick_t left_tick; *tick += inc_tick; left_tick = *tick - cur_tick; rt_spin_unlock_irqrestore(&(thread->spinlock), level); /* suspend thread */ rt_thread_suspend_with_flag(thread, RT_UNINTERRUPTIBLE); level = rt_spin_lock_irqsave(&(thread->spinlock)); /* reset the timeout of thread timer and start it */ rt_timer_control(&(thread->thread_timer), RT_TIMER_CTRL_SET_TIME, &left_tick); rt_timer_start(&(thread->thread_timer)); rt_spin_unlock_irqrestore(&(thread->spinlock), level); rt_schedule(); /* clear error number of this thread to RT_EOK */ if (thread->error == -RT_ETIMEOUT) { thread->error = RT_EOK; } } else { *tick = cur_tick; rt_spin_unlock_irqrestore(&(thread->spinlock), level); } return thread->error; } ``` 在上面的代码中rt_thread_suspend_with_flag函数的调用环境并没有关中断,导致串口中断在该函数返回的过程中打断了线程的执行。 串口中断会调用rt_schedule函数,该函数导致中断返回后原来执行的线程被挂起,后面启动定时器的代码无法被执行,线程也无法通过timeout函数被重新启动,该线程将永远挂起无法执行。 ![screenshot_image.png](https://oss-club.rt-thread.org/uploads/20240806/f36a4b6cf4609d027942714b4a424f0a.png)
撰写答案
登录
注册新账号
关注者
1
被浏览
409
关于作者
liuyue9793
这家伙很懒,什么也没写!
提问
12
回答
6
被采纳
0
关注TA
发私信
相关问题
1
STM32L431线程调度死机?
推荐文章
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 源码分析笔记 :线程和调度器
2
RT-Thread项目助手v0.2.0 - 支持Env Windows
3
RttreadV5.10上,GD32F450Z RTC时间显示问题
4
rt-smart启动流程分析
5
EtherKit快速上手PROFINET
热门标签
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
ESP8266
I2C_IIC
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
MicroPython
C++_cpp
本月问答贡献
出出啊
1517
个答案
342
次被采纳
小小李sunny
1444
个答案
290
次被采纳
张世争
813
个答案
177
次被采纳
crystal266
547
个答案
161
次被采纳
whj467467222
1222
个答案
149
次被采纳
本月文章贡献
出出啊
1
篇文章
2
次点赞
小小李sunny
1
篇文章
1
次点赞
张世争
1
篇文章
3
次点赞
crystal266
2
篇文章
2
次点赞
whj467467222
2
篇文章
2
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部