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位不使用。

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

结束。

  • 17
    点赞
  • 59
    收藏
    觉得还不错? 一键收藏
  • 5
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值