51单片机中断原理.ppt

上传人:夺命阿水 文档编号:236069 上传时间:2023-03-10 格式:PPT 页数:34 大小:653KB
返回 下载 相关 举报
51单片机中断原理.ppt_第1页
第1页 / 共34页
51单片机中断原理.ppt_第2页
第2页 / 共34页
51单片机中断原理.ppt_第3页
第3页 / 共34页
51单片机中断原理.ppt_第4页
第4页 / 共34页
51单片机中断原理.ppt_第5页
第5页 / 共34页
点击查看更多>>
资源描述

《51单片机中断原理.ppt》由会员分享,可在线阅读,更多相关《51单片机中断原理.ppt(34页珍藏版)》请在课桌文档上搜索。

1、单元七 MCS-51单片机的中断,一、中断的概述 二、MCS-51中断系统三、中断系统的应用,5.1 中 断 的 概 述,1.中断 中断是指计算机在执行某一程序的过程中,由于计算机系统内、外的某种原因,而必须中止原程序的执行,转去执行相应的处理程序,待处理结束之后,再回来继续执行被中止的原程序的过程。,采用了中断技术后的计算机,可以解决CPU与外设之间速度匹配的问题,使计算机可以及时处理系统中许多随机的参数和信息,同时,它也提高了计算机处理故障与应变的能力。“中断”与“查询”相比:执行效率 实时性,2.中断源 中断源是指在计算机系统中可以向CPU发出中断请求的来源。通常有I/O设备、实时控制系

2、统中的随机参数和信息故障源等。,3.中断优先级 中断优先级越高,则响应优先权就越高。当CPU正在执行中断服务程序时,又有中断优先级更高的中断申请产生,这时CPU就会暂停当前的中断服务转而处理高级中断申请,待高级中断处理程序完毕再返回原中断程序断点处继续执行,这一过程称为“中断嵌套”。,4.中断响应的一般过程(1)在每条指令结束后,系统都自动检测中断请求信号,如果有中断请求,且CPU处于开中断状态下,则响应中断。(2)保护现场,在保护现场前,一般要关中断,以防止现场被破坏。保护现场一般是用堆栈指令将原程序中用到的寄存器推入堆栈。,(3)中断服务,即为相应的中断源服务。(4)恢复现场,用堆栈指令将

3、保护在堆栈中的数据弹出来,在恢复现场前要关中断,以防止现场被破坏。在恢复现场后应及时开中断。(5)返回,此时 CPU将推入到堆栈的断点地址弹回到程序计数器,从而使CPU继续执行刚才被中断的程序。,5.2 MCS-51中断系统,图5.1 MCS-51中断系统结构框图,5.2.1 中断源,表 5.1 8051 中 断 源,中断标志(Flag)IE0:外部中断0中断标志TF0:定时器/计数器0中断标志IE1:外部中断1中断标志TF1:定时器/计数器1中断标志TI:串行口发送中断标志RI:串行口接收中断标志,1.定时器控制寄存器TCON的格式(88H),(MSB),(LSB),IT0:外部中断0触发方

4、式选择位 0:低电平触发 1:负跳变触发IE0:外部中断0中断请求标志IT1、IE1 类似 IT0、IE0TR0:定时/计数器0运行控制位 0:停止 1:运行TF1:定时/计数器0中断请求标志位TR1、TF1 类似 TR0、TF0,2.特殊功能寄存器SCON的格式(98H),SM0和SM1:串行口工作方式选择位SM2:多机通信使能位REN:接收允许位TB8:发送数据位8RB8:接收数据位8TI:串行口发送中断请求标志RI:串行口接收中断请求标志,MSB,LSB,5.2.2 中断控制,1.中断允许控制 MCS-51单片机有 5个(8052有 6个)中断源,为了使每个中断源都能独立地被允许或禁止,

5、以便用户能灵活使用,CPU内部在每个中断信号的通道中设置了一个中断允许触发器,它控制CPU能否响应中断。只有对应的中断允许触发器被使能(置“1”),相应的中断才能得到相应。,EX0:外部中断0允许位ET0:定时器/计数器0中断允许位EX1:外部中断1允许位ET1:定时器/计数器1中断允许位ES:串行口中断允许位EA:中断总允许位,(MSB),(LSB),中断允许控制寄存器IE(0A8H),2.中断优先级控制寄存器IP(0B8H),(MSB),(LSB),PX0:外部中断0允许位PT0:定时器/计数器0中断允许位PX1:外部中断1允许位PT1:定时器/计数器1中断允许位PS:串行口中断允许位,当

6、两个以上的中断源同时提出申请时,CPU到底相应哪个中断呢?中断响应遵循两条规则:(1)低优先级中断可以被高优先级中断所中断,反之不能;(2)一种中断(不论哪个优先级)一旦得到响应,与它同级的中断不能再中断它。,表 5.2 同级内第二优先级次序,当同时收到处于同一优先级的多个中断请求时,哪一个中断能得到响应,取决于“内部查询次序”,相当于在每个优先级中,还有一个“内部优先级”,如下表所示:,例如,某软件中对寄存器IE、IP设置如下:MOV IE,8FH MOV IP,06H 则此时该系统中:CPU中断允许;允许外部中断 0、外部中断 1、定时器/计数器 0、定时器/计数器1提出的中断申请;允许中

