xref: /nrf52832-nimble/rt-thread/components/drivers/rtc/README.md (revision 104654410c56c573564690304ae786df310c91fc)
1*10465441SEvalZero# RT-Thread RTC 设备
2*10465441SEvalZero
3*10465441SEvalZero## 1、介绍
4*10465441SEvalZero
5*10465441SEvalZeroRT-Thread 的 RTC (实时时钟)设备为操作系统的时间系统提供了基础服务。面对越来越多的 IoT 场景,RTC 已经成为产品的标配,甚至在诸如 SSL 的安全传输过程中,RTC 已经成为不可或缺的部分。
6*10465441SEvalZero
7*10465441SEvalZero## 2、使用
8*10465441SEvalZero
9*10465441SEvalZero应用层对于 RTC 设备一般不存在直接调用的 API ,如果使用到 C 标准库中的时间 API (目前主要是获取当前时间的  `time_t time(time_t *t)`),则会间接通过设备的 control 接口完成交互。
10*10465441SEvalZero
11*10465441SEvalZero> 注意:目前系统内只允许存在一个 RTC 设备,且名称为 `"rtc"` 。
12*10465441SEvalZero
13*10465441SEvalZero### 2.1  设置日期
14*10465441SEvalZero
15*10465441SEvalZero```C
16*10465441SEvalZerort_err_t set_date(rt_uint32_t year, rt_uint32_t month, rt_uint32_t day)
17*10465441SEvalZero```
18*10465441SEvalZero
19*10465441SEvalZero|参数                                    |描述|
20*10465441SEvalZero|:-----                                  |:----|
21*10465441SEvalZero|year                                    |待设置生效的年份|
22*10465441SEvalZero|month                                   |待设置生效的月份|
23*10465441SEvalZero|day                                     |待设置生效的日|
24*10465441SEvalZero
25*10465441SEvalZero### 2.2 设置时间
26*10465441SEvalZero
27*10465441SEvalZero```C
28*10465441SEvalZerort_err_t set_time(rt_uint32_t hour, rt_uint32_t minute, rt_uint32_t second)
29*10465441SEvalZero```
30*10465441SEvalZero
31*10465441SEvalZero|参数                                    |描述|
32*10465441SEvalZero|:-----                                  |:----|
33*10465441SEvalZero|hour                                    |待设置生效的时|
34*10465441SEvalZero|minute                                  |待设置生效的分|
35*10465441SEvalZero|second                                  |待设置生效的秒|
36*10465441SEvalZero
37*10465441SEvalZero### 2.3 使用 Finsh/MSH 命令 查看/设置 日期和时间
38*10465441SEvalZero
39*10465441SEvalZero#### 2.3.1 查看日期和时间
40*10465441SEvalZero
41*10465441SEvalZero输入 `date` 即可,大致效果如下:
42*10465441SEvalZero
43*10465441SEvalZero```
44*10465441SEvalZeromsh />date
45*10465441SEvalZeroFri Feb 16 01:11:56 2018
46*10465441SEvalZeromsh />
47*10465441SEvalZero```
48*10465441SEvalZero
49*10465441SEvalZero#### 2.3.2 设置日期和时间
50*10465441SEvalZero
51*10465441SEvalZero同样使用 `date` 命令,在命令后面再依次输入 `年` `月` `日` `时` `分` `秒` (中间空格隔开, 24H 制),大致效果如下:
52*10465441SEvalZero
53*10465441SEvalZero```
54*10465441SEvalZeromsh />date 2018 02 16 01 15 30    # 设置当前时间为 2018-02-16 01:15:30
55*10465441SEvalZeromsh />
56*10465441SEvalZero```
57*10465441SEvalZero
58*10465441SEvalZero### 2.4 启用 NTP 时间自动同步
59*10465441SEvalZero
60*10465441SEvalZero如果 RT-Thread 已接入互联网,可启用 NTP 时间自动同步功能,定期同步本地时间。
61*10465441SEvalZero
62*10465441SEvalZero在 menuconfig 中启用 `RTC_SYNC_USING_NTP` 配置。启用该功能后,会自动开启 [netutils package](https://github.com/RT-Thread-packages/netutils) 的 NTP 功能。同时务必确保 RT-Thread 网络访问正常。
63*10465441SEvalZero
64*10465441SEvalZero启用该配置后,还有两个配置是用户可选配置:
65*10465441SEvalZero
66*10465441SEvalZero- `RTC_NTP_FIRST_SYNC_DELAY`: 首次执行 NTP 时间同步的延时。延时的目的在于,给网络连接预留一定的时间,尽量提高第一次执行 NTP 时间同步时的成功率。默认时间为 30S;
67*10465441SEvalZero- `RTC_NTP_SYNC_PERIOD`: NTP 自动同步周期,单位为秒,默认一小时(即 3600S)同步一次。
68*10465441SEvalZero
69*10465441SEvalZero> 注意:如果没有使用组件自动初始化功能,则需手动调用 `int rt_rtc_ntp_sync_init(void)` ,完成该功能初始化。
70*10465441SEvalZero
71*10465441SEvalZero### 2.5 启用 Soft RTC (软件模拟 RTC)
72*10465441SEvalZero
73*10465441SEvalZero这个模式非常适用于对时间精度要求不高,没有硬件 RTC 的产品。
74*10465441SEvalZero
75*10465441SEvalZero#### 2.5.1 使用方法
76*10465441SEvalZero
77*10465441SEvalZero在 menuconfig 中启用 `RT_USING_SOFT_RTC` 配置。
78*10465441SEvalZero
79*10465441SEvalZero> 注意:如果没有使用组件自动初始化功能,则需手动调用 `int rt_soft_rtc_init(void)` ,完成该功能初始化。
80*10465441SEvalZero
81