博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
arm9时钟及定时器
阅读量:5924 次
发布时间:2019-06-19

本文共 1599 字,大约阅读时间需要 5 分钟。

hot3.png

首先看下各个模块与时钟总线的关系:

142404_XjUl_1256737.png

芯片刚开始上电时, 运行的时钟就等于晶振的时钟Fin, 通过设置MPLL和UPLL可以提升运行频率.

144025_923Z_1256737.png

MPLL计算方法:

144616_BnH4_1256737.png

例: Fout = (2 * (MDIV + 8) * Fin) / ((PDIV + 2) * (2^SDIV))

Fout = 200MHz = (2 * (92 + 8) * 12) / (1 + 2) * (2^2)

MDIV = 92

PDIV = 1 

SDIV = 2

#define S3C2440_MPLL_200MHZ     ((0x5c << 12) | (0x01 << 4) | (0x02))

也可以使用官方推荐的值:

145137_GDLM_1256737.png

CLKDIVN  = 0x03;            // FCLK:HCLK:PCLK=4:2:1, HDIVN=1,PDIVN=1

145451_dTAL_1256737.png

另外: LockTime是指配置了MPLL/UPLL之后时钟需要一段时间来稳定下来, 这段时间就是locktime

/*************************************************定时器**********************************************************************/

s3c2440有5个16bit定时器, 其中0~3具有pwm功能(输出), TIM4是无输出引脚的内部定时器,  TIM0还包含死区功能, 以PWM定时器的寄存器说明:

163927_mMew_1256737.png

工作原理:

(1)TCMPBn 和 TCNTBn 分别装入定时器 n 的比较值和初始值

(2)设置 TCON 来启动定时器 n. 这时 TCMPBn / TCNTBn 分别自动装入 TCMPn / TCNTn 中, 然后 TCNTn开始递减

(3)当 TCMPn == TCNTn , TIMn输出引脚的电平翻转

(4)当 TCNTn == 0, TIMn 输出引脚再次翻转, 并且申请中断

(5)当 TCNTn == 0, 且 TCON 配置了定时器为自动重装, 则TCMPBn / TCNTBn 自动装入 TCMPn / TCNTn中, 开始新一轮的递减. 

152010_jxLh_1256737.png

TCFG0:  TIMn 的 预分频值

TCFG1: TIMn 的 分频值

例: timer0_clock = 100MHz / (99+1) / 16 = 62500Hz

void TIM0_init(void){    TCFG0 = (99 << 0);  //预分频值 99    TCFG1 = (16 << 0);  //分频值 16    TCNTB0 = 31250;     //定时 0.5 s     TCON = ~(1 << 1);   //手动更新    TCON = 0x09         //自动更新, 清"手动更新"标志位, 启动TIM0. 貌似必须先设置"手动跟新" 然后再清除"手动更新"}

/**************************************看 门 狗**************************************************************/

171330_Udc5_1256737.png

(1) 首先是两级分频, 和TIM一样, 看门狗模块分为两个模式, 1. 普通定时器  2. 看门狗. 如果当做普通定时器时则应使能中断且禁止看门狗定时器

(2) 在 WTDAT 中装入初值, 因为一旦使能WTD之后, WTDAT的值不能自动加载到WTCNT中, 所以必须一开始就为  WTCNT 装载初值, 开始递减.减到0的时候

(3)如果WTD作为普通定时器, WTCNT==0时, 产生中断. 如果作为WTD, WTCNT==0时则产生复位信号

转载于:https://my.oschina.net/cxh1024/blog/264231

你可能感兴趣的文章
Java Activiti 流程审批 后台框架源码 springmvc SSM 工作流引擎
查看>>
mysql之旅【第二篇】
查看>>
Linux —— 常见指令及其英文全称
查看>>
【嵌入式开发】ARM 芯片简介 (ARM芯片类型 | ARM处理器工作模式 | ARM 寄存器 | ARM 寻址)...
查看>>
XML数据库一睹为快
查看>>
javascript事件代理(Event Delegation)
查看>>
test
查看>>
放大镜查看大图代码
查看>>
10.25T3 时间复杂度 离线操作
查看>>
thinkphp自定义分类样式
查看>>
This text field does not specify an inputType or a hint
查看>>
RocketMQ源码 — 十、 RocketMQ顺序消息
查看>>
Monkey测试:Monkey的简单使用
查看>>
Ubuntu 12.04 相关问题
查看>>
mc01_IntelliJ IDEA安装与Java项目创建以及Tomcat配置
查看>>
Tomcat启动45秒解决问题
查看>>
beta 2
查看>>
[西安交大附中集训] 自积
查看>>
linux学习摘记
查看>>
imageX及其安装windows
查看>>