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 ...
随机推荐
- ssh_exchange_identification: Connection closed by remote host 错误解决方案
问题 今天登陆服务器时候,ssh 后返回 ssh_exchange_identification: Connection closed by remote host 错误,重试了几次,会有一定概率失败 ...
- ARC 170_A 题解
AT_arc170_a [ARC170A] Yet Another AB Problem 题解 这道题做了我七天 (同时也是我第一到通过的 ARC 题) 太酷了 其实还是比较好理解的 原题题干 原题题 ...
- hive第三课:Hive函数学习
Hive函数学习 目录 Hive函数学习 SQL练习 Hive 常用函数 关系运算 数值计算 条件函数(主要使用场景是数据清洗的过程中使用,有些构建表的过程也是需要的) 日期函数重点!!! 字符串函数 ...
- 总结:软件开发的3个方向 与 嵌入式Linux学习路线(驱动方向)
--- title: 嵌入式Linux学习路线图(驱动方向) date: 2020-05-09 07:17:58 categories: tags: - embeded - summary - arm ...
- 题解:洛谷 P1137 旅行计划
标签:图论,拓扑,dp 题意 给定一张 \(n\) 个点 \(m\) 条边的 DAG,对于每个 \(i\),求以它为终点最多经过多少个点? 思路 由于是 DAG,求的是终点 \(i\) 经过的所有点, ...
- 是什么导致了客户端TCP连不上服务器?
这几年做了很多基于 GGTalk开源即时通讯系统 的定制开发项目,经常会碰到如下两个问题,分享出来,应该对大家会有所帮助: (1)定制开发完成后,在给客户部署GGTalk即时通讯服务端到正式的服务 ...
- Vue 怎么用 vm.$set() 解决对象新增属性不能响应的问题 ?
受现代 JavaScript 的限制 ,Vue 无法检测到对象属性的添加或删除.由于 Vue 会在初始化实例时对属性执行 getter/setter 转化,所以属性必须在 data 对象上存在才能让 ...
- Solo 开发者周刊 (第6期):仅需一个动作,秒变时间管理大师?
这里会整合 Solo 社区每周推广内容.产品模块或活动投稿,每周五发布.在这期周刊中,我们将深入探讨开源软件产品的开发旅程,分享来自一线独立开发者的经验和见解.本杂志开源,欢迎投稿. 产品推荐 1. ...
- 零代码教你安装部署Stable Diffusion 3,一键生成高质量图像
本文分享自华为云社区<重磅![支持中文]stable-diffusion-3安装部署教程-SD3 来了>,作者:码上开花_Lancer. 正如承诺的那样,Stability AI在6月12 ...
- webpack4.15.1 学习笔记(十) — 常见 loader 使用
目录 style -loader <= css-loader <= less-loader postcss-loader file-loader url-loader html-withi ...