Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
rt_thread_mdelay
rt_thread_mdelay不执行的问题
发布于 2022-06-06 14:53:51 浏览:428
订阅该版
想在拉高电平后延时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
被浏览
428
关于作者
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
RyanMqtt 移植指南(三)
2
RyanMqtt QOS质量测试(二)
3
WCH APT 零等待FLASH的思考
4
RyanMqtt使用介绍和示例代码(一)
5
RTT平台 zephyr_polling软件包 Bluenrg2 蓝牙芯片启动流程
热门标签
RT-Thread Studio
串口
Env
LWIP
AT
SPI
Bootloader
FinSH
ART-Pi
CAN总线
Hardfault
USB
文件系统
DMA
RT-Thread
SCons
线程
RT-Thread Nano
MQTT
stm32
ESP8266
rt-smart
WIZnet_W5500
RTC
flash
ota
UART
FAL
packages_软件包
I2C
freemodbus
cubemx
潘多拉开发板_Pandora
定时器
BSP
PWM
ADC
socket
AB32VG1
SDIO
keil_MDK
中断
消息队列_msg_queue
编译报错
Debug
C++_cpp
msh
QEMU
SFUD
MicroPython
本月问答贡献
张世争
19
个答案
4
次被采纳
道友
41
个答案
3
次被采纳
CrazyH
52
个答案
2
次被采纳
踩姑娘的小蘑菇
15
个答案
2
次被采纳
xiaorui
8
个答案
2
次被采纳
本月文章贡献
paradox
5
篇文章
4
次点赞
螺丝松掉的人
4
篇文章
12
次点赞
Ryan_CW
3
篇文章
5
次点赞
子牧r
3
篇文章
2
次点赞
牧尘
2
篇文章
6
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部