STC89C52单片机定时器2的使用 下载本文

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

#include // _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, //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)%6;

//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=num0/10; gw=num;

P0=0xfe; wela=1;

//数码管编码

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

_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++;