Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
Kernel
线程运行一段时间之后返回-02
发布于 2018-12-27 12:57:59 浏览:3074
订阅该版
* 本帖最后由 jzz 于 2018-12-27 15:13 编辑 * 首先我要说明,我搜过论坛了,只有一个回答的链接失效的帖子,我这里SHELL还能正常运行,运行PS可以看到线程的状态是ready,并且错误状态返回-02 ![timeouterror.jpg](/uploads/201812/27/123210vhc00hs9h9hh9990.jpg) 按照添加cpu_usage_idle_hook的方式添加了一个空闲函数钩子,发现cpuusage结果一直不变,加入一个rt_kprintf发现系统只在开始的一小段时间能进入钩子函数,于是将oled的优先级调整到31(当前最大的优先级),这时候注释掉不必要的rt_kprintf之后发现打印出来的CPU使用率如下图, ![新建位图图像.bmp](/uploads/201812/27/124527oepu6pu4rl1mc444.bmp) 这里我有两个问题 1、有没有更好的CPU使用率统计的改进办法,这种办法在满载的时候无法更新CPU使用率(没有好像也无所谓=-=) 2、这里的smoke线程优先级比oled高,led线程和oled线程是时间片共享的(都是一个时间片),即便oled线程一直占用CPU,受影响的应该只有所有优先级31的线程才对(idle线程),这个-02错误产生的原因是什么 **更新 **:通过阅读源码,发现这样一段代码 ```rt_err_t rt_thread_sleep(rt_tick_t tick) { register rt_base_t temp; struct rt_thread *thread; /* 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 */ temp = rt_hw_interrupt_disable(); /* suspend thread */ rt_thread_suspend(thread); /* reset the timeout of thread timer and start it */ rt_timer_control(&(thread->thread_timer), RT_TIMER_CTRL_SET_TIME, &tick); rt_timer_start(&(thread->thread_timer)); /* enable interrupt */ rt_hw_interrupt_enable(temp); rt_schedule(); /* clear error number of this thread to RT_EOK */ if (thread->error == -RT_ETIMEOUT) thread->error = RT_EOK; return RT_EOK; }```由此可见,线程的-02错误产生的原因是到了该执行的时候而没有得到CPU,此时再做一个实验:将oled线程改为不再一直占用CPU而是加入rt_thread_mdelay(10),并且优先级改回正常的30之后,发现此时已经没有-02错误并且系统运行良好,CPU使用率打印如下图 ![新建位图图像 (3).bmp](/uploads/201812/27/143702ihkj0nwebmtuumx0.bmp) 其中CPU占用率高的时间是按下了按键正在用模拟I2C驱动刷新oled,那么**也就是说****?!**(更新:这里的观点有误缺乏思考还是删了) 我想我可能知道原因了,因为oled里面也有使用了模拟i2c1,bh1750里面也用了i2c1,使用的时候没有加锁,可能就是在这里发生了奇妙的事情导致高优先级的bh1750一直占用CPU,具体原因还是欠缺分析
查看更多
3
个回答
默认排序
按发布时间排序
admin
2018-12-27
这家伙很懒,什么也没写!
1)这种 CPU 使用率的方式还是不精确的,要更精确的方式需要另外考虑的; 2)参考下 [https://www.rt-thread.org/qa/forum.php?mod=viewthread&tid=7398&highlight=-02](https://www.rt-thread.org/qa/forum.php?mod=viewthread&tid=7398&highlight=-02)
yqiu
2018-12-27
这家伙很懒,什么也没写!
1)这种 CPU 使用率的方式还是不精确的,要更精确的方式需要另外考虑的; 2)参考下 [https://www.rt-thread.org/qa/for](https://www.rt-thread.org/qa/for) ... 8&highlight=-02
jzz
2018-12-27
这家伙很懒,什么也没写!
>1)这种 CPU 使用率的方式还是不精确的,要更精确的方式需要另外考虑的; >2)参考下 https://www.rt-thread ... --- 多谢回帖,不过我不是需要更精确的方法,我觉得那没有什么太大的意义,就是这个满载情况下获取不到真正的CPU使用率这个情况觉得不是很好,这个链接有什么打开的特殊技巧么。。。我打不开
yqiu
2018-12-27
这家伙很懒,什么也没写!
[i=s] 本帖最后由 yqiu 于 2018-12-27 17:26 编辑 [/i] 应该是参考这个链接: [https://www.rt-thread.org/qa/forum.php?mod=viewthread&tid=7398&highlight=-02](https://www.rt-thread.org/qa/for ... =7398&highlight=-02)
撰写答案
登录
注册新账号
关注者
0
被浏览
3.1k
关于作者
jzz
这家伙很懒,什么也没写!
提问
2
回答
12
被采纳
0
关注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
在用clangd开发RTT吗,快来试试如何简单获得清晰干净的工作区
2
GD32F450 片内 flash驱动适配
3
STM32H7R7运行CherryUSB
4
RT-Smart首次线下培训,锁定2024 RT-Thread开发者大会!
5
使用RC522软件包驱动FM1722
热门标签
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在线升级
freemodbus
PWM
flash
cubemx
packages_软件包
BSP
潘多拉开发板_Pandora
定时器
ADC
flashDB
GD32
socket
中断
编译报错
Debug
SFUD
rt_mq_消息队列_msg_queue
msh
keil_MDK
ulog
C++_cpp
MicroPython
本月问答贡献
a1012112796
10
个答案
1
次被采纳
踩姑娘的小蘑菇
4
个答案
1
次被采纳
红枫
4
个答案
1
次被采纳
张世争
4
个答案
1
次被采纳
Ryan_CW
4
个答案
1
次被采纳
本月文章贡献
catcatbing
3
篇文章
6
次点赞
YZRD
2
篇文章
5
次点赞
qq1078249029
2
篇文章
2
次点赞
xnosky
2
篇文章
1
次点赞
Woshizhapuren
1
篇文章
5
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部