Linux驱动|rtc-hym8563移植笔记
本文基于瑞芯微rk3568平台,关于该平台快速入手操作,大家可以参考以下文章:
0、什么是rtc-hym8563?
RTC:实时时钟的缩写是(Real_Time Clock)。RTC 是集成电路,通常称为时钟芯片。
1)产品概述
HYM8563是一款低功耗CMOS实时时钟/日历芯片,由武汉昊昱公司设计生产。

它提供一个可编程的时钟输出,一个中断输出和一个掉电检测器,所有的地址和数据都通过I2C总线接口串行传递。
最大总线速度为400Kbits/s,每次读写数据后,内嵌的字地址寄存器会自动递增。
2)产品特点
● 可计时基于32.768kHz晶体的秒,分,小时,星期,天,月和年
● 带有世纪标志
● 宽工作电压范围:1.8~5.5V
● 低休眠电流:典型值为0.25μA(VDD=3.0V,TA=25℃)
● 400kHz的I2C总线接口(VDD=1.8~5.5V时)
● 可编程时钟输出频率为:32.768kHz,1024Hz,
32Hz,1H
● 报警和定时器
● 掉电检测器
● 内部集成振荡电容
● 片内电源复位功能
● I2C总线从地址:读,0A3H;写,0A2H
● 漏极开路中断引脚
● 封装形式:DIP8和SOP8
一、 移植基于平台
soc : rk3568
board: EVB1-DDR4-V10
软 件:Android 11
Linux:4.19.232
二、移植步骤
1)电路图


由以上两个图可得硬件信息如下:
- RTC连接到I2C的通道5
- CLKOUT引脚对应RTCIC_32KOUT
- INT连接的是RTCIC_INT_L_GPIO0_D3,即GPIO0的bit3
- 从设备地址为0x51(0101 0001), read:1010 0011 write: 1010 0010
2)设备树
内核中已有关于hym8563的设备树节点信息说明:
Documentation/devicetree/bindings/rtc/haoyu,hym8563.txt

同时在瑞芯微提供的个厂家sdk中,已经由类似的设备树节点实例,所以我们也可以直接参考该内容:


下面是pinctrl关于rtc引脚的说明:

结合该说明文档,根据硬件信息,填充设备树信息到文件
kernel\arch\arm64\boot\dts\rockchip\rk3568-evb.dtsi
填加信息如下:
1393 &i2c5 {
1394 status = "okay";
1395 hym8563: hym8563@51 {
1396 compatible = "haoyu,hym8563";
1397 reg = <0x51>;
1398
1399 pinctrl-names = "default";
1400 pinctrl-0 = <&rtc_int>;
1401
1402 interrupt-parent = <&gpio0>;
1403 interrupts = <RK_PD3 IRQ_TYPE_LEVEL_LOW>;
1404 };
1468 &pinctrl {
1469 rtc {
1470 rtc_int: rtc-int {
1471 rockchip,pins = <0 RK_PD3 RK_FUNC_GPIO &pcfg_pull_up>;
1472 };
1473 };
可以看到该节点内容和硬件电路图是对应起来的。
3)驱动
hym8563驱动程序位于
drivers/rtc/rtc-hym8563.c
打开该驱动
arch/arm64/configs/rockchip_defconfig

4)打开hctosys驱动权限
为了支持硬件的时钟(RTC)能与系统时间同步,内核需要对应驱动支持:
4434 CONFIG_RTC_HCTOSYS=y 允许RTC时间设置到系统时间
4435 CONFIG_RTC_HCTOSYS_DEVICE="rtc0" 默认同步时间的RTC设备
4436 CONFIG_RTC_SYSTOHC=y 允许系统时间设置到RTC
4437 CONFIG_RTC_SYSTOHC_DEVICE="rtc0" 默认同步时间的RTC设备
修改完毕,重新编译内核和设备树,烧录内核即可
三、测试rtc
测试1)测试rtc驱动
在UI界面上设置->系统->日期和时间->时间 可以读取和设置新的时间,

设置完毕使用hwclock查看时间
如果时间一致,可以设置说明rtc驱动起了作用,

