《80C51的中断系统及定时计数器》由会员分享,可在线阅读,更多相关《80C51的中断系统及定时计数器(43页珍藏版)》请在金锄头文库上搜索。
1、第5章 80C51的中断系统及定时/计数器 5.1 80C51的中断系统 5.2 80C51的中断处理过程 5.3 80C51的定时/计数器15.1 80C51的中断系统统 5.1.1 80C51的中断系统结统结 构 一、中断的概念计计算机具有实时处实时处 理能力,能对对外界发发生的事 件进进行及时处时处 理,这这是依靠它们们的中断系统统来实现实现 的。CPU在处处理某一事件A时时,发发生了另一事件B请请 求CPU迅速去处处理(中断发发生);CPU暂时暂时 中断当前 的工作,转转去处处理事件B(中断响应应和中断服务务); 待CPU将事件B处处理完毕毕后,再回到原来事件A被中断 的地方继续处继续
2、处 理事件A(中断返回),这这一过过程称为为 中断 。2引起CPU中断的根源,称为中断源。中断源向CPU提出 的中断请求。CPU暂时中断原来的事务A,转去处理事件B 。对事件B处理完毕后,再回到原来被中断的地方(即断点 ),称为中断返回。实现上述中断功能的部件称为中断系 统(中断机构)。3随着计算机技术的应用,人们发现中断 技术不仅解决了快速主机与慢速I/O设备的数 据传送问题,而且还具有如下优点:n分时操作。CPU可以分时为多个I/O设备 服务,提高了计算机的利用率;n实时响应。CPU能够及时处理应用系统的 随机事件,系统的实时性大大增强;n可靠性高。CPU具有处理设备故障及掉电 等突发性事
3、件的能力,从而使系统可靠性提 高。4二、80C51中断系统的结构80C51的中断系统有5个中断源,2个优 先级,可实现二级中断嵌套 。55.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),片内定时/
4、计数器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),外
5、部中断0中断请求标志位。 IT1(TCON.2),外部中断1触发方式控制位。 IE1(TCON.3),外部中断1中断请求标志位。 TF0(TCON.5),定时/计数器T0溢出中断请求标志位。 TF1(TCON.7),定时/计数器T1溢出中断请求标志位。 72、SCON的中断标志RI(SCON.0),串行口接收中断标志位。当允 许串行口接收数据时,每接收完一个串行帧,由 硬件置位RI。同样,RI必须由软件清除。 TI(SCON.1),串行口发送中断标志位。当 CPU将一个发送数据写入串行口发送缓冲器时, 就启动了发送过程。每发送完一个串行帧,由硬 件置位TI。CPU响应中断时,不能自动清除TI,
6、 TI必须由软件清除。 8一、中断允许控制CPU对中断系统所有中断以及某个中断源的开放和屏蔽 是由中断允许寄存器IE控制的。5.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(
7、IP.0),外部中断0优先级设定位;nPT0(IP.1),定时/计数器T0优先级设定位;nPX1(IP.2),外部中断0优先级设定位;nPT1(IP.3),定时/计数器T1优先级设定位;nPS (IP.4),串行口优先级设定位。10同一优先级中的中断申请不止一个时,则有 中断优先权排队问题。同一优先级的中断优先权排队 ,由中断系统硬件确定的自然优先级形成,其排列如 所示:1180C51单片机的中断优先级有三条原则:nCPU同时接收到几个中断时,首先响应优先级别最 高的中断请求。n正在进行的中断过程不能被新的同级或低优先级的 中断请求所中断。n正在进行的低优先级中断服务,能被高优先级中断 请求所
8、中断。为了实现上述后两条原则,中断系统内部设有两 个用户不能寻址的优先级状态触发器。其中一个置1, 表示正在响应高优先级的中断,它将阻断后来所有的 中断请求;另一个置1,表示正在响应低优先级中断, 它将阻断后来所有的低优先级中断请求。125.2 80C51单片机中断处理过程 一、中断响应条件 CPU响应中断的条件是:n 中断源有中断请求;n 此中断源的中断允许位为1;n CPU开中断(即EA=1)。 同时满足时,CPU才有可能响应中断。5.2.1 中断响应应条件和时间时间 13CPU执行程序过程中,在每个机器周 期的S5P2期间,中断系统对各个中断源进 行采样。这些采样值在下一个机器周期内按
9、优先级和内部顺序被依次查询。如果某个中断标志在上一个机器周期 的S5P2时被置成了1,那么它将于现在的查 询周期中及时被发现。接着CPU便执行一 条由中断系统提供的硬件LCALL指令,转 向被称作中断向量的特定地址单元,进入相 应的中断服务程序。 14遇以下任一条件,硬件将受阻,不产生LCALL指令 :nCPU正在处理同级或高优先级中断;n当前查询的机器周期不是所执行指令的最后一个机 器周期。即在完成所执行指令前,不会响应中断,从而 保证指令在执行过程中不被打断;n正在执行的指令为RET、RETI或任何访问IE或IP寄 存器的指令。即只有在这些指令后面至少再执行一条指 令时才能接受中断请求。若
10、由于上述条件的阻碍中断未能得到响应,当条 件消失时该中断标志却已不再有效,那么该中断将不被 响应。就是说,中断标志曾经有效,但未获响应,查询 过程在下个机器周期将重新进行。 15二、中断响应时间 某中断的响应时序如图:n若M1周期的S5P2前某中断生效,在S5P2期间其中 断请求被锁存到相应的标志位中去;M2恰逢指令的 最后一个机器周期,且该指令不是RETI或访问IE、 IP的指令。于是,M3和M4便可以执行硬件LCALL指 令,M5周期将进入了中断服务程序。n80C51的中断响应时间(从标志置1到进入相应的 中断服务),至少要3个完整的机器周期。 16n将相应的优先级状态触发器置1(以阻断
11、后来的同级或低级的中断请求)。n执行一条硬件LCALL指令,即把程序计 数器PC的内容压入堆栈保存,再将相应的 中断服务程序的入口地址送入PC。n执行中断服务程序。中断响应过程的前两步是由中断系统内 部自动完成的,而中断服务程序则要由用 户编写程序来完成。 5.2.2 中断响应过应过 程 175.2.3 中断返回RETI指令的具体功能是:n将中断响应时压入堆栈保存的断点地址从栈 顶弹出送回PC,CPU从原来中断的地方继续 执行程序;n 将相应中断优先级状态触发器清0,通知中 断系统,中断服务程序已执行完毕。注意,不能用RET指令代替RETI指令。 在中断服务程序中PUSH指令与POP指令必须
12、成对使用,否则不能正确返回断点 。18若外部中断定义为电平触发方式,中断标志 位的状态随CPU在每个机器周期采样到的外部中断 输入引脚的电平变化而变化,这样能提高CPU对外 部中断请求的响应速度。但外部中断源若有请求, 必须把有效的低电平保持到请求获得响应时为止, 不然就会漏掉;而在中断服务程序结束之前,中断 源又必须撤消其有效的低电平,否则中断返回之后 将再次产生中断。 电平触发方式适合于外部中断输入以低电平输 入且中断服务程序能清除外部中断请求源的情况。 例如,并行接口芯片8255的中断请求线在接受读 或写操作后即被复位,因此,以其去请求电平触发 方式的中断比较方便。19若外部中断定义为边
13、沿触发方式,在相继连续的 两次采样中,一个周期采样到外部中断输入为高电平 ,下一个周期采样到为低电平,则在IE0或IE1中将锁 存一个逻辑1。即便是CPU暂时不能响应,中断申请 标志也不会丢失,直到CPU响应此中断时才清零。这 样,为保证下降沿能被可靠地采样到,外中断引脚上 的高低电平(负脉冲的宽度)均至少要保持一个机器 周期(若晶振为12MHz时,为1微秒)。边沿触发方式适合于以负脉冲形式输入的外部中 断请求,如ADC0809的转换结束标志信号EOC为正 脉冲,经反相后就可以作为80C51的中断输入。205.2.4 中断程序举举例 21ORG 0000H START:LJMP MAIN ;跳
14、转到主程序ORG 0003HLJMP INTO ;转向中断服务程序ORG 0030H ;主程序MAIN:CLR IT0 ;设为电平触发方式SETB EA ;CPU开放中断SETB EX0 ;允许中断MOV DPTR,#1000H ;设置数据区地址指针 ORG 0200H ;中断服务程序INT0:PUSH PSW ;保护现场PUSH ACCCLR P3.0 ;由P3.0输出0NOPNOPSETB P3.0 ;由P3.0输出1,撤除 MOV A,P1 ;输入数据MOVX DPTR,A ;存入数据存储器INC DPTR ;修改数据指针,指向下一个单元 POP ACC ;恢复现场POP PSWRETI
15、 ;中断返回22例 多外部中断源的系统示例。设有5个外部中断源,中断优先级排队顺序为: XI0、XI1、XI2、XI3、XI4。试设计它们与80C51单 片机的接口。23ORG 0003HLJMP INSE0 ;转外部中断0服务程序入口ORG 0013HLJMP INSE1 ;转外部中断1服务程序入口 INSE0: PUSH PSW ;XI0中断服务程序PUSH ACC POP ACCPOP PSWRETI 24INSE1:PUSH PSW ;中断服务程序PUSH ACCJB 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 ACCPOP PSWRETIDV1: ;XI1中