7、断源的中断优先次序为:定时器/计数器 0外部中断 1外部中断 0定时器/计数器 1。,5.2.3 中断响应The interrupt request flags are sampled in each machine cycle.The sampled flags are polled during the following machine cycle.If one of the flags was in a set condition in the preceding cycle,the polling cycle will find it and the interrupt contro

8、ller will cause the CPU to branch to the vector address of the appropriate service routine by generating an internal LCALL.,中断标志检测与响应过程,5.2.3.1 中断响应的阻断条件 在EA1且相应的中断允许位也为1的情况下,检测到的最高级的中断请求将会得到相应。但此时如果发生下列三种情况中的任何一种,中断响应的过程将被阻断:(1)同级或高优先级的中断已在进行中;(2)当前的机器周期还不是正在执行指令的最后一个机器周期(换言之,正在执行的指令完成前,任何中断请求都得不到响

9、应);(3)正在执行的是一条 RETI 或者访问特殊功能寄存器 IE或 IP的指令(换言之,在 RETI或读写 IE或 IP之后,不会马上响应中断请求,而至少执行一条其它指令之后才会响应)。,当上述阻断条件存在时,中断不能被相应,且丢弃查询结果。若阻断条件结束时,中断标志已经消失,则这个被拖延了的中断请求可能不会再得到响应。在单一外部中断的系统里(即不考虑上述阻断条件中断的第一个条件),外部中断响应时间总是在38个机器周期之间。,2.单片机一旦响应中断请求,由硬件完成以下功能:(1)根据响应的中断源的中断优先级,使相应的优先级状态触发器置 1;(2)执行硬件中断服务子程序调用,并把当前程序计数

10、器PC的内容压入堆栈;(3)清除相应的中断请求标志位(串行口中断请求标志 RI和 TI除外);(4)把被响应的中断源所对应的中断服务程序的入口地址(中断矢量)送入PC,从而转入相应的中断服务程序。,中断响应过程,相当于执行了一条隐含的调用指令(或称隐指令)LCALL。例如当TF0被置1且得到中断响应时,CPU就自动的执行一条隐指令“LCALL 000BH”。应当注意,在中断服务子程序的调用过程中,仅仅保存了PC的信息,其余的现场信息(如寄存器的值等)都要由编程人员通过软件来进行保护。,表 5.3 中断服务程序入口地址表,例如,现有外部中断 1 提出申请,且主程序中有R0、R1、DPTR、累加器

11、A需保护,则编制程序应为:,ORG 0000H AJMP MAIN ORG 0013H LJMP INT1 ORG 0100H MAIN:;主程序 ORG 1000H,INT1:PUSH ACC;中断服务程序 PUSH DPH;若有更高级中断,PUSH DPL;应先关闭EA PUSH R0;待现场保护完成后 PUSH R1;再打开EA POP R1;恢复现场时相同 POP R0 POP DPL POP DPH POP ACC RETI,编程中应注意:(1)在 0000H放一条跳转到主程序的跳转指令,这是因为 MCS-51单片机复位后,PC的内容变为 0000H,程序从 0000H 开始执行,紧

12、接着 0003H是中断程序入口地址,故在此中间只能插入一条转移指令;(2)响应中断时,先自动执行一条隐指令“LCALL 0013H”,而 0013H至 001BH(定时器 1 溢出中断入口地址)之间可利用的存储单元不够,故放一条无条件转移指令。(3)在中断服务程序的末尾,必须安排一条中断返回指令RETI,使程序自动返回主程序。,5.3 中断系统的应用,例 1 单步操作的中断实现。把一个外部中断(设为INT0)设置为电平激活方式。其中断服务程序的末尾写上如下几条指令:JNB P3.2,$;在INT0变高前,原地等待(死循环)JB P3.2,$;在 INT0变低前,原地等待(死循环)RETI;返回

13、并执行一条指令,现在,若INT0保持低电平,且允许INT0中断,则CPU就进入外部中断 0 服务程序,由于有上述几条指令,它就会停在 JNB处,原地等待。当INT0 端出现一个正脉冲(由低到高,再到低)时,程序就会往下执行,执行RETI后,将返回主程序,往下执行一条指令,然后又立即响应中断,以等待INT0端出现的下一个正脉冲。这样在INT0端每出现一个正脉冲,主程序就执行一条指令,实现了单步执行的目的,要注意的是,这个正脉冲的高电平持续时间不小于 2 个周期,以确保 CPU能采集到高电平值。,例 2 多中断源。MCS-51 单片机有两个外部中断输入端,当有 2 个以上中断源时,它的中断输入端就

14、不够了。此时,可以将定时器/计数器作为外部中断源使用,也可以采用中断与查询相结合的方法来实现。可以使每个中断源都接在同一个外部中断输入端上,同时利用输入口线作为多中断源情况下各中断源的识别线。,图 5.6 多中断源,ORG 0003H LJMP INT0INT0:PUSH PSW PUSH ACC JB P0.7,DV1 JB P0.6,DV2 JB P0.5,DV3 JB P0.4,DV4GOBACK:POP ACC POP PSW RETI DV1:;装置1中断服务程序,AJMP GOBACKDV2:;装置2中断服务程序 AJMP GOBACKDV3:;装置3中断服务程序 AJMP GOBACKDV4:;装置4中断服务程序 AJMP GOBACK,

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 在线阅读 > 生活休闲


备案号:宁ICP备20000045号-1

经营许可证:宁B2-20210002

宁公网安备 64010402000986号