Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
RTC
【FRDM-MCXA156测评】- RTC模块
发布于 2025-02-23 23:00:32 浏览:16
订阅该版
[tocm] # 前言 之前朋友向我推送此板卡测评信息时,发现驱动列表中有好几个没有适配驱动的,首当其冲的便是rtc模块未适配,恰好最近也把rtt驱动框架层代码都梳理了一遍,整理出了一份适配驱动时的参考模板,便顺势申请了测评RTC模块。 在获知申请通过后,第一时间跑到nxp官网去搜索资料,但搜索了几天,没找到任何提到mcxa156支持硬件rtc的资料,虽然后来在群里有群友提到可以用低功耗定时器作为RTC时钟源来适配硬件RTC框架,但个人感觉毕竟不是真正的RTC,无法做到断电的时间计时功能,还是觉得使用软件RTC更加合适些。原因为: 1. 软件RTC基于rt_systick_get()接口,而此接口的基准时钟为systick,本身就可以保证时间的精度足够高。 2. 唯一不足的是,软件定时器闹钟功能使用的是基于线程的软件定时器,在线程优先级不高的情况下,可能会出现ms级别的误差,但个人认为此误差在大部分场景下对用户无感,不算什么大问题。 3. 低功耗定时器(LPTMR)毕竟属于定时器,虽然能够做到1s级别的滴答,但是无法实现硬件RTC最关键的断电计时功能,与其强行将该模块适配成RTC,倒不如直接将其与硬件定时器适配。 # 配置过程 ## 软件I2C使能  选择完毕后按Q键并选择Y保存退出。 ## 生成工程 在env环境下输入scons --target=mdk5后按回车生成新工程。  ## 代码修改 在main.c中添加以下代码,以下代码的逻辑为:获取当前时间,并以当前时间的下一秒为闹铃开始时间启动闹钟,在闹钟中循环打印最新的时间节点。之所以这么操作,主要是考虑到这种操作既测试了闹钟功能,也能通过闹钟和直接获取当前时间接口获取的时间做对比,反向验证RTC计时功能和检验闹钟功能的误差。 ```c void user_alarm_callback(rt_alarm_t alarm, time_t timestamp) { time_t now = (time_t)0; struct timeval tv = { 0 }; gettimeofday(&tv, RT_NULL); now = tv.tv_sec; rt_kprintf("local time: %.*s", 25U, ctime(&now)); } void alarm_sample(void) { rt_device_t dev = rt_device_find("rtc"); struct rt_alarm_setup setup; struct rt_alarm * alarm = RT_NULL; static time_t now; struct tm p_tm; if (alarm != RT_NULL) return; now = time(NULL) + 1; gmtime_r(&now,&p_tm); setup.flag = RT_ALARM_SECOND; setup.wktime.tm_year = p_tm.tm_year; setup.wktime.tm_mon = p_tm.tm_mon; setup.wktime.tm_mday = p_tm.tm_mday; setup.wktime.tm_wday = p_tm.tm_wday; setup.wktime.tm_hour = p_tm.tm_hour; setup.wktime.tm_min = p_tm.tm_min; setup.wktime.tm_sec = p_tm.tm_sec; alarm = rt_alarm_create(user_alarm_callback, &setup); if(RT_NULL != alarm) { rt_alarm_start(alarm); } } MSH_CMD_EXPORT(alarm_sample,alarm sample); ``` ## 编译运行 双击打开生成的project.uvprojx后点击rebuild按钮,编译固件后点击Load图标烧录至板卡中,之后短按板卡上的Reset按钮重启复位板卡。 ## 运行结果 ```c \ | / - RT - Thread Operating System / | \ 5.2.0 build Feb 23 2025 22:06:49 2006 - 2024 Copyright by RT-Thread team using armclang, version: 6210000 MCXA156 HelloWorld msh > msh > msh > msh >alr msh >alar alarm_sample msh >alarm_sample msh >local time: Mon Jan 1 08:00:11 2018 local time: Mon Jan 1 08:00:12 2018 local time: Mon Jan 1 08:00:13 2018 local time: Mon Jan 1 08:00:14 2018 local time: Mon Jan 1 08:00:15 2018 local time: Mon Jan 1 08:00:16 2018 local time: Mon Jan 1 08:00:17 2018 local time: Mon Jan 1 08:00:18 2018 local time: Mon Jan 1 08:00:19 2018 local time: Mon Jan 1 08:00:20 2018 local time: Mon Jan 1 08:00:21 2018 local time: Mon Jan 1 08:00:22 2018 local time: Mon Jan 1 08:00:23 2018 local time: Mon Jan 1 08:00:24 2018 local time: Mon Jan 1 08:00:25 2018 local time: Mon Jan 1 08:00:26 2018 local time: Mon Jan 1 08:00:27 2018 local time: Mon Jan 1 08:00:28 2018 local time: Mon Jan 1 08:00:29 2018 local time: Mon Jan 1 08:00:30 2018 local time: Mon Jan 1 08:00:31 2018 local time: Mon Jan 1 08:00:32 2018 local time: Mon Jan 1 08:00:33 2018 local time: Mon Jan 1 08:00:34 2018 local time: Mon Jan 1 08:00:35 2018 local time: Mon Jan 1 08:00:36 2018 local time: Mon Jan 1 08:00:37 2018 local time: Mon Jan 1 08:00:38 2018 local time: Mon Jan 1 08:00:39 2018 local time: Mon Jan 1 08:00:40 2018 local time: Mon Jan 1 08:00:41 2018 local time: Mon Jan 1 08:00:42 2018 local time: Mon Jan 1 08:00:43 2018 local time: Mon Jan 1 08:00:44 2018 local time: Mon Jan 1 08:00:45 2018 local time: Mon Jan 1 08:00:46 2018 local time: Mon Jan 1 08:00:47 2018 local time: Mon Jan 1 08:00:48 2018 local time: Mon Jan 1 08:00:49 2018 local time: Mon Jan 1 08:00:50 2018 local time: Mon Jan 1 08:00:51 2018 local time: Mon Jan 1 08:00:52 2018 local time: Mon Jan 1 08:00:53 2018 local time: Mon Jan 1 08:00:54 2018 local time: Mon Jan 1 08:00:55 2018 local time: Mon Jan 1 08:00:56 2018 local time: Mon Jan 1 08:00:57 2018 local time: Mon Jan 1 08:00:58 2018 local time: Mon Jan 1 08:00:59 2018 local time: Mon Jan 1 08:01:00 2018 ``` 从结果上看,alarm功能已经启用,且通过后续打印看,每次读到的时间都和前一个时间差1s,不存在一样或者超过1s的情况,说明RTC最基础的计时功能已经正常,且软件定时器线程的优先级能够满足闹钟功能的使用。 # 总结 虽然这次很意外选中了硬件不支持的RTC功能,没法从0开始适配硬件RTC,但是在使用软件RTC的过程中,对之前软件RTC的错误理解进行了纠正(以前认为软件RTC需要支持RT_DEVICE_CTRL_RTC_GET_TIME和RT_DEVICE_CTRL_RTC_SET_TIME命令的设备才能正常工作,原因为看代码工具未将RT_USING_SYSTEM_WORKQUEUE包含部分灰掉,导致理解错误),加强了对软件RTC方面逻辑的理解。 后续计划,按照群友思路使用低功耗定时器适配硬件RTC框架,实现类似于软件RTC的功能,但此代码仅存放至个人github上rt-thread仓库下的mcxa156分支中,不主动合并至主线中,以免其他人以为支持硬件RTC而踩雷。
0
条评论
默认排序
按发布时间排序
登录
注册新账号
关于作者
oxlm
这家伙很懒,什么也没写!
文章
5
回答
105
被采纳
8
关注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
DMA
USB
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
rt-smart
FAL
I2C_IIC
UART
ESP8266
cubemx
WIZnet_W5500
ota在线升级
PWM
BSP
flash
freemodbus
packages_软件包
潘多拉开发板_Pandora
定时器
ADC
GD32
flashDB
socket
编译报错
中断
Debug
rt_mq_消息队列_msg_queue
keil_MDK
ulog
SFUD
msh
C++_cpp
MicroPython
本月问答贡献
RTT_逍遥
10
个答案
3
次被采纳
xiaorui
3
个答案
2
次被采纳
winfeng
2
个答案
2
次被采纳
三世执戟
8
个答案
1
次被采纳
KunYi
8
个答案
1
次被采纳
本月文章贡献
catcatbing
3
篇文章
5
次点赞
lizimu
2
篇文章
8
次点赞
swet123
1
篇文章
4
次点赞
Days
1
篇文章
4
次点赞
YZRD
1
篇文章
2
次点赞
回到
顶部
发布
问题
投诉
建议
回到
底部