1《单片机原理及应用》第五章MCS-51单片机中断系统与定时/计数器1、中断的基本概念,中断系统结构,中断响应过程,中断初始化程序及中断服务程序的编写;2、定时/计数器结构和工作原理,定时/计数器初始化编程。5.1中断系统5.2定时/计数器本章主要内容25.1中断系统课题引入CPU与外设之间交换信息的方式有四种:1)无条件传送2)查询传送3)中断传送4)DMA传送35.1中断系统一、中断的基本概念同学提问教师讲课教师答疑教师讲课中断示意图1、日常生活中断的例子教师讲课过程中,同学遇有疑问,随时向老师提问,教师终止当前的讲课,解答学生疑问后再继续之前的讲课。4中断申请主程序中断服务程序返回中断示意图2、计算机的中断概念中断是指由于某种随机事件的发生,计算机暂停现行程序的运行,转去执行另一程序,以处理发生的事件,处理完毕后又自动返回原来的程序继续运行。能引起中断的事件称为中断源。CPU现行运行的程序称为主程序。处理随机事件的程序称为中断服务子程序。53、中断技术的优点1)分时操作。CPU可以分时为多个I/O设备服务,提高了计算机的利用率;2)实时响应。CPU能够及时处理应用系统的随机事件,系统的实时性大大增强;3)可靠性高。CPU具有处理设备故障及掉电等突发性事件的能力,从而使系统可靠性提高。6二、MCS-51的中断系统1)中断请求信号的产生(中断源如何申请中断?)2)CPU如何响应?(如何知道有中断请求?是否有求必应?响应后的处理过程?)3)中断优先权问题;4)中断的具体服务;5)中断服务完毕,如何返回原程序。中断系统应解决如下问题:7二、MCS-51的中断系统80C51的中断系统有5个中断源,2个优先级,可实现二级中断嵌套,其结构如下图所示。IE0TCONSCONINT0IT0=0IT0=1INT1IT1=0IT1=1TF0IE1TF1T0T1TIRITXDRXDESET0EX0EX1ET1EA自然优先级矢量地址高级中断请求自然优先级矢量地址低级中断请求PX0PT0PX1PT1PSIEIP中断标志位中断源允许总允许中断优先级81、中断源1)INT0(P3.2)。可由IT0(TCON.0)选择其为低电平有效还是下降沿有效。当CPU检测到P3.2引脚上出现有效的中断信号时,中断标志IE0(TCON.1)置1,向CPU申请中断。2)INT1(P3.3)。可由IT1(TCON.2)选择其为低电平有效还是下降沿有效。当CPU检测到P3.3引脚上出现有效的中断信号时,中断标志IE1(TCON.3)置1,向CPU申请中断。5个中断源包含2个外部中断和3个内部中断。2个外部中断——91、中断源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申请中断。3个内部中断——102、中断请求标志IT0:外部中断0触发方式控制位。当IT0=0时,为电平触发方式。当IT0=1时,为边沿触发方式(下降沿有效)。IE0:外部中断0中断请求标志位。IT1:外部中断1触发方式控制位。IE1:外部中断1中断请求标志位。TF0:定时/计数器T0溢出中断请求标志位。TF1:定时/计数器T1溢出中断请求标志位。1)TCON的中断标志TCON(88H)TF1TR1TF0TR0IE1IT1IE0IT011注意若外部中断定义为电平触发方式:中断标志位的状态随CPU在每个机器周期采样到的外部中断输入引脚的电平变化而变化,这样能提高CPU对外部中断请求的响应速度。但外部中断源若有请求,必须把有效的低电平保持到请求获得响应时为止,不然就会漏掉;而在中断服务程序结束之前,中断源又必须撤消其有效的低电平,否则中断返回之后将再次产生中断。12注意若外部中断定义为边沿触发方式:在相继连续的两次采样中,一个周期采样到外部中断输入为高电平,下一个周期采样到为低电平,则在IE0或IE1中将锁存一个逻辑1。即便是CPU暂时不能响应,中断申请标志也不会丢失,直到CPU响应此中断时才清零。这样,为保证下降沿能被可靠地采样到,外中断引脚上的高低电平(负脉冲的宽度)均至少要保持一个机器周期(若晶振为12MHz时,为1微秒)。132、中断请求标志RI:串行口接收中断标志位。当允许串行口接收数据时,每接收完一个串行帧,由硬件置位RI。RI必须由软件清除。TI:串行口发送中断标志位。当CPU将一个发送数据写入串行口发送缓冲器时,就启动了发送过程。每发送完一个串行帧,由硬件置位TI。CPU响应中断时,不能自动清除TI,TI必须由软件清除。2)SCON的中断标志SCON(98H)TIRI143、中断的控制EX0:外部中断0允许位;ET0:定时/计数器T0中断允许位;EX1:外部中断0允许位;ET1:定时/计数器T1中断允许位;ES:串行口中断允许位;EA:CPU中断允许(总允许)位。1)中断允许控制IE(A8H)EAESET1EX1ET0EX0CPU对中断系统所有中断以及某个中断源的开放和屏蔽是由中断允许寄存器IE控制的。153、中断的控制PX0:外部中断0优先级设置位;PT0:定时/计数器T0优先级设置位;PX1:外部中断1优先级设置位;PT1:定时/计数器T1优先级设置位;PS:串行口优先级设置位。2)中断优先级控制IP(B8H)PSPT1PX1PT0PX080C51单片机有两个中断优先级,可实现二级中断服务嵌套,由中断优先级寄存器IP中的相应位的状态来规定每个中断源的优先级。16注意同一优先级中的中断申请不止一个时,则有中断优先权排队问题。同一优先级的中断优先权排队,由中断系统硬件确定的自然优先级形成,其排列如所示:INT0INT1T0T1串口IE0TF0IE1TF1TISI中断源中断标志位中断入口地址0023H000BH0003H0013H001BH自然优先级高低17CPU同时接收到几个中断时,首先响应优先级别最高的中断请求。正在进行的中断过程不能被新的同级或低优先级的中断请求所中断。正在进行的低优先级中断服务,能被高优先级中断请求所中断。MCS-51单片机的中断优先级有三条原则:18三、中断处理过程1、中断响应的条件中断源有中断请求;此中断源的中断允许位为1;CPU开中断(即EA=1)。同时满足时,CPU才有可能响应中断。CPU执行程序过程中,在每个机器周期的S5P2期间,中断系统对各个中断源进行采样。这些采样值在下一个机器周期内按优先级和内部顺序被依次查询。如果某个中断标志在上一个机器周期的S5P2时被置成了1,那么它将于现在的查询周期中及时被发现。接着CPU便执行一条由中断系统提供的硬件LCALL指令,转向被称作中断向量的特定地址单元,进入相应的中断服务程序。19若由于上述条件的阻碍中断未能得到响应,当条件消失时该中断标志却已不再有效,那么该中断将不被响应。遇以下任一条件,硬件将受阻,不产生LCALL指令:CPU正在处理同级或高优先级中断;当前查询的机器周期不是所执行指令的最后一个机器周期,即在完成所执行指令前,不会响应中断;正在执行的指令为RET、RETI或任何访问IE或IP寄存器的指令,即只有在这些指令后面至少再执行一条指令时才能接受中断请求。注意202、中断响应时间S1M1S2S3S4S5S6S1M2S2S3S4S5S6S1M3S2S3S4S5S6S1M4S2S3S4S5S6S1M5S2S3S4S5S6中断有效标志锁存标志查询保护断点,长调用至入口中断服务某中断的响应时序图:若M1周期的S5P2前某中断生效,在S5P2期间其中断请求被锁存到相应的标志位中去;M2恰逢指令的最后一个机器周期,且该指令不是RETI或访问IE、IP的指令。于是,M3和M4便可以执行硬件LCALL指令,M5周期将进入了中断服务程序;80C51的中断响应时间(从标志置1到进入相应的中断服务),至少要3个完整的机器周期;213、中断响应过程将相应的优先级状态触发器置1(以阻断后来的同级或低级的中断请求)。执行一条硬件LCALL指令,即把程序计数器PC的内容压入堆栈保存,再将相应的中断服务程序的入口地址送入PC。执行中断服务程序。中断响应过程的前两步是由中断系统内部自动完成的,而中断服务程序则要由用户编写程序来完成。224、中断返回RETI指令的具体功能是:将中断响应时压入堆栈保存的断点地址从栈顶弹出送回PC,CPU从原来中断的地方继续执行程序;将相应中断优先级状态触发器清0,通知中断系统,中断服务程序已执行完毕。不能用RET指令代替RETI指令。在中断服务程序中PUSH指令与POP指令必须成对使用,否则不能正确返回断点。注意23四、应用1、主程序部分1)给堆栈指针SP赋值,设置一个深度适宜的堆栈;2)如为外部中断,定义触发方式;3)根据需要给IP赋值,定义中断优先级;4)给IE赋值,开放中断,即置位EA和其它需要的中断允许位;5)安排好等待中断过程中主程序应做的操作。具体设计过程:(包括主程序和中断服务程序的设计步骤)242、中断服务程序部分1)在相应的中断入口地址单元设置一条跳转指令,使程序转移到中断服务程序的实际入口处;2)根据需要保护现场;3)若为电平触发的外部中断,应有中断信号撤除操作;4)安排中断服务所做的操作;5)恢复现场;6)中断返回。25SETBIT0;SETBPX0;SETBEA;SETBEX0;例1若规定外部中断0为电平触发方式,高优先级,试写出有关的初始化程序。解:1)设触发方式2)设优先级3)开中断用位操作指令2、应用举例用字节操作指令MOVTCON,#01HMOVIP,#01HORLIE,#81H26ORG0000H;LJMPMAIN;主程序转至MAIN处ORG0013H;LJMPINT;中断服务程序转至INT处ORG0030HMAIN:MOVSP,#6FHSETBIT1;边沿触发CLRPX1;设为低优先级SETBEA;开总中断SETBEX1;允许外中断1中断MOVB,#01H;设B的初值HALT:SJMPHALT;暂停等待中断INT:MOVA,B;A←BRLA;左环移一位MOVB,A;回送RETI;中断返回例2若规定外部中断1为边沿触发方式,低优先级,在中断服务程序中将寄存器B的内容左环移一位,B的初值设为01H。试编写主程序与中断服务程序。解:返回275.2定时/计数器课题引入1、定时器/计数器的功能是什么?单片机为何要提供硬件定时/计数器?2、实现定时/计数功能的方法有哪些?1)软件定时2)时基电路定时3)可编程芯片定时287070定时器T0TH0TL08CH8AH7070定时器T1TH1TL18DH8BH工作方式启动工作方式TCON(88H)控制寄存器TMOD(89H)方式寄存器溢出溢出启动CPU中断内部总线T1(P3.5)T0(P3.4)各部分如何协调工作完成定时或计数功能?一、结构及原理1、结构29一、结构及原理2、工作原理(T0为例)1)方式选择部分:选择不同的计数脉冲2)计数部分:对脉冲进行加一计数3)控制启停部分:控制计数启动/停止定时方式:对内部机器周期计数计数方式:对外部引脚P3.4输入脉冲计数TL0(低8位)+TH0(高8位)→TF0(溢出位)TR0(启动位)=130二、方式和控制寄存器1、TMOD方式寄存器T1T0TMOD(89H)GATEC/TM1M0GATEC/TM1M0GATE:门控位M1M0:工作方式设置位GATE=0时,只要用软件使TCON中的TR0或TR1为1,就可以启动定时/计数器工作;GATA=1时,要用软件使TR0或TR1为1,同时外部中断引脚或也为高电平时,才能启动定时/计数器工作。定时/计数器有四种工作方式,由M1M0进行设置。C/T:定时/计数