Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
RTC
time
rt-thread 如何输出毫秒级别的时间戳
发布于 2022-02-24 19:34:25 浏览:3276
订阅该版
[tocm] ## 配置硬件 rtc 既然要毫秒级别的时间戳,广义上的精确肯定是要有的,那么就不能使用软件模拟 `rtc` 了,使用 `STM32CubeMX` 配置硬件 `rtc` ,其他地方都不用改动,改动也不会生效,rt-thread 会重新进行配置,直接生成代码即可 ![image.png](https://oss-club.rt-thread.org/uploads/20220224/2fb2a59feff180ae03f3947d37432405.png) 生成代码之后打开目录,删除 `MDK-ARM` `Drivers` 这两个目录,rt-thread 内部集成了,如果不删除会报错的 将当前时间戳打印出来 ![image.png](https://oss-club.rt-thread.org/uploads/20220224/212438e5b5ce50a7eeeb371d1a744530.png) ![image.png](https://oss-club.rt-thread.org/uploads/20220224/b763a096a7ce6fcc9a6074256bc33205.png) 可以看出,默认的是秒时间戳 而且经查询保存时间戳的数据类型是 long,也不会支持毫秒精度的时间戳的 ```c #define _TIME_T_ long /* time() */ ``` 那么我们怎么更改代码让他输出毫秒精度的时间戳呢,那就要看时间获取的底层究竟是怎么实现的了 经调试得到下面这段代码,不难发现最终是调用 `HAL` 库实现的 ```c static time_t get_rtc_timestamp(void) { RTC_TimeTypeDef RTC_TimeStruct = {0}; RTC_DateTypeDef RTC_DateStruct = {0}; struct tm tm_new; HAL_RTC_GetTime(&RTC_Handler, &RTC_TimeStruct, RTC_FORMAT_BIN); HAL_RTC_GetDate(&RTC_Handler, &RTC_DateStruct, RTC_FORMAT_BIN); tm_new.tm_sec = RTC_TimeStruct.Seconds; tm_new.tm_min = RTC_TimeStruct.Minutes; tm_new.tm_hour = RTC_TimeStruct.Hours; tm_new.tm_mday = RTC_DateStruct.Date; tm_new.tm_mon = RTC_DateStruct.Month - 1; tm_new.tm_year = RTC_DateStruct.Year + 100; LOG_D("get rtc time."); return mktime(&tm_new); } ``` 查询 `HAL_RTC_GetTime` 函数,可以得到,其实 `HAL` 里是有小于秒的精度的,`SubSeconds` `SubSeconds = 1S / (SecondFraction + 1)` 也就是说,我们只需要设置 `SecondFraction` 的值为 999,所得到的 `SubSeconds` 就是毫秒值 ## 修改 rtc 驱动文件 drv_rtc.c 将 `RTC_Handler.Init.SynchPrediv = 0XFF;` 改为 `RTC_Handler.Init.SynchPrediv = 0X3E7;` 添加以下代码 ```c char * get_time_ms(void){ RTC_TimeTypeDef RTC_TimeStruct = {0}; RTC_DateTypeDef RTC_DateStruct = {0}; struct tm tm_new; char * time_str = NULL; rt_size_t time_str_len = 14; HAL_RTC_GetTime(&RTC_Handler, &RTC_TimeStruct, RTC_FORMAT_BIN); HAL_RTC_GetDate(&RTC_Handler, &RTC_DateStruct, RTC_FORMAT_BIN); tm_new.tm_sec = RTC_TimeStruct.Seconds; tm_new.tm_min = RTC_TimeStruct.Minutes; tm_new.tm_hour = RTC_TimeStruct.Hours; tm_new.tm_mday = RTC_DateStruct.Date; tm_new.tm_mon = RTC_DateStruct.Month - 1; tm_new.tm_year = RTC_DateStruct.Year + 100; time_t now = mktime(&tm_new); time_str = rt_malloc(time_str_len); rt_memset(time_str, 0, time_str_len); rt_snprintf(time_str, time_str_len, "%d%.3d", now, RTC_TimeStruct.SubSeconds); return time_str; } ``` ```c extern char * get_time_ms(void); void time_stamp(int argc, char **argv) { char * time_ms = get_time_ms(); rt_kprintf("time_stamp : %s\n", time_ms); } MSH_CMD_EXPORT(time_stamp,"time_stamp!") ``` 运行 可以看出这里获取的就是毫秒时间戳 ![image.png](https://oss-club.rt-thread.org/uploads/20220224/fd738863d46a3fc2b9a49d14677cef0a.png)
0
条评论
默认排序
按发布时间排序
登录
注册新账号
关于作者
zhkag
这家伙很懒,什么也没写!
文章
12
回答
482
被采纳
66
关注TA
发私信
相关文章
1
RTC驱动框架几点建议
2
求助:RTT在STM32F407上使用内置的RTC设置日期需重启生效,设置时间即时生效,有遇到同样问题的吗?
3
[新人试水] LPC1768 Nano3_9 添加RTC
4
STM32 关于RTC的问题
5
stm32f4xx-HAL BSP的RTC设置不对
6
关于STM32的RTC设置年份不正确的问题
7
RTT的RTC驱动调试
8
rtc驱动中的bkp模块起不到防止时间的重新设置
9
rtc时钟跑十几个小时后,比实际时间快几秒怎么解决
10
stm32如何断电之后开发板rtc时间继续往前跑
推荐文章
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组件
热门标签
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在线升级
freemodbus
PWM
flash
cubemx
packages_软件包
BSP
潘多拉开发板_Pandora
定时器
ADC
flashDB
GD32
socket
中断
编译报错
Debug
SFUD
rt_mq_消息队列_msg_queue
msh
keil_MDK
ulog
C++_cpp
MicroPython
本月问答贡献
踩姑娘的小蘑菇
4
个答案
1
次被采纳
红枫
4
个答案
1
次被采纳
张世争
4
个答案
1
次被采纳
Ryan_CW
4
个答案
1
次被采纳
xiaorui
1
个答案
1
次被采纳
本月文章贡献
catcatbing
3
篇文章
5
次点赞
qq1078249029
2
篇文章
2
次点赞
xnosky
2
篇文章
1
次点赞
Woshizhapuren
1
篇文章
5
次点赞
YZRD
1
篇文章
2
次点赞
回到
顶部
发布
问题
投诉
建议
回到
底部