【也可以在驱动的read函数中,增加log,更加直观】
.read_time = hym8563_rtc_read_time,
.set_time = hym8563_rtc_set_time,
测试2)测试rtc关机后时间同步
- 设置当前时间和自己手机同步
- 拔掉电源,等待几分钟开机
- 确认板子时间是否则和当前手机时间一致
四、其他查看rtc方法
同时在以下目录中也可以直接读取驱动相关的信息。
rk3568_r:/sys/class/rtc # ls
rtc0
rk3568_r:/sys/class/rtc # cd rtc0
rk3568_r:/sys/class/rtc/rtc0 # cd ..
rk3568_r:/sys/class/rtc # ls -l
total 0
lrwxrwxrwx 1 root root 0 2021-01-01 12:00 rtc0 -> ../../devices/platform/fe5e0000.i2c/i2c-5/5-0051/rtc/rtc0
rk3568_r:/sys/class/rtc # cd rtc0
rk3568_r:/sys/class/rtc/rtc0 # ls
date device max_user_freq power subsystem uevent wakeup8
dev hctosys name since_epoch time wakealarm
rk3568_r:/sys/class/rtc/rtc0 # cat name
rtc-hym8563 5-0051
rk3568_r:/sys/class/rtc/rtc0 # cat time
03:04:57
rk3568_r:/sys/class/rtc/rtc0 # cat hctosys
1
五、遇到的问题
问题1)/sys/class/rtc下有多个rtc设备,需要去掉rtc-rk808驱动
共板里除了hym8563,在pmic中还有内部的rtc-rk808,我们需要把该rtc驱动去掉,否则/sys/class/rtc下会有2个rtc设备
在以下文件
arch/arm64/configs/rockchip_defconfig
808 CONFIG_RTC_DRV_RK808=n
该驱动位于
drivers/rtc/rtc-rk808.c
问题2)ui界面设置的时间无法同步到hym8563中
打开开机后的logcat,发现有如下信息
01-01 12:00:14.256 439 439 E AlarmManagerService: failed to open /sys/class/rtc/rtc0/hctosys: Permission denied
01-01 12:00:14.256 439 439 W AlarmManagerService: no wall clock RTC found
01-01 12:00:14.260 439 439 D AlarmManagerService: Kernel timezone updated to 0 minutes west of GMT
01-01 12:00:14.261 439 439 D AlarmManagerService: Setting time of day to sec=1663584459
09-19 10:47:39.000 439 439 W AlarmManagerService: Unable to set rtc to 1663584459: No such device
该log位于以下文件:
frameworks\base\services\core\jni\com_android_server_AlarmManagerService.cpp
该log位于263行:
257 static bool rtc_is_hctosys(unsigned int rtc_id)
258 {
259 android::String8 hctosys_path = String8::format("%s/rtc%u/hctosys",
260 rtc_sysfs, rtc_id);
261 FILE *file = fopen(hctosys_path.string(), "re");
262 if (!file) {
263 ALOGE("failed to open %s: %s", hctosys_path.string(), strerror(errno));
264 return false;
265 }
266
267 unsigned int hctosys;
268 bool ret = false;
269 int err = fscanf(file, "%u", &hctosys);
270 if (err == EOF)
271 ALOGE("failed to read from %s: %s", hctosys_path.string(),
272 strerror(errno));
273 else if (err == 0)
274 ALOGE("%s did not have expected contents", hctosys_path.string());
275 else
276 ret = hctosys;
277
278 fclose(file);
279 return ret;
280 }
由程序可知,没有权限打开文件
/sys/class/rtc/rtc0/hctosys
增加该文件读取权限,打开文件
device/rockchip/common/sepolicy/vendor/genfs_contexts
增加以下内容:
28 # rk356x RTC
29 genfscon sysfs /devices/platform/fe5e0000.i2c/i2c-5/5-0051/rtc/rtc0/hctosys u:object_r:sysfs_hctosys:s0
重新编译安卓即可。
注意
/sys/class/rtc/rtc0/hctosys 其实对应的文件位置是/sys/devices/platform/fe5e0000.i2c/i2c-5/5-0051/rtc/rtc0/hctosys
rk3568_r:/sys/class/rtc # ls -l
total 0
lrwxrwxrwx 1 root root 0 2021-01-01 12:00 rtc0 -> ../../devices/platform/fe5e0000.i2c/i2c-5/5-0051/rtc/rtc0
问题3)没有纽扣电池,需要自己飞线,接稳压电源
如下图,注意正负极,电压设置为3v即可

