的中断系统及定时计数器.ppt
的中断系统及定时计数器 Still waters run deep.流静水深流静水深,人静心深人静心深 Where there is life,there is hope。有生命必有希望。有生命必有希望5.1 80C51的中断系的中断系统统 5.1.1 80C515.1.1 80C51的中断系的中断系统结统结构构 一、中断的概念一、中断的概念 计计算机具有算机具有实时处实时处理能力,能理能力,能对对外界外界发发生的事件生的事件进进行及行及时处时处理理,这这是依靠它是依靠它们们的中断系的中断系统统来来实现实现的。的。CPU CPU在在处处理某一事件理某一事件A A时时,发发生了另一事件生了另一事件B B请请求求CPUCPU迅速去迅速去处处理(理(中断中断发发生生););CPUCPU暂时暂时中断当前的工作,中断当前的工作,转转去去处处理事件理事件B B(中断响中断响应应和中断服和中断服务务);待);待CPUCPU将事将事件件B B处处理完理完毕毕后,再回到原来事件后,再回到原来事件A A被中断的地方被中断的地方继续继续处处理事件理事件A A(中断返回中断返回),),这这一一过过程称程称为为中断中断 。2引起引起CPU中断的根源,称为中断源。中断源向中断的根源,称为中断源。中断源向CPU提出提出的中断请求。的中断请求。CPU暂时中断原来的事务暂时中断原来的事务A,转去处理事件,转去处理事件B。对事件对事件B处理完毕后,再回到原来被中断的地方(即断点),处理完毕后,再回到原来被中断的地方(即断点),称为中断返回。实现上述中断功能的部件称为中断系统称为中断返回。实现上述中断功能的部件称为中断系统(中断机构)。(中断机构)。3 随着计算机技术的应用,人们发现中断技随着计算机技术的应用,人们发现中断技术不仅解决了快速主机与慢速术不仅解决了快速主机与慢速I/O设备的数据设备的数据传送问题,而且还具有如下优点:传送问题,而且还具有如下优点:n分时操作分时操作。CPU可以分时为多个可以分时为多个I/O设备服设备服务,提高了计算机的利用率;务,提高了计算机的利用率;n实时响应实时响应。CPU能够及时处理应用系统的能够及时处理应用系统的随机事件,系统的实时性大大增强;随机事件,系统的实时性大大增强;n可靠性高可靠性高。CPU具有处理设备故障及掉电具有处理设备故障及掉电等突发性事件的能力,从而使系统可靠性提等突发性事件的能力,从而使系统可靠性提高。高。4二、二、80C51中断系统的结构中断系统的结构 80C51的中断系统有的中断系统有5个中断源,个中断源,2个优先个优先级,可实现二级中断嵌套级,可实现二级中断嵌套。55.1.2 80C515.1.2 80C51的中断源的中断源 一、中断源一、中断源1、(P3.2)。可由)。可由IT0(TCON.0)选择其为低电平有效选择其为低电平有效还是下降沿有效。当还是下降沿有效。当CPU检测到检测到P3.2引脚上出现有效的中引脚上出现有效的中断信号时,中断标志断信号时,中断标志IE0(TCON.1)置置1,向,向CPU申请中断。申请中断。2、(P3.3)。可由)。可由IT1(TCON.2)选择其为低电平有效选择其为低电平有效还是下降沿有效。当还是下降沿有效。当CPU检测到检测到P3.3引脚上出现有效的中引脚上出现有效的中断信号时,中断标志断信号时,中断标志IE1(TCON.3)置置1,向向CPU申请中断。申请中断。3、TF0(TCON.5),片内定时),片内定时/计数器计数器T0溢出中断请求标溢出中断请求标志。当定时志。当定时/计数器计数器T0发生溢出时,置位发生溢出时,置位TF0,并向,并向CPU申申请中断。请中断。4、TF1(TCON.7),片内定时),片内定时/计数器计数器T1溢出中断请求标溢出中断请求标志。当定时志。当定时/计数器计数器T1发生溢出时,置位发生溢出时,置位TF1,并向,并向CPU申申请中断。请中断。5、RI(SCON.0)或)或TI(SCON.1),串行口中断请求标志。),串行口中断请求标志。当串行口接收完一帧串行数据时置位当串行口接收完一帧串行数据时置位RI或当串行口发送完一或当串行口发送完一帧串行数据时置位帧串行数据时置位TI,向,向CPU申请中断。申请中断。6二、中断请求标志二、中断请求标志1、TCON的中断标志的中断标志IT0(TCON.0),外部中断),外部中断0触发方式控制位。触发方式控制位。当当IT0=0时,为电平触发方式。时,为电平触发方式。当当IT0=1时,为边沿触发方式(下降沿有效)。时,为边沿触发方式(下降沿有效)。IE0(TCON.1),外部中断),外部中断0中断请求标志位。中断请求标志位。IT1(TCON.2),外部中断),外部中断1触发方式控制位。触发方式控制位。IE1(TCON.3),外部中断),外部中断1中断请求标志位。中断请求标志位。TF0(TCON.5),定时),定时/计数器计数器T0溢出中断请求标志位。溢出中断请求标志位。TF1(TCON.7),定时),定时/计数器计数器T1溢出中断请求标志位。溢出中断请求标志位。72、SCON的中断标志的中断标志nRI(SCON.0),串行口接收中断标志位。当允),串行口接收中断标志位。当允许串行口接收数据时,每接收完一个串行帧,由许串行口接收数据时,每接收完一个串行帧,由硬件置位硬件置位RI。同样,。同样,RI必须由软件清除。必须由软件清除。nTI(SCON.1),串行口发送中断标志位。当),串行口发送中断标志位。当CPU将一个发送数据写入串行口发送缓冲器时,将一个发送数据写入串行口发送缓冲器时,就启动了发送过程。每发送完一个串行帧,由硬就启动了发送过程。每发送完一个串行帧,由硬件置位件置位TI。CPU响应中断时,不能自动清除响应中断时,不能自动清除TI,TI必须由软件清除。必须由软件清除。8一、中断允许控制一、中断允许控制 CPU对中断系统所有中断以及某个中断源的开放和屏蔽是对中断系统所有中断以及某个中断源的开放和屏蔽是由中断允许寄存器由中断允许寄存器IE控制的。控制的。5.1.3 80C515.1.3 80C51中断的控制中断的控制 nEX0(IE.0),外部中断,外部中断0允许位;允许位;nET0(IE.1),定时,定时/计数器计数器T0中断允许位;中断允许位;nEX1(IE.2),外部中断,外部中断0允许位;允许位;nET1(IE.3),定时,定时/计数器计数器T1中断允许位;中断允许位;nES(IE.4),串行口中断允许位;,串行口中断允许位;nEA(IE.7),CPU中断允许(总允许)位。中断允许(总允许)位。9二、中断优先级控制二、中断优先级控制 80C51单片机有两个中断优先级,即可实现二级中断服务单片机有两个中断优先级,即可实现二级中断服务嵌套。每个中断源的中断优先级都是由中断优先级寄存器嵌套。每个中断源的中断优先级都是由中断优先级寄存器IP中中的相应位的状态来规定的的相应位的状态来规定的。nPX0(IP.0),外部中断),外部中断0优先级设定位;优先级设定位;nPT0(IP.1),定时),定时/计数器计数器T0优先级设定位;优先级设定位;nPX1(IP.2),外部中断),外部中断0优先级设定位;优先级设定位;nPT1(IP.3),定时),定时/计数器计数器T1优先级设定位;优先级设定位;nPS(IP.4),串行口优先级设定位。),串行口优先级设定位。10 同一优先级中的中断申请不止一个时,则有中同一优先级中的中断申请不止一个时,则有中断优先权排队问题。同一优先级的中断优先权排队,断优先权排队问题。同一优先级的中断优先权排队,由中断系统硬件确定的自然优先级形成,其排列如由中断系统硬件确定的自然优先级形成,其排列如所示:所示:1180C51单片机的中断优先级有三条原则:单片机的中断优先级有三条原则:nCPU同时接收到几个中断时,首先响应优先级别最高同时接收到几个中断时,首先响应优先级别最高的中断请求。的中断请求。n正在进行的中断过程不能被新的同级或低优先级的中正在进行的中断过程不能被新的同级或低优先级的中断请求所中断。断请求所中断。n正在进行的低优先级中断服务,能被高优先级中断请正在进行的低优先级中断服务,能被高优先级中断请求所中断。求所中断。为了实现上述后两条原则,为了实现上述后两条原则,中断系统内部设有两个中断系统内部设有两个用户不能寻址的优先级状态触发器用户不能寻址的优先级状态触发器。其中一个置。其中一个置1,表,表示正在响应高优先级的中断,它将阻断后来所有的中示正在响应高优先级的中断,它将阻断后来所有的中断请求;另一个置断请求;另一个置1,表示正在响应低优先级中断,它,表示正在响应低优先级中断,它将阻断后来所有的低优先级中断请求。将阻断后来所有的低优先级中断请求。125.2 80C51单片机中断处理过程单片机中断处理过程 一、中断响应条件一、中断响应条件CPU响应中断的条件是:响应中断的条件是:n 中断源有中断请求;中断源有中断请求;n 此中断源的中断允许位为此中断源的中断允许位为1;n CPU开中断(即开中断(即EA=1)。)。同时满足时,同时满足时,CPU才有可能响应中断才有可能响应中断。5.2.1 5.2.1 中断响中断响应应条件和条件和时间时间 13 CPU执行程序过程中,在每个机器周期执行程序过程中,在每个机器周期的的S5P2期间,中断系统对各个中断源进行期间,中断系统对各个中断源进行采样采样。这些采样值在下一个机器周期内按优。这些采样值在下一个机器周期内按优先级和内部顺序被依次查询。先级和内部顺序被依次查询。如果某个中断标志在上一个机器周期的如果某个中断标志在上一个机器周期的S5P2时被置成了时被置成了1,那么它将于现在的查询,那么它将于现在的查询周期中及时被发现。接着周期中及时被发现。接着CPU便执行一条便执行一条由中断系统提供的硬件由中断系统提供的硬件LCALL指令,转向指令,转向被称作中断向量的特定地址单元,进入相应被称作中断向量的特定地址单元,进入相应的中断服务程序。的中断服务程序。14遇以下任一条件,硬件将受阻,不产生遇以下任一条件,硬件将受阻,不产生LCALL指令:指令:nCPU正在处理同级或高正在处理同级或高优先级中断;优先级中断;n当前查询当前查询的机器周期的机器周期不是所执行指令的最后一个机器不是所执行指令的最后一个机器周期周期。即在完成所执行指令前,不会响应中断,从而保。即在完成所执行指令前,不会响应中断,从而保证指令在执行过程中不被打断;证指令在执行过程中不被打断;n正在执行正在执行的指令为的指令为RET、RETI或任何访问或任何访问IE或或IP寄存寄存器的指令。即只有在这些指令后面至少再执行一条指令器的指令。即只有在这些指令后面至少再执行一条指令时才能接受中断请求。时才能接受中断请求。若由于上述条件的阻碍中断未能得到响应,当条件消若由于上述条件的阻碍中断未能得到响应,当条件消失时该中断标志却已不再有效,那么该中断将不被响应。失时该中断标志却已不再有效,那么该中断将不被响应。就是说,中断标志曾经有效,但未获响应,查询过程在就是说,中断标志曾经有效,但未获响应,查询过程在下个机器周期将重新进行下个机器周期将重新进行。15二、中断响应时间二、中断响应时间某中断的响应时序如图:某中断的响应时序如图:n若若M1周期的周期的S5P2前某中断生效,在前某中断生效,在S5P2期间其中期间其中断请求被锁存到相应的标志位中去;断请求被锁存到相应的标志位中去;M2恰逢指令的恰逢指令的最后一个机器周期,且该指令不是最后一个机器周期,且该指令不是RETI或访问或访问IE、IP的指令。于是,的指令。于是,M3和和M4便可以执行硬件便可以执行硬件LCALL指指令,令,M5周期将进入了中断服务程序。周期将进入了中断服务程序。n80C51的中断响应时间(从标志置的中断响应时间(从标志置1到进入相应的中到进入相应的中断服务),至少要断服务),至少要3个完整的机器周期。个完整的机器周期。16n将相应的优先级状态触发器置将相应的优先级状态触发器置1(以阻断(以阻断后来的同级或低级的中断请求)。后来的同级或低级的中断请求)。n执行一条硬件执行一条硬件LCALL指令,即把程序计指令,即把程序计数器数器PC的内容压入堆栈保存,再将相应的的内容压入堆栈保存,再将相应的中断服务程序的入口地址送入中断服务程序的入口地址送入PC。n执行中断服务程序。执行中断服务程序。中断响应过程的前两步是由中断系统内部中断响应过程的前两步是由中断系统内部自动完成的,而中断服务程序则要由用户自动完成的,而中断服务程序则要由用户编写程序来完成。编写程序来完成。5.2.2 5.2.2 中断响中断响应过应过程程 17 5.2.3 5.2.3 中断返回中断返回RETI指令的具体功能是:指令的具体功能是:n将中断响应时压入堆栈保存的断点地址从栈将中断响应时压入堆栈保存的断点地址从栈顶弹出送回顶弹出送回PC,CPU从原来中断的地方继续从原来中断的地方继续执行程序;执行程序;n 将相应中断优先级状态触发器清将相应中断优先级状态触发器清0,通知中,通知中断系统,中断服务程序已执行完毕。断系统,中断服务程序已执行完毕。注意,不能用注意,不能用RET指令代替指令代替RETI指令。在中指令。在中断服务程序中断服务程序中PUSH指令与指令与POP指令必须成对指令必须成对使用,否则不能正确返回断点使用,否则不能正确返回断点 。18 若外部中断定义为电平触发方式若外部中断定义为电平触发方式,中断标志位的,中断标志位的状态随状态随CPU在每个机器周期采样到的外部中断输入在每个机器周期采样到的外部中断输入引脚的电平变化而变化,这样能提高引脚的电平变化而变化,这样能提高CPU对外部中对外部中断请求的响应速度。但外部中断源若有请求,必须断请求的响应速度。但外部中断源若有请求,必须把有效的把有效的低电平保持到请求获得响应时为止低电平保持到请求获得响应时为止,不然,不然就会漏掉;就会漏掉;而在中断服务程序结束之前,中断源又而在中断服务程序结束之前,中断源又必须撤消其有效的低电平必须撤消其有效的低电平,否则中断返回之后将再,否则中断返回之后将再次产生中断。次产生中断。电平触发方式适合于外部中断输入以低电平输入且电平触发方式适合于外部中断输入以低电平输入且中断服务程序能清除外部中断请求源的情况。例如,中断服务程序能清除外部中断请求源的情况。例如,并行接口芯片并行接口芯片8255的中断请求线在接受读或写操的中断请求线在接受读或写操作后即被复位,因此,以其去请求电平触发方式的作后即被复位,因此,以其去请求电平触发方式的中断比较方便。中断比较方便。19 若外部中断定义为边沿触发方式若外部中断定义为边沿触发方式,在相继连续的两,在相继连续的两次采样中,一个周期采样到外部中断输入为高电平,次采样中,一个周期采样到外部中断输入为高电平,下一个周期采样到为低电平,则在下一个周期采样到为低电平,则在IE0或或IE1中将锁存中将锁存一个逻辑一个逻辑1。即便是。即便是CPU暂时不能响应,中断申请标暂时不能响应,中断申请标志也不会丢失,直到志也不会丢失,直到CPU响应此中断时才清零。这样,响应此中断时才清零。这样,为保证下降沿能被可靠地采样到,为保证下降沿能被可靠地采样到,外中断引脚上的高外中断引脚上的高低电平(负脉冲的宽度)均至少要保持一个机器周期低电平(负脉冲的宽度)均至少要保持一个机器周期(若晶振为(若晶振为12MHz时,为时,为1微秒)。微秒)。边沿触发方式适合于以负脉冲形式输入的外部中断边沿触发方式适合于以负脉冲形式输入的外部中断请求,如请求,如ADC0809的转换结束标志信号的转换结束标志信号EOC为正脉为正脉冲,经反相后就可以作为冲,经反相后就可以作为80C51的中断输入。的中断输入。205.2.4 5.2.4 中断程序中断程序举举例例 21 ORG 0000HSTART:LJMP MAIN ;跳转到主程序;跳转到主程序 ORG 0003H LJMP INTO ;转向中断服务程序;转向中断服务程序 ORG 0030H ;主程序;主程序 MAIN:CLR IT0 ;设为电平触发方式;设为电平触发方式 SETB EA ;CPU开放中断开放中断 SETB EX0 ;允许中断;允许中断 MOV DPTR,#1000H;设置数据区地址指针;设置数据区地址指针 ORG 0200H ;中断服务程序;中断服务程序 INT0:PUSH PSW ;保护现场;保护现场 PUSH ACC CLR P3.0 ;由;由P3.0输出输出0 NOP NOP SETB P3.0 ;由;由P3.0输出输出1,撤除,撤除 MOV A,P1 ;输入数据;输入数据 MOVX DPTR,A ;存入数据存储器;存入数据存储器 INC DPTR ;修改数据指针,指向下一个单元;修改数据指针,指向下一个单元 POP ACC ;恢复现场;恢复现场 POP PSW RETI ;中断返回;中断返回22 例例 多外部中断源的系统示例。多外部中断源的系统示例。设有设有5个外部中断源,中断优先级排队顺序为:个外部中断源,中断优先级排队顺序为:XI0、XI1、XI2、XI3、XI4。试设计它们与。试设计它们与80C51单单片机的接口。片机的接口。23 ORG 0003H LJMP INSE0 ;转外部中断;转外部中断0服务程序入口服务程序入口 ORG 0013H LJMP INSE1 ;转外部中断;转外部中断1服务程序入口服务程序入口 INSE0:PUSH PSW ;XI0中断服务程序中断服务程序 PUSH ACC POP ACC POP PSW RETI 24INSE1:PUSH PSW ;中断服务程序;中断服务程序 PUSH ACC JB P1.0,DV1 ;P1.0为为1,转,转XI1中断服务程序中断服务程序 JB P1.1,DV2 ;P1.1为为1,转,转XI2中断服务程序中断服务程序 JB P1.2,DV3 ;P1.2为为1,转,转XI3中断服务程序中断服务程序 JB P1.3,DV4 ;P1.3为为1,转,转XI4中断服务程序中断服务程序INRET:POP ACC POP PSW RETI DV1:;XI1中断服务程序中断服务程序 AJMP INRET DV2:;XI2中断服务程序中断服务程序 AJMP INRET DV3:;XI3中断服务程序中断服务程序 AJMP INRET DV4:;XI4中断服务程序中断服务程序 AJMP INRET255.3 80C51的定时的定时/计数器计数器 实现定时功能,实现定时功能,比较方便的办法是利用单片比较方便的办法是利用单片机内部的定时机内部的定时/计数器计数器。也可以采用下面三种。也可以采用下面三种方法:方法:n软件定时软件定时:软件定时不占用硬件资源,但占用了:软件定时不占用硬件资源,但占用了CPU时间,降低了时间,降低了CPU的利用率。的利用率。n采用时基电路定时采用时基电路定时:例如采用:例如采用555电路,外接必要电路,外接必要的元器件(电阻和电容),即可构成硬件定时电路。的元器件(电阻和电容),即可构成硬件定时电路。但在硬件连接好以后,定时值与定时范围不能由软但在硬件连接好以后,定时值与定时范围不能由软件进行控制和修改,即不可编程。件进行控制和修改,即不可编程。n采用可编程芯片定时采用可编程芯片定时:这种定时芯片的定时值及:这种定时芯片的定时值及定时范围很容易用软件来确定和修改,此种芯片定定时范围很容易用软件来确定和修改,此种芯片定时功能强,使用灵活。在单片机的定时时功能强,使用灵活。在单片机的定时/计数器不够计数器不够用时,可以考虑进行扩展。用时,可以考虑进行扩展。265.3.1 5.3.1 定定时时/计计数器的数器的结结构和工作原理构和工作原理 一、定时一、定时/计数器的结构计数器的结构 定时定时/计数器的实质是加计数器的实质是加1计数器(计数器(16位),由高位),由高8位和低位和低8位两个寄存器组成。位两个寄存器组成。TMOD是定时是定时/计数器的工作方式寄存计数器的工作方式寄存器,确定工作方式和功能;器,确定工作方式和功能;TCON是控制寄存器,控制是控制寄存器,控制T0、T1的启动和停止及设置溢出标志的启动和停止及设置溢出标志。27二、定时二、定时/计数器的工作原理计数器的工作原理 加加1计数器输入的计数脉冲有两个来源计数器输入的计数脉冲有两个来源,一个是由一个是由系统的时钟振荡器输出脉冲经系统的时钟振荡器输出脉冲经12分频后送来;一个分频后送来;一个是是T0或或T1引脚输入的外部脉冲源。每来一个脉冲计引脚输入的外部脉冲源。每来一个脉冲计数器加数器加1,当加到计数器为全,当加到计数器为全1时,再输入一个脉冲时,再输入一个脉冲就使计数器回零,且计数器的溢出使就使计数器回零,且计数器的溢出使TCON中中TF0或或TF1置置1,向,向CPU发出中断请求(定时发出中断请求(定时/计数器中计数器中断允许时)。如果定时断允许时)。如果定时/计数器工作于定时模式,计数器工作于定时模式,则表示定时时间已到;如果工作于计数模式,则表则表示定时时间已到;如果工作于计数模式,则表示计数值已满。示计数值已满。可见,由溢出时计数器的值减去计数初值才是加可见,由溢出时计数器的值减去计数初值才是加1计数器的计数值计数器的计数值。28n设置为定时器模式时设置为定时器模式时,加,加1计数器是对内部机器周期计数器是对内部机器周期计数(计数(1个机器周期等于个机器周期等于12个振荡周期,即计数频率个振荡周期,即计数频率为晶振频率的为晶振频率的1/12)。)。计数值计数值N乘以机器周期乘以机器周期Tcy就就是定时时间是定时时间t。n设置为设置为计数器模式时计数器模式时,外部事件计数脉冲由,外部事件计数脉冲由T0或或T1引脚输入到计数器。在每个机器周期的引脚输入到计数器。在每个机器周期的S5P2期间采期间采样样T0、T1引脚电平。当某周期采样到一高电平输入,引脚电平。当某周期采样到一高电平输入,而下一周期又采样到一低电平时,则计数器加而下一周期又采样到一低电平时,则计数器加1,更,更新的计数值在下一个机器周期的新的计数值在下一个机器周期的S3P1期间装入计数期间装入计数器。由于检测一个从器。由于检测一个从1到到0的下降沿需要的下降沿需要2个机器周期,个机器周期,因此要求被采样的电平至少要维持一个机器周期。当因此要求被采样的电平至少要维持一个机器周期。当晶振频率为晶振频率为12MHz时时,最高计数频率不超过,最高计数频率不超过1/2MHz,即计数脉冲的周期要大于,即计数脉冲的周期要大于2 微秒微秒。29 5.3.2 定时定时/计数器的控制计数器的控制 80C51单片机定时单片机定时/计数器的工作由两个特殊计数器的工作由两个特殊功能寄存器控制。功能寄存器控制。TMOD用于设置其工作方式;用于设置其工作方式;TCON用于控制其启动和中断申请。用于控制其启动和中断申请。一、工作方式寄存器一、工作方式寄存器TMOD 工作方式寄存器工作方式寄存器TMOD用于设置定时用于设置定时/计数器的计数器的工作方式,低四位用于工作方式,低四位用于T0,高四位用于,高四位用于T1。其格式。其格式如下:如下:30GATE:门控位。:门控位。GATE0时,只要用软件使时,只要用软件使TCON中的中的TR0或或TR1为为1,就可以启动定时,就可以启动定时/计数器工作;计数器工作;GATA1时,时,要用软件使要用软件使TR0或或TR1为为1,同时外部中断引脚或也为高电,同时外部中断引脚或也为高电平时,才能启动定时平时,才能启动定时/计数器工作。即此时定时器的启动条计数器工作。即此时定时器的启动条件,加上了或引脚为高电平这一条件。件,加上了或引脚为高电平这一条件。:定时定时/计数模式选择位。计数模式选择位。0为定时模式;为定时模式;=1为计数模式。为计数模式。M1M0:工作方式设置位。定时:工作方式设置位。定时/计数器有四种工作方式,计数器有四种工作方式,由由M1M0进行设置。进行设置。31 二、控制寄存器二、控制寄存器TCON TCON的低的低4位用于控制外部中断位用于控制外部中断,已在前面介绍。已在前面介绍。TCON的高的高4位用于位用于控制定时控制定时/计数器的启动和中断申请。其格式如下:计数器的启动和中断申请。其格式如下:nTF1(TCON.7):):T1溢出中断请求标志位。溢出中断请求标志位。T1计数溢出时由硬件自计数溢出时由硬件自动置动置TF1为为1。CPU响应中断后响应中断后TF1由硬件自动清由硬件自动清0。T1工作时,工作时,CPU可随时查询可随时查询TF1的状态。所以,的状态。所以,TF1可用作查询测试的标志。可用作查询测试的标志。TF1也可也可以用软件置以用软件置1或清或清0,同硬件置,同硬件置1或清或清0的效果一样。的效果一样。nTR1(TCON.6):):T1运行控制位。运行控制位。TR1置置1时,时,T1开始工作;开始工作;TR1置置0时,时,T1停止工作。停止工作。TR1由软件置由软件置1或清或清0。所以,用软件可控制定时。所以,用软件可控制定时/计数器的启动与停止。计数器的启动与停止。nTF0(TCON.5):):T0溢出中断请求标志位,其功能与溢出中断请求标志位,其功能与TF1类同。类同。nTR0(TCON.4):):T0运行控制位,其功能与运行控制位,其功能与TR1类同。类同。32 5.3.3 定时定时/计数器的工作方式计数器的工作方式 一、方式一、方式0 方式方式0为为13位计数位计数,由,由TL0的低的低5位(高位(高3位未用)和位未用)和TH0的的8位组成。位组成。TL0的低的低5位溢出时向位溢出时向TH0进位,进位,TH0溢出时,溢出时,置位置位TCON中的中的TF0标志,向标志,向CPU发出中断请求。发出中断请求。33 定时器模式时定时器模式时有有:Nt/Tcy 计数初值计算的公式为:计数初值计算的公式为:定时器的初值还可以采用计数个数直接取补法获得定时器的初值还可以采用计数个数直接取补法获得。计数模式时,计数脉冲是计数模式时,计数脉冲是T0引脚上的外部脉冲。引脚上的外部脉冲。门控位门控位GATE具有特殊的作用。当具有特殊的作用。当GATE=0时,经反相后使时,经反相后使或门输出为或门输出为1,此时仅由,此时仅由TR0控制与门的开启,与门输出控制与门的开启,与门输出1时,控制开关接通,计数开始;时,控制开关接通,计数开始;当当GATE=1时时,由外中断引,由外中断引脚信号控制或门的输出,此时控制脚信号控制或门的输出,此时控制与门的开启由外中断引脚与门的开启由外中断引脚信号和信号和TR0共同控制共同控制。当。当TR0=1时,外中断引脚信号引脚的时,外中断引脚信号引脚的高电平启动计数高电平启动计数,外中断引脚信号引脚的,外中断引脚信号引脚的低电平停止计数低电平停止计数。这种方式常用来测量外中断引脚上正脉冲的宽度。这种方式常用来测量外中断引脚上正脉冲的宽度。34 二、方式二、方式1 方式方式1的计数位数是的计数位数是16位,由位,由TL0作为低作为低8位、位、TH0作为高作为高8位,组成了位,组成了16位加位加1计数器计数器。计数个数与计数初值的关系为:计数个数与计数初值的关系为:35 三、方式三、方式2 方式方式2为自动重装初值的为自动重装初值的8位计数方式。位计数方式。工作方式2特别适合于用作较精确的脉冲信号发生器。计数个数与计数初值的关系为计数个数与计数初值的关系为:36 四、方式四、方式3 方式方式3只适用于定时只适用于定时/计数器计数器T0,定时器定时器T1处于方式处于方式3时相当时相当于于TR1=0,停止计数。,停止计数。工作方式工作方式3将将T0分成为两个独立的分成为两个独立的8位计数器位计数器TL0和和TH0。37 5.3.4 定时定时/计数器用于外部中断扩展计数器用于外部中断扩展 扩展方法是,将定时扩展方法是,将定时/计数器设置为计数器方式,计数初值计数器设置为计数器方式,计数初值设定为满程,将待扩展的外部中断源接到定时设定为满程,将待扩展的外部中断源接到定时/计数器的外部计数器的外部计数引脚。从该引脚输入一个下降沿信号,计数器加计数引脚。从该引脚输入一个下降沿信号,计数器加1后便产后便产生定时生定时/计数器溢出中断。计数器溢出中断。例如,利用例如,利用T0扩展一个外部中断源。将扩展一个外部中断源。将T0设置为计数器方式,设置为计数器方式,按方式按方式2工作,工作,TH0、TL0的初值均为的初值均为0FFH,T0允许中断,允许中断,CPU开放中断。开放中断。其初始化程序如下:其初始化程序如下:MOV TMOD,#06H ;置;置T0为计数器方式为计数器方式2 MOV TL0,#0FFH ;置计数初值;置计数初值 MOV TH0,#0FFH SETB TR0 ;启动;启动T0工作工作 SETB EA ;CPU开中断开中断 SETB ET0 ;允许;允许T0中断中断 38 5.3.5 定时定时/计数器应用举例计数器应用举例 初始化程序应完成如下工作:初始化程序应完成如下工作:n对对TMOD赋值,以确定赋值,以确定T0和和T1的工作方式。的工作方式。n计算初值计算初值,并将其写入并将其写入TH0、TL0或或TH1、TL1。n中断方式时,则对中断方式时,则对IE赋值,开放中断。赋值,开放中断。n使使TR0或或TR1置位,启动定时置位,启动定时/计数器定时或计数。计数器定时或计数。39 例例 利用定时利用定时/计数器计数器T0的方式的方式1,产生,产生10ms的定时,的定时,并使并使P1.0引脚上输出周期为引脚上输出周期为20ms的方波,采用中的方波,采用中断方式,设系统时钟频率为断方式,设系统时钟频率为12 MHz。解:解:1、计算计数初值、计算计数初值X:由于晶振为由于晶振为12 MHz,所以机器周期,所以机器周期Tcy为为1S。所以:所以:Nt/Tcy 10103/110610000X655361000055536D8F0H即应将即应将D8H送入送入TH0中,中,F0H送入送入TL0中中 2、求、求T0的方式控制字的方式控制字TMOD:M1M0=01,GATE=0,C/T=0,可取方式控制,可取方式控制字为字为01H;40 ORG 0000H LJMP MAIN ;跳转到主程序 ORG 000BH ;T0的中断入口地址 LJMP DVT0 ;转向中断服务程序 ORG 0100H MAIN:MOV TMOD,#01H ;置T0工作于方式1 MOV TH0,#0D8H ;装入计数初值 MOV TL0,#0F0H SETB ET0 ;T0开中断 SETB EA ;CPU开中断 SETB TR0 ;启动T0 SJMP$;等待中断 DVT0:CPL P1.0 ;P1.0取反输出 MOV TH0,#0D8H ;重新装入计数值 MOV TL0,#0F0H RETI ;中断返回 END41思考题及习题思考题及习题1、80C51有几个中断源?各中断标志是如何产生的?又是如何有几个中断源?各中断标志是如何产生的?又是如何复位的?复位的?CPU响应各中断时,其中断入口地址是多少?响应各中断时,其中断入口地址是多少?2、某系统有三个外部中断源、某系统有三个外部中断源1、2、3,当某一中断源变低电平,当某一中断源变低电平时便要求时便要求CPU处理,它们的优先处理次序由高到低为处理,它们的优先处理次序由高到低为3、2、1,处理程序的入口地址分别为,处理程序的入口地址分别为2000H、2100H、2200H。试编。试编写主程序及中断服务程序(转至相应的入口即可)。写主程序及中断服务程序(转至相应的入口即可)。3、外部中断源有电平触发和边沿触发两种触发方式,这两种触、外部中断源有电平触发和边沿触发两种触发方式,这两种触发方式所产生的中断过程有何不同?怎样设定?发方式所产生的中断过程有何不同?怎样设定?4、定时、定时/计数器工作于定时和计数方式时有何异同点?计数器工作于定时和计数方式时有何异同点?5、定时、定时/计数器的计数器的4种工作方式各有何特点?种工作方式各有何特点?6、要求定时、要求定时/计数器的运行控制完全由计数器的运行控制完全由TR1、TR0确定和完全确定和完全由、高低电平控制时,其初始化编程应作何处理?由、高低电平控制时,其初始化编程应作何处理?427、当定时、当定时/计数器计数器T0用作方式用作方式3时,定时时,定时/计数器计数器T1可以工作在可以工作在何种方式下?如何控制何种方式下?如何控制T1的开启和关闭?的开启和关闭?8、利用定时、利用定时/计数器计数器T0从从P1.0输出周期为输出周期为1s,脉宽为,脉宽为20ms的的正脉冲信号,晶振频率为正脉冲信号,晶振频率为12MHz。试设计程序。试设计程序。9、要求从、要求从P1.1引脚输出引脚输出1000Hz方波,晶振频率为方波,晶振频率为12MHz。试。试设计程序。设计程序。10、试用定时、试用定时/计数器计数器T1对外部事件计数。要求每计数对外部事件计数。要求每计数100,就,就将将T1改成定时方式,控制改成定时方式,控制P1.7输出一个脉宽为输出一个脉宽为10ms的正脉冲,的正脉冲,然后又转为计数方式,如此反复循环。设晶振频率为然后又转为计数方式,如此反复循环。设晶振频率为12MHz。11、利用定时、利用定时/计数器计数器T0产生定时时钟产生定时时钟,由由P1口控制口控制8个指示灯。个指示灯。编一个程序编一个程序,使使8个指示灯依次一个一个闪动,闪动频率为个指示灯依次一个一个闪动,闪动频率为20次次/秒秒(8个灯依次亮一遍为一个周期个灯依次亮一遍为一个周期)。12、若晶振频率为、若晶振频率为12MHz,如何用,如何用T0来测量来测量201s之间的方波之间的方波周期?又如何测量频率为周期?又如何测量频率为0.5MHz左右的脉冲频率?左右的脉冲频率?43