在orangepi 3 lts使用high speed timer
概述
在allwin H6的用户手册上可以发现全志H6芯片支持普通计时器和高速计时器。
普通计时器可以处理低频定时任务,其时钟源包括LOSC和OSC,前者频率为32768Hz,后者为24MHz。
高数计时器专门用于高频定时任务,其时钟源为ahb1,其时钟频率高达200MHz。
本篇主要关注高速计时器,英文全称High Speed Timer,简称hst。
HST
高速计时器最高频率可达200MHz,它有两个分频参数,一个是预分频系数(pre-scaler),另一个间隔计数(interval)。
所以hst的工作频率计算方式为:hst_clk = 200MHz / pre-sacle / interval
预分频系数有效值有1、2、4、8、16,在HS_TMR0_CTRL_REG中指定。
间隔计数长度为56bit,由HS_TMR0_INTV_LO_REG和HS_TMR0_INTV_HI_REG共同指定。
设备树
在orangepi官方提供linux4.9系统源码中,相关的设备树文件并没有hst的具体定义,所以需要手动添加hst的定义。
在设备树soc@03000000字段的包含下添加hst定义
hstimer0x03005000 {
#address-cells = <0x1>;
#size-cells = <0x0>;
compatible = "allwinner,sunxi-hst";
reg = <0x0 0x3005000 0x0 0x400>;
interrupts = <0x0 0x2E 0x4>;
clocks = <0x2E>;
status = "okay";
};
为clocks字段包含下的hstimer字段为添加phandle属性
hstimer {
#clock-cells = <0x0>;
compatible = "allwinner,periph-clock";
clock-output-names = "hstimer";
linux,phandle = <0x2E>;
phandle = <0x2E>;
};
关于hstimer0x03005000中的中断号
查看全志芯片用户手册GIC一章,可查到hst的硬件中断号。
从列表中可以看到hst的硬件中断号为78,但是在设备树中的中断号是按组划分的,所以设备树中填入的不是78。
从手册上的中断源表格中看到,前32项分别为SGI和PPI中断,所以设备树中的中断号要从32开始算,即HST在设备树中的中断号为78-32=46。
关于hstimer中的phandle
该字段的值在整个设备树文件中不能重复,而刚好0x2E是未使用值。
测试
驱动和测试代码点击此处
测试效果
测试中使用的间隔计数为1000000,预分频系数为1,故hst的工作频率为200。通过比较实际中断的次数和预期值来确认hst是否工作正常
最新文章
- 动态sql语句基本语法--Exec与Exec sp_executesql 的区别
- 怎么解决svn清理失败且路径显示乱码问题
- Titanium Studio下载地址
- Android中ListView放入PopupWindow产生问题解决
- 使用solr报错,错误信息 include(SolrClient.php): failed to open stream: No such file or directory
- ReSharper warning: Virtual member call in a constructor
- ID3算法 决策树 C++实现
- 百度下载google 浏览器安装失败
- IE与FF脚本兼容性问题
- Vim常见操作汇总
- shrio初体验(1)
- 性能测试培训:帮你定位 Linux 性能问题的 18 个命令以及工具
- Android - service and thread
- 百度鹰眼Java接口调用增删改查实例
- FreeMarker 快速入门
- python配置apache的web服务器方法(python的CGI配置)
- Beautiful Soup库
- Android之BaseAdapter的优雅实现
- FPGA设计千兆以太网MAC(3)——数据缓存及位宽转换模块设计与验证
- JS &; JQuery 动态处理select option
热门文章
- python安装过程
- Safari浏览器对SVG中的<;foreignObject>;标签支持不友好,渲染容易错位
- RocketMQ消息短暂而又精彩的一生
- 失配树学习笔记 | P5829 【模板】失配树
- GreenPlum批量授权(PG未测试)
- Java基础学习笔记-类的静态属性和静态方法--待继续补充
- 小白从零到AIoT之路(前言)
- 笔记本USB接口案例_分析-笔记本USB接口案例_实现
- C#零基础小白快速入门
- 12月20日内容总结——ajax补充知识点、多对多外键的三种创建方式、django内置序列化组件、批量操作数据、分页器推导思路与自定义分页器的使用、form组件