Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
HWTIMER_硬件定时器
硬件定时器定时不准确?
发布于 2021-11-02 09:33:02 浏览:1440
订阅该版
再用官方例程去调试硬件定时器的时候,发现延时5s后在回调函数里面调用rt_tick_get()不准确,这是怎么回事啊 ```c static rt_err_t timeout_cb(rt_device_t dev, rt_size_t size) { rt_kprintf("this is hwtimer timeout callback fucntion!\n"); rt_kprintf("tick is :%d !\n", rt_tick_get()); return 0; } static int hwtimer_sample(int argc, char *argv[]) { rt_err_t ret = RT_EOK; rt_hwtimerval_t timeout_s; /* 定时器超时值 */ rt_device_t hw_dev = RT_NULL; /* 定时器设备句柄 */ rt_hwtimer_mode_t mode; /* 定时器模式 */ /* 查找定时器设备 */ hw_dev = rt_device_find(HWTIMER_DEV_NAME); if (hw_dev == RT_NULL) { rt_kprintf("hwtimer sample run failed! can't find %s device!\n", HWTIMER_DEV_NAME); return RT_ERROR; } /* 以读写方式打开设备 */ ret = rt_device_open(hw_dev, RT_DEVICE_OFLAG_RDWR); if (ret != RT_EOK) { rt_kprintf("open %s device failed!\n", HWTIMER_DEV_NAME); return ret; } /* 设置超时回调函数 */ rt_device_set_rx_indicate(hw_dev, timeout_cb); /* 设置模式为周期性定时器 */ mode = HWTIMER_MODE_PERIOD; ret = rt_device_control(hw_dev, HWTIMER_CTRL_MODE_SET, &mode); if (ret != RT_EOK) { rt_kprintf("set mode failed! ret is :%d\n", ret); return ret; } /* 设置定时器超时值为5s并启动定时器 */ timeout_s.sec = 5; /* 秒 */ timeout_s.usec = 0; /* 微秒 */ if (rt_device_write(hw_dev, 0, &timeout_s, sizeof(timeout_s)) != sizeof(timeout_s)) { rt_kprintf("set timeout value failed\n"); return RT_ERROR; } /* 延时3500ms */ rt_thread_mdelay(3500); /* 读取定时器当前值 */ rt_device_read(hw_dev, 0, &timeout_s, sizeof(timeout_s)); rt_kprintf("Read: Sec = %d, Usec = %d\n", timeout_s.sec, timeout_s.usec); return ret; ``` 调试的结果: ``` Read: Sec = 3, Usec = 499387 msh />this is hwtimer timeout callback fucntion! tick is :38289 ! this is hwtimer timeout callback fucntion! tick is :43284 ! this is hwtimer timeout callback fucntion! tick is :48279 ! this is hwtimer timeout callback fucntion! tick is :53274 ! this is hwtimer timeout callback fucntion! tick is :58269 ! ```
查看更多
3
个回答
默认排序
按发布时间排序
小小李sunny
2021-11-02
这家伙很懒,什么也没写!
rt_tick_get()获取的是当前tick值,2次tick值之差换算为时间等同于定时时间值,计算出来都是4995,4995ms ≈ 5s,结果是准确的呀。
李肯陪你玩赚嵌入式
认证专家
2021-11-02
2022年度和2023年度RT-Thread社区优秀开源布道师,COC深圳城市开发者社区主理人,专注于嵌入式物联网的架构设计
估计楼主搞混了tick值和时间值的关系, 按照你的系统搭配置,应该1tick=1ms,也就是1000个tick=1S 正确评估定时器的定时是否精确的方法: 1.在启动定时器前rt_tick_get取一下当前的tick0值; 2.每一次定时器超时回调的时候取一下tickn值; 3.分别计算出: tick1-tick0,tick2-tick1,以此类推; 4.根据1tick与1s的换算关系,对步骤3的差值进行比较; 5。得出比较结论。 如果你不像做tick与时间的换算,你可以考虑使用rt_tick_get_millisecond代替rt_tick_get。
RTT_逍遥
认证专家
2021-11-02
https://github.com/supperthomas
仔细帮你查看了一下dr_hwtimer.c里面的代码, 如果5tick是你觉得疑惑的地方,你可以追踪一下dr_hwtimer.c里面的如何把5s转换成tick的地方,并且打印出来看下,最后设置的是否是5000还是4995. 以我的经验来看,应该是在clock放大和乘积的时候,有一些地方精读的丢失。具体由于不知道你的时钟是多少,所以你可以自己找到root cause。 ``` { prescaler_value = (uint32_t)(HAL_RCC_GetPCLK1Freq() * pclk1_doubler / 10000) - 1; } tim->Init.Period = 10000 - 1; tim->Init.Prescaler = prescaler_value; tim->Init.ClockDivision = TIM_CLOCKDIVISION_DIV1; ```
撰写答案
登录
注册新账号
关注者
0
被浏览
1.4k
关于作者
吕蛋蛋
这家伙很懒,什么也没写!
提问
56
回答
14
被采纳
0
关注TA
发私信
相关问题
1
请问HWTIMER设备支持计数模式吗
2
HWTIMER 设备没有计数模式吗
3
ART-Pi开发板,新建Wifi示例工程,打开hwtimer就42个错误?
4
求助:使用HWTIMER timer13的问题
5
使用menuconfig 使能硬件定时器的驱动,使能PWM 编码器等,编译错误
6
STM32H743 的硬件定时器是不是是不是没有晚上
7
硬件定时器如何实现us,ms级定时功能
8
纳秒级的高精度定时器在RTT中的实现
9
HWTIMER设备TIM2_CONFIG函数要自己手动添加?F407ZGT6
10
【已解决】STMF103ZE定时器hwtimer 定时时间为us的时候不准确
推荐文章
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
简单两步配置RTT源码阅读环境 vsc+clangd
2
恩智浦[FRDM-MCXN947]初探 之 ADC与DAC
3
LVGL使用字库IC芯片显示中文
4
基于STM32H750和Rt-Thread的CANFD通信实现的记录(一)
5
freemodbus主机在freertos的适配,参考rtthread例程
热门标签
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
UART
WIZnet_W5500
ota在线升级
PWM
cubemx
freemodbus
flash
packages_软件包
BSP
潘多拉开发板_Pandora
定时器
ADC
GD32
flashDB
socket
中断
编译报错
Debug
SFUD
msh
rt_mq_消息队列_msg_queue
keil_MDK
ulog
MicroPython
C++_cpp
本月问答贡献
出出啊
1517
个答案
342
次被采纳
小小李sunny
1443
个答案
289
次被采纳
张世争
805
个答案
174
次被采纳
crystal266
547
个答案
161
次被采纳
whj467467222
1222
个答案
148
次被采纳
本月文章贡献
出出啊
1
篇文章
4
次点赞
小小李sunny
1
篇文章
1
次点赞
张世争
1
篇文章
1
次点赞
crystal266
2
篇文章
2
次点赞
whj467467222
2
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部