51单片机工作于方式0的定时器模式

51单片机的   模式0(13位定时器/计数器)

第一步:通过设置TMOD中的M1/M0位设置,即可完成模式选择

             “00模式0(13位定时/计数模式)

             “01”为模式1(16位定时/计数模式)

             “10”模式28'自动重装初'值定时/计数模式)

             “11”模式3分割为 2个8位计数模式)

第二步:打开总中断(EA)、开T0中断(ET0)、启动T0(TR0)

             因为寄存器在复位后初始值都为“0”,默认属于关闭的状态,所以我们在使用T0中断功能时,

      需要将这些位置“1”才可启动定T0。

第三步:根据时钟计算并装载合适的初值

             在T0模式中,因为它只使用了TL0的低5位和TH0的8位空间,剩余3位不使用。

51单片机工作于方式0的定时器模式_第1张图片

            当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;
	}
}

结束。

你可能感兴趣的:(硬件开发,单片机)