Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
RT-Thread一般讨论
两个RT_Thread版本运行的结果不一样
发布于 2013-01-16 18:14:52 浏览:6426
订阅该版
自己写的一个Applications文件,但在RT_Thread 1.1.0 版本和0.3.1个版本仿真结果不一样,个人认为0.3.1的仿真结果应该是正确,不知道1.1.0版本哪里设置出问题还是怎样。编译运行环境为MDK-ARM4.53,两个工程文件都是RT_Thread官方提供的基于stm32f10x移植历程,除了Application文件,其他文件没进行任何更改;下面是仿真结果和是我的Application文件,百思不得其解,请各路好友帮忙分析分析 在RT_Thread 0.3.1版本的仿真结果为 ``` | / - RT - Thread Operating System / | 0.3.1 build Jan 16 2013 2006 - 2010 Copyright by rt-thread team LED1 ON LED2 ON LED1 OFF LED2 OFF LED1 ON LED2 ON LED1 OFF LED2 OFF LED1 ON LED2 ON``` 而RT_Thread 1.1.0版本上仿真的结果为 ``` | / - RT - Thread Operating System / | 1.1.0 build Jan 16 2013 2006 - 2012 Copyright by rt-thread team LED1 ON LED2 ON LED2 OFF LED1 OFF LED1 ON LED2 ON LED2 OFF LED1 OFF LED1 ON``` Application.c 文件 ``` #include
#include
static void thread1_entry(void* parameter) //线程1入口处 { while (1) { rt_kprintf("LED1 ON "); rt_thread_delay( 20 ); rt_kprintf("LED1 OFF "); rt_thread_delay( 20 ); } } static void thread2_entry(void* parameter) //线程2入口处 { while (1) { rt_kprintf("LED2 ON "); rt_thread_delay( 20 ); rt_kprintf("LED2 OFF "); rt_thread_delay( 20 ); } } int rt_application_init() { rt_thread_t thread1, thread2; /* init led thread */ thread1 = rt_thread_create("thread1",thread1_entry, RT_NULL,512, 20, 10); if (thread1 != RT_NULL) rt_thread_startup(thread1); thread2 = rt_thread_create("thread2",thread2_entry, RT_NULL,512, 20, 10); if (thread2 != RT_NULL) rt_thread_startup(thread2); return 0; }``` 下载附件 [timer的时候发现问题.7z](https://oss-club.rt-thread.org/uploads/3230_0cea402ed231790d1d796224e33a13fc.7z)
查看更多
16
个回答
默认排序
按发布时间排序
aozima
2013-01-16
调网络不抓包,调I2C等时序不上逻辑分析仪,就像电工不用万用表!多用整理的好的文字,比截图更省流量,还能在整理过程中思考。
把所有打印修改成下面这样好比较一些: ``` rt_kprintf("%u LED1 ON ", rt_tick_get()); ```
xdzy
2013-01-16
这家伙很懒,什么也没写!
还是不行呀 0.3.1 \ | / - RT - Thread Operating System / | \ 0.3.1 build Jan 16 2013 2006 - 2010 Copyright by rt-thread team 1 LED1 ON 1 LED2 ON 21 LED1 ON 21 LED2 ON 41 LED1 ON 41 LED2 ON 1.1.0 \ | / - RT - Thread Operating System / | \ 1.1.0 build Jan 16 2013 2006 - 2012 Copyright by rt-thread team 1 LED1 ON 1 LED2 ON 21 LED2 ON 21 LED1 ON 41 LED1 ON 41 LED2 ON
xdzy
2013-01-16
这家伙很懒,什么也没写!
是不是我编译环境有问题呀
prife
2013-01-16
这家伙很懒,什么也没写!
>是不是我编译环境有问题呀 --- 跟编译环境没关系, 这个地方是跟线程的timer有关系, 我记得有邮件列表里修改过这个地方.. 楼主如果真要分析这个原因,那就得深入RTT代码分析, 跟编译器,编译环境,无关. 这个帖子找到了 [https://groups.google.com/forum/#!msg/rt-thread-cnusers/kC57X8dsSL4/G2O8qlFF_R8J](https://groups.google.com/forum/#!msg/r ... O8qlFF_R8J) 如果打不开,就下载附件. [attach]1716[/attach]
xdzy
2013-01-17
这家伙很懒,什么也没写!
原来一年前就出现这种情况了,官方是不是觉得这个现象不算是个问题呢
xdzy
2013-01-17
这家伙很懒,什么也没写!
timer.c可是内核文件呀,改了会不会对其他功能上造成影响,问题一年前就出现了,官方也没有声明,更没有做出什么改进,是不是每遇到类似的基本问题都要用户深入内核代码,修修补补,作为应用层我只关心它的工作原理,工作方式和工作性能;如果内核上的事也需要应用层的用户去做一些不可靠的修改,会延长项目的开发周期。
bernard
2013-01-17
这家伙很懒,什么也没写!
文档里写得很明确,相同优先级任务没有确定性可言。
bernard
2013-01-17
这家伙很懒,什么也没写!
多谢prife给出的链接, 这个问题按照这个线索检查了下,应该是timer队列插入时,如果超时时间相同时,谁先谁后的问题。 这部分应该说按照FIFO方式比较合理。而0.3.x到1.x的变动应该是因为0.3.x OS Tick溢出翻转时,而引入的OS Tick算法的缘故。
bernard
2013-01-17
这家伙很懒,什么也没写!
针对这个问题,Grissiom提供了一个补丁,原来因为没有pull request,所以一些问题的管理不是太方便,被遗忘了(在RealTime这块,相同优先级确实存在着不确定性,相同优先级也就没有确定性可言,所以这个不是个问题),现在使用github后,Grissiom可以把这个补丁的request提上来。
prife
2013-01-17
这家伙很懒,什么也没写!
>timer.c可是内核文件呀,改了会不会对其他功能上造成影响,问题一年前就出现了,官方也没有声明,更没有做出什么改进,是不是每遇到类似的基本问题都要用户深入内核代码,修修补补,作为应用层我只关心它的工作原理,工作方式和工作性能;如果内核上的事也需要应用层的用户去做一些不可靠的修改,看来也只能玩玩,真正要上项目,我看还是算了吧。 --- 首先我对你的不满表示理解. bernard刚才给出了回复,主要是相同优先级的线程本身就不应该具有确定的调度机制. 所以本质上来说不应该是bug, 只是表现形式确实不太符合逻辑. 我们会尽快修复这个问题, 开源项目,希望多给些机会和耐心...把这个项目完善起来..谢谢
撰写答案
登录
注册新账号
关注者
0
被浏览
6.4k
关于作者
xdzy
这家伙很懒,什么也没写!
提问
7
回答
31
被采纳
0
关注TA
发私信
相关问题
1
有关动态模块加载的一篇论文
2
最近的调程序总结
3
晕掉了,这么久都不见layer2的踪影啊
4
继续K9ii的历程
5
[GUI相关] FreeType 2
6
[GUI相关]嵌入式系统中文输入法的设计
7
20081101 RT-Thread开发者聚会总结
8
嵌入式系统基础
9
linux2.4.19在at91rm9200 上的寄存器设置
10
[转]基于嵌入式Linux的通用触摸屏校准程序
推荐文章
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 Studio中构建前执行python命令
2
研究一了一段时间RTT,直接标准版上手太难,想用nano,但又舍不得组件
3
CherryUSB开发笔记(一):FSDEV USB IP核的 HID Remote WakeUp (USB HID 远程唤醒) 2025-01-18 V1.1
4
RT-thread 缩写字典
5
RT Thread 源码分析笔记 :线程和调度器
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
Bootloader
AT
Hardfault
CAN总线
FinSH
ART-Pi
USB
DMA
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
FAL
rt-smart
I2C_IIC
ESP8266
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
次被采纳
本月文章贡献
聚散无由
2
篇文章
14
次点赞
catcatbing
2
篇文章
4
次点赞
Wade
2
篇文章
2
次点赞
Ghost_Girls
1
篇文章
5
次点赞
xiaorui
1
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部