Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
rt_thread_mdelay
rt_thread_mdelay不执行的问题
发布于 2022-06-06 14:53:51 浏览:707
订阅该版
想在拉高电平后延时20ms, 使用示波器查看发现并没有20ms的延时, 故直接打印看了一下. 发现tick的值没有20ms的变化. 这是什么造成的呢? 没有在中断中使用. ```c void hb_on(void) { drv_pwr(name, LOGIC_STAT_ON); LOG_D("%d",rt_tick_get()); rt_thread_mdelay(20); LOG_D("%d",rt_tick_get()); } ``` 这是打印的两次tick的值: ``` 12-08 08:00:23 D/HB: 23153 12-08 08:00:23 D/HB: 23153 ``` rt-thread 4.0.3 使用类似: ```c void thread_task(void) { while(1) { ....... ....... (此处调用) hb_on(); ....... ....... rt_thread_mdelay(20); // 这个是没问题的 } } ```
查看更多
出出啊
2022-06-06
恃人不如自恃,人之为己者不如己之自为也
被优化了💤
5
个回答
默认排序
按发布时间排序
123
认证专家
2022-06-07
这家伙很懒,什么也没写!
用这个`rt_thread_delay_until`, 然后[测试用例在rtt仓库](https://gitee.com/rtthread/rt-thread/blob/gitee_master/examples/utest/testcases/kernel/thread_tc.c#L402-456)都有,我摘取一段如下: ```c { rt_tick_t tick; rt_tick_t check_tick = 0; rt_tick_t delta = 0; tick = rt_tick_get(); check_tick = tick; rt_thread_delay_until(&tick, 100); delta = rt_tick_get() - check_tick; rt_kprintf("delta[100] -> %d\n", delta); } ```
ZMJJ_5836
2022-06-06
这家伙很懒,什么也没写!
做了个测试: ``` void thread_task(void) { while(1) { ....... ....... LOG_D("%d",rt_tick_get()); rt_thread_mdelay(20); LOG_D("%d",rt_tick_get()); LOG_D("11111111111"); ....... ....... rt_thread_mdelay(20); } } ``` 打印的内容如下: 12-08 08:07:43 D/TASK: 463334 12-08 08:07:43 D/TASK: 463334 12-08 08:07:43 D/TASK: 11111111111 12-08 08:07:43 D/TASK: 463374 12-08 08:07:43 D/TASK: 463374 12-08 08:07:43 D/TASK: 11111111111 12-08 08:07:43 D/TASK: 463414 12-08 08:07:43 D/TASK: 463414 12-08 08:07:43 D/TASK: 11111111111 走了40ms!!!!' 怎样才能中间停20ms去做其他的事再接着这个task继续跑呢? 又做了个测试, 没有加while(1), 结果就是对的 ``` void thread_test(void) { ....... ....... LOG_D("%d",rt_tick_get()); rt_thread_mdelay(300); LOG_D("%d",rt_tick_get()); ....... ....... LOG_D("%d",rt_tick_get()); rt_thread_mdelay(200); LOG_D("%d",rt_tick_get()); } ``` 打印如下: 01-01 00:00:00 D/S: 168 01-01 00:00:00 D/S: 469 12-08 08:00:01 D/S: 1472 12-08 08:00:01 D/S: 1672
张世争
2022-06-07
学以致用
改成这种方式看看 ```c void hb_on(void) { rt_tick_t tick = 0; drv_pwr(name, LOGIC_STAT_ON); tick = rt_tick_get(); LOG_D("%d", tick); rt_thread_mdelay(20); tick = rt_tick_get(); LOG_D("%d", tick); } ```
flashman2002
2022-06-07
这家伙很懒,什么也没写!
你的ulog是否设置成了async output mode?
撰写答案
登录
注册新账号
关注者
0
被浏览
707
关于作者
ZMJJ_5836
这家伙很懒,什么也没写!
提问
3
回答
1
被采纳
0
关注TA
发私信
相关问题
1
在rt_hw_board_init里如何使用rt_thread_mdelay函数
2
_mdelay()时间误差问题
3
在main函数while里调用rt_thread_mdelay导致死机
4
tickless模式下唤醒后第一个延时不起作用吗?
5
rt-thread延时函数的区别
6
rt_thread_mdelay()延迟时间不对
7
rtt nano rt_thread_mdelay后无法使用uart2发送
8
rtthread调用了rt_thread_mdelay后卡死
9
求助关于rt_thread_mdelay的使用范围
10
驱动中调用 rt_thread_mdelay
推荐文章
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
使用百度AI助手辅助编写一个rt-thread下的ONVIF设备发现功能的功能代码
2
RT-Thread 发布 EtherKit开源以太网硬件!
3
rt-thread使用cherryusb实现虚拟串口
4
《C++20 图形界面程序:速度与渲染效率的双重优化秘籍》
5
《原子操作:程序世界里的“最小魔法单位”解析》
热门标签
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
次被采纳
本月文章贡献
程序员阿伟
8
篇文章
2
次点赞
hhart
3
篇文章
4
次点赞
大龄码农
1
篇文章
5
次点赞
ThinkCode
1
篇文章
1
次点赞
Betrayer
1
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部