Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Prry/rtt-rx8900
rx8900 driver for rt-thread
https://github.com/Prry/rtt-rx8900
i2c rt-thread rtc rx8900
Last synced: 16 days ago
JSON representation
rx8900 driver for rt-thread
- Host: GitHub
- URL: https://github.com/Prry/rtt-rx8900
- Owner: Prry
- License: apache-2.0
- Created: 2020-04-10T14:16:27.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2024-10-16T15:57:01.000Z (3 months ago)
- Last Synced: 2024-10-18T15:59:50.183Z (3 months ago)
- Topics: i2c, rt-thread, rtc, rx8900
- Language: C
- Homepage:
- Size: 2.44 MB
- Stars: 5
- Watchers: 2
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-rt-thread - rx8900 - Extern RTC driver for rx8900. (Packages / Peripherals)
- awesome-rt-thread - rx8900 - Extern RTC driver for rx8900. (Packages / Peripherals)
README
# 高精度RTC rx8900 驱动软件包
## 1 介绍
rx8900 软件包是针对RT-Thread驱动框架实现的实时时钟驱动,遵循RT-Thread RTC框架,可以从芯片内置RTC无缝切换使用外置高精度rx8900 RTC。rx8900是爱普生公司一款i2c接口的高精度RTC芯片,集成32768Hz晶振和温度传感器,并能根据环境温度调整频率,具有供电范围灵活、待机电流低、走时精度高等优点。
### 1.1 支持功能
* 实时时钟
* 闹钟
* 片内温度读取### 1.2 目录结构
| 名称 | 说明 |
| -------- | ---------- |
| docs | 文档目录 |
| inc |头文件目录 |
| src | 源代码目录 |
|LICENSE| 许可证文件 |
|SConscript|RT-Thread默认构建脚本|### 1.3 许可证
rx8900 软件包遵循 Apache license v2.0 许可,详见 `LICENSE` 文件。
### 1.4 依赖
- RT-Thread 3.0+
- RT-Thread I2C设备驱动框架
- RT-Thread RTC设备驱动框架
## 2 获取 rx8900 软件包
使用 rx8900 package 需要在 RT-Thread 的包管理器中选择它,具体路径如下:
```
RT-Thread online packages --->
peripheral libraries and drivers --->
[*] extren rtc drivers --->
[*] ds3231:Extern RTC drivers fo rx8900
Version (latest) --->
```然后让 RT-Thread 的包管理器自动更新,或者使用 `pkgs --update` 命令更新包到 BSP 中。
## 3 使用 rx8900 软件包
### 3.1 初始化
首先需初始化rx8900 驱动,可以手动在初始化线程合适的地方调用rt_hw_rx8900 _init()
初始化,也可以直接使用INIT_DEVICE_EXPORT
通过RT-Thread的自动初始化机制来初始化注册。初始化成功后,会注册名称为“rtc”的驱动设备。```c
INIT_DEVICE_EXPORT(rt_hw_rx8900_init); /* 通过RTT的自动初始化机制初始化rx8900 */
```> 注:
>
> 如果开启了芯片内部RTC,需先禁止内部RTC### 3.2 使用方式
对于时间和闹钟的访问,使用RT-Thread标准RTC和闹钟接口访问。片内温度读取,则由软件包提供一个函数接口。
* **获取当前时间**
```
time_t time(time_t *t)
time_t now;
now = time(RT_NULL);
```* **设置时间**
```
#define RT_DEVICE_CTRL_RTC_SET_TIME 0x11 /**< set time */
rt_err_t rt_device_control(rt_device_t dev, int cmd, void *arg);
```* **获取闹钟时间**
```
#define RT_DEVICE_CTRL_RTC_GET_ALARM 0x12 /**< get alarm */
rt_err_t rt_device_control(rt_device_t dev, int cmd, void *arg);
```* **设置闹钟时间**
```
#define RT_DEVICE_CTRL_RTC_SET_ALARM 0x13 /**< set alarm */
rt_err_t rt_device_control(rt_device_t dev, int cmd, void *arg);
```> 注:
>
> 详细用法可以参考“/components/drivers/rtc.c”和“/components/drivers/alarm.c”源码。* **提供一个获取片内温度接口**
```
float rx8900 _get_temperature(void);
```### 3.3 msh/finsh测试
* msh获取时间
```
msh >date
Sat Jan 1 00:00:04 2000
```* msh设置时间
```
msh date 2020 04 10 17 41 10
msh >date
Fri Apr 10 17:41:15 2020
```* finsh获取时间
```
finsh >list_date()
Fri Apr 10 17:41:49 2020
```* finsh设置时间
```
finsh >set_date(2020,5,1)
0, 0x00000000
finsh >set_time(12,0,0)
0, 0x00000000
finsh >list_date()
Fri May 1 12:00:04 2020
```* msh打印温度
```
msh >list_rx89_temp
rx8900 temperature: [27.5C]
```* finsh打印温度
```
finsh >list_rx89_temp()
rx8900 temperature: [27.5C]
```
## 4 注意事项
使用RT-Thread的RTC框架,RTC设备注册名称为“rtc”,注意需先屏蔽内置芯片RTC驱动。
## 5 联系方式
- 维护:[Acuity](https://github.com/Prry)
- 主页: