Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
线程调度死机
rt_thread_delay_until函数运行几个小时后线程不再被执行
发布于 2024-07-30 15:24:03 浏览:285
订阅该版
使用函数进行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
被浏览
285
关于作者
liuyue9793
这家伙很懒,什么也没写!
提问
11
回答
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
如何在master上的BSP中添加配置yml文件
2
使用百度AI助手辅助编写一个rt-thread下的ONVIF设备发现功能的功能代码
3
RT-Thread 发布 EtherKit开源以太网硬件!
4
rt-thread使用cherryusb实现虚拟串口
5
《C++20 图形界面程序:速度与渲染效率的双重优化秘籍》
热门标签
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
WIZnet_W5500
UART
ota在线升级
PWM
cubemx
freemodbus
flash
packages_软件包
BSP
潘多拉开发板_Pandora
定时器
ADC
GD32
flashDB
socket
中断
Debug
编译报错
msh
SFUD
keil_MDK
rt_mq_消息队列_msg_queue
ulog
C++_cpp
at_device
本月问答贡献
踩姑娘的小蘑菇
7
个答案
3
次被采纳
a1012112796
13
个答案
2
次被采纳
张世争
9
个答案
2
次被采纳
rv666
5
个答案
2
次被采纳
用户名由3_15位
11
个答案
1
次被采纳
本月文章贡献
程序员阿伟
9
篇文章
2
次点赞
hhart
3
篇文章
4
次点赞
大龄码农
1
篇文章
5
次点赞
RTT_逍遥
1
篇文章
2
次点赞
ThinkCode
1
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部