微波EDA网,见证研发工程师的成长!
首页 > 研发问答 > 嵌入式设计讨论 > MCU和单片机设计讨论 > 51单片机T2的使用

51单片机T2的使用

时间:10-02 整理:3721RD 点击:

52单片机有3个定时器,T2是一个16位自动重载的,像T0和T1的方式2一样,只不过它是16位重载,如果作为计数器或定时用,中断用的是5,就是interrupt 5,T2的引脚是P1.0口。P1.0作为I/O口用了以后T2计数是不行了,不过定时或是作为串口时钟还是可以的。



T2CON(T2的控制寄存器),字节地址0C8H:



0CFH    0CEH   0CDH  
0CCH   0CBH   0CAH  
0C9H   0C8H



TF2     EXF2   RCLK  
TCLK   EXEN2  TR2   
C/T2   CP/RT2


各位的定义如下:


TF2:定时/计数器2溢出标志,T2溢出时置位,并申请中断。只能用软件清除,但T2作为波特率发生器使用的时候,(即RCLK=1或TCLK=1),T2溢出时不对TF2置位。


EXF2:当EXEN2=1时,且T2EX引脚(P1.0)出现负跳变而造成T2的捕获或重装的时候,EXF2置位并申请中断。EXF2也是只能通过软件来清除的。


RCLK:串行接收时钟标志,只能通过软件的置位或清除;用来选择T1(RCLK=0)还是T2(RCLK=1)来作为串行接收的波特率产生器


TCLK:串行发送时钟标志,只能通过软件的置位或清除;用来选择T1(TCLK=0)还是T2(TCLK=1)来作为串行发送的波特率产生器


EXEN2:T2的外部允许标志,只能通过软件的置位或清除;EXEN2=0:禁止外部时钟触发T2;EXEN2=1:当T2未用作串行波特率发生器时,允许外部时钟触发T2,当T2EX引脚输入一个负跳变的时候,将引起T2的捕获或重装,并置位EXF2,申请中断。


TR2:T2的启动控制标志;TR2=0:停止T2;TR2=1:启动T2


C/T2:T2的定时方式或计数方式选择位。只能通过软件的置位或清除;C/T2=0:选择T2为定时器方式;C/T2=1:选择T2为计数器方式,下降沿触发。


CP/RT2:捕获/重装载标志,只能通过软件的置位或清除。CP/RT2=0时,选择重装载方式,这时若T2溢出(EXEN2=0时)或者T2EX引脚(P1.0)出现负跳变(EXEN2=1时),将会引起T2重装载;CP/RT2=1时,选择捕获方式,这时若T2EX引脚(P1.0)出现负跳变(EXEN2=1时),将会引起T2捕获操作。但是如果RCLK=1或TCLK=1时,CP/RT2控制位不起作用的,被强制工作于定时器溢出自动重装载模式。




对应郭天祥老师的52单片机板子!

/***********************************

程序编著院校  南昌航空大学

晶振         
11.0592MHZ


T2CON(0XC8)的说明 定时器2可以产生两个中断TF2和EXF2,这两个中断通过逻辑或共享一个端口

定时器2溢出时  TF2置位  如果定时器工作在重装模式  RCAP2H和RCAP2L的值会自动装入TH2和TL2  TR2启动

TF2和TL2必须软件清零

T2MOD    必须定义sfr T2MOD= 0xC9;

扩展 RCLK TCLK其中一个为高电平 定时器2做波特率发生器

***********************************/

#include<reg52.h>

#include<intrins.h>  //
_nop_();


#define uchar unsigned char

#define uint unsigned int

sfr T2MOD   = 0xC9;

sbit  dula=P2^6;

sbit  wela=P2^7;

sbit  led=P1^7;

uchar timer2_ctr,num;

uchar code table[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,                      //数码管编码

                       
0x07,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};


//11.0592MHZ延时函数

void delay(uint ms)

{

  uint x;

  while(ms--)

  {

    for(x=125;x>0;x--);

  }  

}

//初始化主函数

void init()

{

  dula=wela=0;                //关闭数码管显示  

  RCAP2H=(0XFFFF-50000)/256;

  RCAP2L=(0XFFFF-50000)%256;   

  //TH2=RCAP2H;              //会自动重装

  //TL2=RCAP2L;

  T2CON=0;

  T2MOD=0;            

  IE=0XA0;                   //开总中断和定时器2中断

  TR2=1;                     //启动

}

void display(uchar num)

{

   uchar gw,sw,bw;

   bw=num/100;

   sw=num%100/10;

   gw=num%10;



   P0=0xfe;

   wela=1;

   _nop_();_nop_();

   wela=0;

   P0=table[bw];

   dula=1;

   _nop_();_nop_();

   dula=0;

   delay(3);

  

   P0=0xfd;

   wela=1;

   _nop_();_nop_();

   wela=0;

   P0=table[sw];

   dula=1;

   _nop_();_nop_();

   dula=0;

   delay(3);



   P0=0xfb;

   wela=1;

   _nop_();_nop_();

   wela=0;

   P0=table[gw];

   dula=1;

   _nop_();_nop_();

   dula=0;

   delay(3);                     //显示个 十 百

}



void main()

{

   init();

   while(1)

   {

      display(num);

   }

}





void timer2() interrupt 5

{

   TF2=0;             //注意!定时器2必须由软件对溢出标志位清零,硬件不能清零,这里与定时器0和定时器1不同!

   timer2_ctr++;

   if(timer2_ctr>=20)  //定时50ms×20=1000ms即1秒钟,这里模拟一个60秒秒表  

   {

      timer2_ctr=0;

      led=~led;

      num++;

      if(num>=256)

      {

          num=0;

      }

   }

}





现象是:数码管显示0-256,

程序很简单!朋友们可以自己试试!



祝你学成!

介绍的很详细

介绍的不错               

写的不错!

谢谢分享!

不错。值得学习!

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top