6.11物联网RK3399项目开发实录-驱动开发之定时器的使用(wulianjishu666)

本文详细介绍了RK3399处理器的12个定时器(Timer0-11)及其SecureTimers的工作模式,包括user-definedcount和free-running,以及如何在dts文件和驱动中进行软件配置,包括寄存器操作和中断管理。
摘要由CSDN通过智能技术生成

嵌入式实战开发例程【珍贵收藏,开发必备】:

链接:https://pan.baidu.com/s/1tkDBNH9R3iAaHOG1Zj9q1Q?pwd=t41u
======================================================================

定时器使用

前言

RK3399有 12 个 Timers (timer0-timer11),有 12 个 Secure Timers(stimer0~stimer11) 和 2 个 Timers(pmutimer0~pmutimer1), 我们主要用到的是 Timers(timer0-timer11) 时钟频率为 24MHZ ,工作模式有 free-running 和 user-defined count 模式。

框架图

_images/timer_frame.jpg

工作模式

user-defined count:Timer 先载入初始值到 TIMERn_LOAD_COUNT3 和 TIMER_LOADn_COUNT2 寄存器, 当时间累加的值在寄存器 TIMERn_LOAD_COUNT1 和 TIMERn_LOAD_COUNT0 时,将不会自动载入到计数寄存器。 用户需要重新关闭计数器和然后重新设置计数器相关才能继续工作。

free-running:Timer 先载入初始值到 TIMER_LOAD_COUNT3 和 TIMER_LOAD_COUNT2 寄存器, 当时间累加的值在寄存器 TIMERn_LOAD_COUNT1 和 TIMERn_LOAD_COUNT0 时,Timer 将一直自动加载计数寄存器。

软件配置

1.在 dts 文件中定义 Timer 的相关配置 kernel/arch/arm64/boot/dts/rockchip/rk3399.dtsi

rktimer: rktimer@ff850000 {
	compatible = "rockchip,rk3399-timer";
	reg = <0x0 0xff850000 0x0 0x1000>;
	interrupts = <GIC_SPI 81 IRQ_TYPE_LEVEL_HIGH 0>;
	clocks = <&cru PCLK_TIMER0>, <&cru SCLK_TIMER00>;
	clock-names = "pclk", "timer";
};

其中定义的 Timer0 的寄存器和中断号和时钟等。

其他 Timer 对应的中断号可看如下图片:

_images/timer_interrupt.jpg

2.对应的驱动文件 Kernel/drivers/clocksource/rockchip_timer.c

对应寄存器和使用

寄存器如下图片:

_images/timer_register.jpg

使用 io 命令方式查看对应寄存器:

root@host_name:/ # io -4 0xff85001c  //查看当前控制寄存器的状态
ff85001c:  00000007

root@host_name:/ # io -4 0xff850000  //查看寄存器时时的值
ff850000:  0001639f

控制对应寄存器:

root@host_name:/ # io -4 -w 0xff85001c 0x06  //关闭时间计数功能
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值