51单片机的 模式0(13位定时器/计数器)
第一步:通过设置TMOD中的M1/M0位设置,即可完成模式选择
“00”为模式0(13位定时/计数模式)
“01”为模式1(16位定时/计数模式)
“10”为模式2(8位'自动重装初'值定时/计数模式)
“11”为模式3(分割为 2个8位计数模式)
第二步:打开总中断(EA)、开T0中断(ET0)、启动T0(TR0)
因为寄存器在复位后初始值都为“0”,默认属于关闭的状态,所以我们在使用T0中断功能时,
需要将这些位置“1”才可启动定T0。
第三步:根据时钟计算并装载合适的初值
在T0模式中,因为它只使用了TL0的低5位和TH0的8位空间,剩余3位不使用。
当TL0的低5位计数满并溢出后(通俗点说就是超过低5位的计算的能力后就会向高位进位,与
十进制加法同理),会向TH0位进位,同样当TH0也计满并溢出,TF0置位,此时就会中断函数就
会向CPU发送中断请求,以发生中断。
初值计算:由上面可以T0的最大计算能力为:
2的13次方=8192
由于最低位只有5位,当5位计数满(2的5次方=32)后发生溢出并进位,所有装初值
时要对TL0进行求模和余。
示例程序如下:
#include"reg52.h"
#define uint unsigned int //宏定义
#define uchar unsigned char
sbit LED=P2^0;
uchar i=0;
void main()
{
TMOD=0xf0; //设置T0为工作方式0
TH0=(8192-5000)/32; //5000us延时
TL0=(8192-5000)%32;
/*Timer0工作在模式0下时为13位定时/计数器,
TL0只使用前5位,故对32进行求余/模 */
EA=1; //开总中断
ET0=1; //开定时器0中断
TR0=1; //启动定时器0
while(1); //程序停止,等待中断请求
}
/******T0中断函数*******/
void Timer0()interrupt 1
{
TH0=(8192-5000)/32;
TL0=(8192-5000)%32;
i++;
while(i>=200)
{
i=0;
LED=~LED;
}
}
结束。