Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
Kernel
线程运行一段时间之后返回-02
发布于 2018-12-27 12:57:59 浏览:3130
订阅该版
* 本帖最后由 jzz 于 2018-12-27 15:13 编辑 * 首先我要说明,我搜过论坛了,只有一个回答的链接失效的帖子,我这里SHELL还能正常运行,运行PS可以看到线程的状态是ready,并且错误状态返回-02  按照添加cpu_usage_idle_hook的方式添加了一个空闲函数钩子,发现cpuusage结果一直不变,加入一个rt_kprintf发现系统只在开始的一小段时间能进入钩子函数,于是将oled的优先级调整到31(当前最大的优先级),这时候注释掉不必要的rt_kprintf之后发现打印出来的CPU使用率如下图,  这里我有两个问题 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使用率打印如下图  其中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
RT-thred的stm32h723对应bsp包CubeMX添加其他外设报错
2
RT-Thread中的time溢出问题,时间戳溢出,解决方法
3
ART-PI使用env驱动ETH网卡,pc和板子可以ping通
4
SystemView线程名字不显示
5
只用网页也能跑RT-Smart 无门槛腾讯Cloud studio + smart-build快速构建
热门标签
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
次被采纳
三世执戟
8
个答案
1
次被采纳
KunYi
8
个答案
1
次被采纳
xiaorui
3
个答案
1
次被采纳
winfeng
2
个答案
1
次被采纳
本月文章贡献
catcatbing
2
篇文章
5
次点赞
swet123
1
篇文章
4
次点赞
Days
1
篇文章
4
次点赞
YZRD
1
篇文章
2
次点赞
阳光的掌控者
1
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部