EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
本帖最后由 CLBuu 于 2021-9-17 09:42 编辑
4 ?1 Z" D6 ?5 K- S4 W8 b+ {; P/ J8 e+ O! Q/ ]' m
定时器作用:定时器就是用来准确控制时间的工具,精确的控制时间,以满足控制某些特定事件的要求。例如:在电机控制中,要求为在系统启动5S后加载负载,这时候就能够利用定时器来精确控制。在F28335中,有3个32位的定时器,分别是Timer0、Timer1、Timer2。其中,Timer1、Timer2被系统保留,用于实时操作系统,如果不用于实时操作系统,用户也可以使用这两个定时器**
0 q6 z6 k- N6 w: g定时器工作原理图 CPU定时器的内部结构如下图所示:
5 l( F- F# C& x2 M- s6 N$ n& o 从上图可以看出,在定时器中有以下几个寄存器: 32位的定时器周期寄存器 prdh:prd; 32位计数器寄存器 TIMH:TIM; 16位的定时器分频器寄存器TDDRH:TDDR; 16位的预定标计数器寄存器psch:psc. 定时器的工作示意图如下:
( |/ E4 O" c( H
5 ]" t p- _' w1 z3 F b
定时器工作流程 在定时器中,最主要的功能就是定时,那么就像我们设置闹钟一样,先要给个目标值,也就是我们的周期值,计算好这个值后(后续会提到)赋给周期寄存器 prdh:prd, 当启动定时器开始计数时,周期寄存器prdh:prd 的值会装载到定时器计数寄存器TIMH:TIM。当定时器计数寄存器TIMH:TIM不断减1到0时,这个时候到了我们所设定的时间,产生一个中断信号。那么问题来了,定时器计数寄存器TIMH:TIM多长时间减一次1呢,这个就又TIMCLK来控制了,根据上图所示,每来一个TIMCLK,定时器计数寄存器就会减1,那么TIMCLK又是如何产生的呢?根据上图可以看出是由定时器分频器TDDRH:TDDR和定时器预定标 PSCH:pSC来控制。先给定时器分频器TDDRH:TDDR赋值,然后装载到预定标PSCH:pSC中,每经过一个系统时钟信号,PSCH:pSC就会自动减1,当减到0时候就会产生一个TIMCLK。
* a1 [3 k: H8 ^) l# l8 M时间计算 如果系统时钟使用的是X(MHZ)则: ***TIMCLK = (TDDRH:TDDR+1)*10^-6/ X(这里的单位是秒,为什么分子需要加1呢,因为需要减到0,所以需要加1) 定时器一个周期所需要的时间: T=(PRDH:pRD+1) *TIMCLK(S) 9 P9 r: X# w+ b+ Q1 C, c
6 l) O: x! g. _; \- x% Y! u# i
|