计时器,中止
############################
EX0(IE.0),外部中止0答应位;
ET0(IE.1),守时/计数器T0中止答应位;
EX1(IE.2),外部中止0答应位;
ET1(IE.3),守时/计数器T1中止答应位;
ES(IE.4),串行口中止答应位;
EA (IE.7), CPU中止答应(总答应)位。
初始化对守时计数器操作:
第一步:对TMOD赋值,以确认T0,T1的作业方法
第二部:核算初值,写入TH0,TL0或许TH1,TL1
第三步:中止方法,对IE赋值敞开中止
第四步:使TR0或许TR1置位,发动守时计数器作业方法是守时或许计数
TMOD:低4位操控T0 高4位操控T1
GATE C/TM1M0GATEC/TM1M0
M1M0 设置作业方法
0 0 方法0 13位守时计数器
0 1 方法1 16位守时计数器
1 0 方法2 8位主动重装守时计数器
1 1 方法3 T0分红独立两个8位守时计数器,T1中止计数
C/T 0为守时形式1为计数模式
GATE:门控位。
GATE=0时,只要用软件使TCON中的TR0或TR1为1,就可以发动守时/计数器作业;
GATA=1时,要用软件使TR0或TR1为1,一起外部中止引脚或也为高电平时,才干发动守时/计数器作业。即此刻守时器的发动多了一条件
例:
作业方法1的初始化 ,守时器用T0
则M1M0=01C/T=0 (守时形式)GATE=0
所以TMOD=0000 0001=0x01
TCON 高四位操控守时计数器的发动和中止请求
高四位: TF1,TR1,TF0,TR0
TR0开关 其他的固定
这儿只举例方法1
计数是16位 , 由TL0 作为低8位, TH0作为高8位 组成加1计数器
个数与初值联系: X=2^16-N
如,核算50000 (50毫秒)
TH0=(65536-50000)/256 放入高4位
TL0=(65536-50000)%256 放入低4位
####################################################################################
#include
#define uint unsigned int
#define uchar unsigned char
sbit dula=P2^6;
sbit wela=P2^7;
sbit d1=P1^0;
uchar num,num1;tt;
uchar code table[]={
0x3f,0x06,0x5b,0x4f,
0x66,0x6d,0x7d,0x07,
0x7f,0x6f,0x77,0x7c,
0x39,0x5e,0x79,0x71};
void delay(uint z);
void main()
{
num=0;
tt=0;
TMOD=0x11;//设置守时器0为作业方法1
TH0=(65536-10000)/256;
TL0=(65536-10000)%256;
TH1=(65536-20000)/256;
TL1=(65536-20000)%256;
//EA=1;//开总中止
ET0=1;//开守时器0中止
ET1=1;
TR0=1;//发动守时器0
TR1=1;
wela=1;//11101010
P0=0xea;
wela=0;
dula=1;
P0=0x3f;
dula=0;
while(1)
{
if(num1==25)
{
num1=0;
P1=~P1;
}
if(tt==100)
{
tt=0;
num++;
if(num==16)
num=0;
dula=1;
P0=table[num];
dula=0;
}
}
}
void delay(uint z)
{
uint x,y;
for(x=z;x>0;x–)
for(y=110;y>0;y–);
}
void time0() interrupt 1
{
TH0=(65536-10000)/256;
TL0=(65536-10000)%256;
tt++;
}
void time1() interrupt 3
{
TH1=(65536-20000)/256;
TL1=(65536-20000)%256;
num1++;
}