定时器/计数器 0和1
N76E003系列定时器/计数器 0和1是2个16位定时器/计数器。每个都是由两个8位的寄存器组成的16位计数寄存器。
对于定时器/计数器0,高8位寄存器是TH0、 低8位寄存器是TL0。
同样定时器/计数器1也有两个8位寄存器, TH1 和TL1。
TCON 和 TMOD 可以配置定时器/计数器0和1的工作模式。
通过TMOD中的 位来选择定时器或计数器功能。
每个定时器/计数器都有选择位,TMOD的第2位选择定时器/计数器0功能,TMOD的第6位选择定时器/计数器1功能。
将它们设置为定时器后,定时器将对系统时钟周期计数。
定时器0通过设置T0M(CKCON.3)位,定时器1通过设置T1M(CKCON.4)位,来选择定时器时钟是系统时钟(FSYS)的12分频或直接是系统时钟。
在计数器模式下,每当检测到外部输入脚T0上的下降沿,计数寄存器的内容就会加一。如果在一个时钟周期采样到高电平,在下一个时钟周期采样到低电平,那么T0或T1引脚就会确认为一个由高到低的跳变。
当有定时器溢出发生,定时器0和1能配置引脚T0/T1自动翻转输出。
这个功能通过设P2S寄存器的T0OE和T1OE来设置,分别对应于定时器0和定时器1。当打开这个功能,输出端口在第一个定时溢出之前输出逻辑1。为确保此模式功能, 位应该被清除并且选择系统时钟作为定时器的时钟源。
注意:TH0(TH1)和TL0(TL1)是独立分开访问。需要特别注意,在模式0或模式1下时,当读/写TH0(TH1)和TL0(TL1)之前,必须清除TR0(TR1)来停止计时。否则将产生不可预料的结果。
模式0(13位定时器)
在模式 0, 定时器/计数器是13位的计数器。13位的计数器由TH0 (TH1) 和TL0 (TL1)的低五位组成。TL0 (TL1)的高三位被忽略。当TR0 (TR1)置位且GATE是0或 是1时,定时器/计数器使能。GATE设置为1可以通过定时器来计算外部输入引脚上输入脉冲的宽度。当13位的定时器计数值从1FFFH变为0000H后,定时器溢出标志TF0 (TF1) 置位,如果中断打开,此时会产生一个定时器中断。
#define TH0_INIT 0xFC //[email protected]=12MHz, Period = (10.85/2) [email protected]=22.1184MHz #define TL0_INIT 0x0F #define TH1_INIT 0xE0 //[email protected]=12MHz, Period = (5.425/2) [email protected]=22.1184MHz #define TL1_INIT 0x00
TMOD = 0XFF; Set_All_GPIO_Quasi_Mode; TIMER0_MODE0_ENABLE; //Timer 0 and Timer 1 mode configuration TIMER1_MODE0_ENABLE; clr_T0M; clr_T1M; TH0 = TH0_INIT; TL0 = TL0_INIT; TH1 = TH1_INIT; TL1 = TL1_INIT; // set_ET0; //enable Timer0 interrupt set_ET1; //enable Timer1 interrupt set_EA; //enable interrupts set_TR0; //Timer0 run // set_TR1; //Timer1 run
TMOD = 0XFF;
Set_All_GPIO_Quasi_Mode; 设置引脚模式 #define P14_OpenDrain_Mode P1M1|=SET_BIT4;P1M2|=SET_BIT4
TIMER0_MODE0_ENABLE; //Timer 0 and Timer 1 mode configuration #define TIMER0_MODE0_ENABLE TMOD&=0xF0
//-------------------- Timer1 function define -------------------- #define TIMER0_MODE0_ENABLE TMOD&=0xF0 #define TIMER0_MODE1_ENABLE TMOD&=0xF0;TMOD|=0x01 #define TIMER0_MODE2_ENABLE TMOD&=0xF0;TMOD|=0x02 #define TIMER0_MODE3_ENABLE TMOD&=0xF0;TMOD|=0xF3
clr_T0M; clr_T1M;
#define clr_PWMCKS CKCON &= ~SET_BIT6 #define clr_T1M CKCON &= ~SET_BIT4 #define clr_T0M CKCON &= ~SET_BIT3 #define clr_CLOEN CKCON &= ~SET_BIT1
TH0 = TH0_INIT; TL0 = TL0_INIT; TH1 = TH1_INIT; TL1 = TL1_INIT;
#define TH0_INIT 0xFC //[email protected]=12MHz, Period = (10.85/2) [email protected]=22.1184MHz #define TL0_INIT 0x0F #define TH1_INIT 0xE0 //[email protected]=12MHz, Period = (5.425/2) [email protected]=22.1184MHz #define TL1_INIT 0x00
set_ET1; //enable Timer1 interrupt
#define set_ET1 ET1 = 1
set_EA; //enable interrupts
set_TR0; //Timer0 run
中断服务函数:
void Timer0_ISR (void) interrupt 1 //interrupt address is 0x000B { TH0 = TH0_INIT; TL0 = TL0_INIT; P12 = ~P12; // GPIO toggle when interrupt }
模式1(16位定时器)
模式1与模式0 非常相似,只是模式1下定时器/计数器为16位的,就是说是用THx和TLx的全部16位用来计数。当
计数值由FFFFH向0000H翻转后,定时器相应的溢出标志TF0(TF1)置1,如果中断使能则将产生中断。
模式2(8位自动重装载定时器)
模式2下定时器/计数器为自动重装模式。此模式下TL0(TL1)是一个8位的计数器,TH0(TH1)保存重装计数
值。当TL0(TL1)溢出后,TCON中的TF0(TF1)标志置位且TH0(TH1)中内容重装至TL0(TL1),然后继续计数过
程。重装过程中TH0(TH1)内的值保持不变.该特征最好地适用于UART波特率发生器,不需要连续软件介入。
模式3(两组独立8位定时器)
定时器0和定时器1的模式3有着不同的工作方式。对定时器/计数器1来说模式3会将其停用;对定时器/计数器0来
说,模式3下TL0和TH0是2个独立的8位计数寄存器。模式3下TL0使用定时器0的控制位:如 GATE, TR0,
(TMOD.2)来决定。TH0 只能对时钟周期计和 TF0。TL0也可以用来对T0 脚上的1到0 跳变计数,由
数,并使用定时器/计数器1的控制位(TR1和TF1)。当需要额外的8位定时器时可以使用模式3 。当定时器0配
置为模式3时,定时器1可以通过配置其进入或离开模式3的方式来打开或关闭自己。定时器1依然可以工作在模
式0、1、2下,但它的灵活性受到限制。虽然基本功能得以维持,但已不能对TF1和TR1进行控制。此时定时器1
依然可以使用GATE脚、T1M。它同样可以用作串行口的波特率发生器或其他不需要中断的应用。
原文地址:https://www.cnblogs.com/zhugeanran/p/9180609.html