Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
rt_thread_mdelay
rt_thread_mdelay不执行的问题
发布于 2022-06-06 14:53:51 浏览:375
订阅该版
想在拉高电平后延时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
被浏览
375
关于作者
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
机器人操作系统 (ROS2) 和 RT-Thread 通信
4
五分钟玩转RT-Thread新社区
5
国产MCU移植系列教程汇总,欢迎查看!
6
【技术三千问】之《玩转ART-Pi》,看这篇就够了!干货汇总
7
关于STM32H7开发板上使用SDIO接口驱动SD卡挂载文件系统的问题总结
8
STM32的“GPU”——DMA2D实例详解
9
RT-Thread隐藏的宝藏之completion
10
【ART-PI】RT-Thread 开启RTC 与 Alarm组件
最新文章
1
STM32H7 实现 BootLoader 内 SDRAM 的初始化的注意事项
2
PSoC™ 62 温湿采集功耗测试
3
利用RT-Thread与MQTT实现的毕业设计——智慧班车管理系统的设计与实现实录
4
vscode+pyocd+daplink 调试瑞萨ra6m3
5
RT-Thread Smart 用户态开发教程(基于xmake)
热门标签
RT-Thread Studio
串口
LWIP
Env
SPI
AT
FinSH
ART-Pi
Bootloader
CAN总线
Hardfault
文件系统
USB
DMA
RT-Thread
线程
SCons
RT-Thread Nano
stm32
MQTT
ESP8266
ota
WIZnet_W5500
RTC
rt-smart
UART
flash
rtthread
packages_软件包
freemodbus
潘多拉开发板_Pandora
I2C
cubemx
FAL
定时器
PWM
BSP
AB32VG1
ADC
中断
消息队列_msg_queue
SDIO
msh
Debug
keil
编译报错
socket
LVGL
SFUD
C++_cpp
本月问答贡献
出出啊
1440
个答案
321
次被采纳
小小李sunny
1355
个答案
269
次被采纳
crystal266
507
个答案
150
次被采纳
whj467467222
1212
个答案
143
次被采纳
张世争
636
个答案
140
次被采纳
本月文章贡献
出出啊
3
篇文章
12
次点赞
小小李sunny
1
篇文章
1
次点赞
crystal266
1
篇文章
1
次点赞
whj467467222
2
篇文章
1
次点赞
张世争
2
篇文章
8
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部