后续还会继续编写Linux内核的rtc 时间子系统的文章,敬请关注!
六、欢迎交流
一口君建立了瑞芯微的技术交流群,
大家工作中用到瑞芯微系列soc的,可以一起交流,
加群后台留言即可。
加我好友yikoupeng
Linux驱动|rtc-hym8563移植笔记的更多相关文章
- 第一章 Andorid系统移植与驱动开发概述 - 读书笔记
Android驱动月考1 第一章 Andorid系统移植与驱动开发概述 - 读书笔记 1.Android系统的架构: (1)Linux内核,Android是基于Linux内核的操作系统,并且开源,所以 ...
- linux 驱动学习笔记01--Linux 内核的编译
由于用的学习材料是<linux设备驱动开发详解(第二版)>,所以linux驱动学习笔记大部分文字描述来自于这本书,学习笔记系列用于自己学习理解的一种查阅和复习方式. #make confi ...
- 第一章Android系统移植与驱动开发概述--读书笔记
以前,初步学习过嵌入式Linux驱动开发的基础课程,对于驱动开发可以说是有了一点点微末的基础吧.首先我们要对Android嵌入式系统有一个初步的认识,Android系统发展到今天已经具备了完善的架构. ...
- I.MX6 SHT20 Linux 驱动移植
/*********************************************************************** * I.MX6 SHT20 Linux 驱动移植 * ...
- Linux开源模块迁移概述暨交叉编译跨平台移植总结--从《嵌入式Linux驱动模板简洁和工程实践》
本文摘录<嵌入式Linux驱动模板简洁和工程实践>一本书"开发和调试技术". Linux强大的是,有那么多的开源项目可以使用.通常非常需要可以通过寻找相关的源模块被定义 ...
- Davinci DM6446开发攻略——LINUX GPIO驱动源码移植
一. DM6446 GPIO的介绍 说到LINUX 驱动移植,没有移植过的朋友,或刚刚进入LINUX领域的朋友,最好去看看<LINUX 设备驱动程序>第三 ...
- 嵌入式Linux驱动笔记(十八)------浅析V4L2框架之ioctl【转】
转自:https://blog.csdn.net/Guet_Kite/article/details/78574781 权声明:本文为 风筝 博主原创文章,未经博主允许不得转载!!!!!!谢谢合作 h ...
- linux驱动基础系列--linux rtc子系统
前言 linux驱动子系统太多了,连时钟也搞了个子系统,这导致一般的时钟芯片的驱动也会涉及到至少2个子系统,一个是时钟芯片接口子系统(比如I2c接口的时钟芯片),一个是内核给所有时钟芯片提供的rtc子 ...
- linux驱动移植
1.1 开发前准备 1.1.1 Linux 驱动(面向对象) 1).Linux 驱动框架 思想:写驱动的时候,只提供操作硬件设备的函数接口 文件存放磁盘: open ,read ,write ,clo ...
- Linux驱动开发学习笔记(1):LINUX驱动版本的hello world
1.关于目录 /lib/modules/2.6.9-42.ELsmp/build/ 这个是内核源码所在的目录 一般使用这样的命令进入这个目录:cd /lib/modules/$(una ...
随机推荐
- Css实现浏览滚动条效果
Css实现浏览滚动条效果 前言 也是有大半个月没有更新文章了,大部分时间都在玩,然后就是入职的事.今天就更新一个小知识,刷抖音的时候看到的,感觉还不错. 属性介绍 关键属性animation-time ...
- Linux内核驱动:cdev、misc以及device三者之间的联系和区别
Linux内核驱动:cdev.misc以及device三者之间的联系和区别 背景 我想在cdev中使用dev_err等log打印函数,但是跟踪了一下cdev中的原型,发现并不是我想要的. 常见的驱动是 ...
- arm 移植 lighttpd + CGI 配置
--- title: arm 移植 lighttpd + CGI 配置 EntryName: porting-lighttpd-on-arm-and-make-cgi-config date: 202 ...
- 一个JVM参数,服务超时率降了四分之三
先说结论:通过优化Xms,改为和Xmx一致,使系统的超时率降了四分之三 1. 背景 一个同事说他负责的服务在一次上线之后超时率增加了一倍 2. 分析 2.1 机器的监控 首先找了一台机器,看了监控 上 ...
- Java报表开发工具总结
Java报表工具,首先可以分成两大类:纯Java报表工具,和支持Java的报表工具. 支持Java的报表工具 支持Java的报表工具.其实就是非Java的报表工具,但是可以在Java程序中调用,这样的 ...
- JSON 的了解?
1., JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式.(为了和其他语言进行交互)2. 数据格式简单, 易于读写, 占用带宽小{'age':'12', ' ...
- Golang 切片作为函数参数传递的陷阱与解答
作者:林冠宏 / 指尖下的幽灵.转载者,请: 务必标明出处. GitHub : https://github.com/af913337456/ 出版的书籍: <1.0-区块链DApp开发实战&g ...
- zookeeper的znode节点过多无法通过zkCli.sh移除节点
背景描述:zookeeper的一个目录下的znode节点过多,导致在执行ls 和rmr命令的时候,直接终止会话退出,无法递归删除下面的子节点,具体情况如下(生产环境的zookeeper是clickho ...
- redis雪崩
每个key(即数据)如果设置了失效时间的话,如果大量key同时过期的时候,或者说因为某种原因redis中的数据突然大批量丢失,这些key又大量地去请求这些key时,因为redis里面没有这些数据,就会 ...
- 可视化—gojs 超多超实用经验分享(三)
目录 32.go.Palette 一排放两个 33.go.Palette 基本用法 34.创建自己指向自己的连线 35.设置不同的 groupTemplate 和 linkTemplate 36.监听 ...