第5章-中断.ppt





《第5章-中断.ppt》由会员分享,可在线阅读,更多相关《第5章-中断.ppt(57页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、第6章 51单片机的中断系统 主要内容主要内容 中断的基本概念中断的基本概念 中断的系统结构中断的系统结构 中断的响应过程中断的响应过程 中断的的应用编程中断的的应用编程第6章 51单片机的中断系统 在在CPU和外设交换信息时,存在着和外设交换信息时,存在着快速快速CPU和和慢速慢速外设间外设间的矛盾,机器内部有时也可能出现的矛盾,机器内部有时也可能出现突发事件突发事件,为,为此,计算机中通常采用中断技术。此,计算机中通常采用中断技术。中断中断 CPU和外设并行工作,当外设数据准备好和外设并行工作,当外设数据准备好(或有某种突发事或有某种突发事件发生件发生)时向时向CPU提出请求,提出请求,C
2、PU暂停正在执行的程序转而为该外暂停正在执行的程序转而为该外设服务设服务(或处理紧急事件或处理紧急事件),处理完毕再回到原断点继续执行原程,处理完毕再回到原断点继续执行原程序。序。第6章 51单片机的中断系统 在在CPU和外设交换信息时,存在着快速和外设交换信息时,存在着快速CPU中断中断源源引起中断的原因引起中断的原因,中断申请的来源,中断源可以是中断申请的来源,中断源可以是I/O设备、故障、时钟、调试中人为设置。设备、故障、时钟、调试中人为设置。中断优先级中断优先级 当有多个中断源同时向当有多个中断源同时向CPU申请中断时,申请中断时,CPU优优先响应最需紧急处理的中断请求,处理完毕再响应
3、优先响应最需紧急处理的中断请求,处理完毕再响应优先级别较低的先级别较低的,这种预先安排的响应次序。,这种预先安排的响应次序。第6章 51单片机的中断系统 中断的嵌套中断的嵌套 在中断系统中,高优先级的中断请求能中断正在在中断系统中,高优先级的中断请求能中断正在进行的较低级的中断源处理。进行的较低级的中断源处理。中断系统中断系统 能实现中断功能并能对中断进行管理的硬件和软件能实现中断功能并能对中断进行管理的硬件和软件称为中断系统。称为中断系统。本章将讨论本章将讨论MCS51系列单片机的中断系统。系列单片机的中断系统。第6章 51单片机的中断系统 中断请求是在执行程序的过程中的随机发生的,中断请求
4、是在执行程序的过程中的随机发生的,中断系统要解决的问题是:中断系统要解决的问题是:1)CPU在不断的执行指令中,是如何在不断的执行指令中,是如何检测检测到到随机随机发发 生的中断请求?生的中断请求?2)如何使中断的双方()如何使中断的双方(CPU方和中断源方)均能人方和中断源方)均能人 为控制,为控制,允许中断或禁止中断允许中断或禁止中断。第6章 51单片机的中断系统 3)由于中断产生的随机性,不可能在程序中安排调子)由于中断产生的随机性,不可能在程序中安排调子 程序指令或转移指令,那么程序指令或转移指令,那么如何实现正确的转移如何实现正确的转移,以便为该中断源服务呢?以便为该中断源服务呢?4
5、)中断源有多个,而中断源有多个,而CPU只有一个只有一个,当有多个中断源,当有多个中断源 同时有中断请求时,用户怎么控制同时有中断请求时,用户怎么控制 CPU 按照自己的按照自己的 需要安排需要安排响应次序响应次序?5)中断服务完毕,如何正确地返回到原断点处?)中断服务完毕,如何正确地返回到原断点处?第6章 51单片机的中断系统 6.1 6.1 中断系统结构中断系统结构 8XX51有有5个中断源,个中断源,3个在片内,个在片内,2个在片外,个在片外,它们在程序存贮器中有固定的中断入口地址,它们在程序存贮器中有固定的中断入口地址,当当CPU响应中断时,硬件自动形成这些地址,由此响应中断时,硬件自
6、动形成这些地址,由此进入中断服务程序;进入中断服务程序;5个中断源有两级中断优先个中断源有两级中断优先级,可形成中断嵌套。级,可形成中断嵌套。第6章 51单片机的中断系统 6.1 6.1 中断系统结构中断系统结构 8XX51有有5个中断源,其符号、名称、产生个中断源,其符号、名称、产生条件及中断服务程序的入口地址如表条件及中断服务程序的入口地址如表6.1。第6章 51单片机的中断系统 二、中断控制的有关寄存器二、中断控制的有关寄存器 (1)(1)中断的允许和禁止中断的允许和禁止中断控制寄存器中断控制寄存器IEIE IE IE寄存器的各位对应相应的中断源,如果允许该中断寄存器的各位对应相应的中断
7、源,如果允许该中断源中断则该位置源中断则该位置1 1,禁止中断则该位,禁止中断则该位0 0。EA EA -ET2ET2 ES ES ET1ET1 EX1 EX1 ET0 ET0 EX0 EX0中断中断总控总控允允/禁禁 不不 用用 T2T2允允/禁禁 串行口串行口允允/禁禁 T1T1允允/禁禁 INT1 INT1允允/禁禁 T0 T0允允/禁禁 INT0INT0允允/禁禁 第6章 51单片机的中断系统 EAEA:中断总控开关,是:中断总控开关,是CPUCPU是否响应中断的前提。是否响应中断的前提。EA=1EA=1,CPUCPU开中断开中断;EA=0 EA=0,CPUCPU关中断。关中断。ESE
8、S:串行口中断允许位,串行口中断允许位,ES=1ES=1,允许串行口发送,允许串行口发送/接收中断;接收中断;ES=0ES=0,禁止串行口中断。,禁止串行口中断。ET1ET1:定时器:定时器T1T1中断允许位,中断允许位,ET1=1ET1=1,允许,允许T1T1计数溢出中断;计数溢出中断;ET1=0ET1=0,禁止,禁止T1T1中断。中断。第6章 51单片机的中断系统 ET0ET0:定时器定时器T0T0中断允许位中断允许位,ET0=1 ET0=1,允许,允许T1T1计数溢出中断;计数溢出中断;ET0=0ET0=0,禁止,禁止T0T0中断。中断。EX1EX1:外部中断外部中断INT1INT1允许
9、位,允许位,EX1=1EX1=1,允许,允许INT1INT1中断;中断;EX1=0EX1=0,禁止,禁止INT1INT1中断。中断。EX0EX0:外部中断外部中断INT0INT0允许位,允许位,EX0=1EX0=1,允许,允许INT0INT0中断;中断;EX0=0EX0=0,禁止,禁止INT0INT0中断。中断。第6章 51单片机的中断系统 (2)(2)中断请求标志及外部中断方式选择寄存器中断请求标志及外部中断方式选择寄存器TCONTCON第6章 51单片机的中断系统 说明:说明:1.IT0和和IT1为外中断为外中断INT0 和和INT1中断触发方式选择,中断触发方式选择,若选下降沿触发则相应
10、位置若选下降沿触发则相应位置1;若选低电平触发;若选低电平触发,IT相应位置相应位置0。2.某中断源有中断请求,该中断标志置某中断源有中断请求,该中断标志置1,无中断请求,无中断请求,该中断标志置该中断标志置0 3.TR0 和和 TR1 为定时器为定时器T0和和T1 工作启动和停止控制。工作启动和停止控制。第6章 51单片机的中断系统 (3)(3)中断优先级管理寄存器中断优先级管理寄存器IP IP 五个中断源的优先级别由五个中断源的优先级别由IP寄存器管理,相应位置寄存器管理,相应位置1,则该中断源优先级别高,置则该中断源优先级别高,置0的优先级的优先级 别低。别低。-PT2PSPT1PX1P
11、T0PX0无无用用位位无无用用位位T2高高/低低串行串行 口口高高/低低 T1高高/低低INT1高高/低低 T0高高/低低 INT0高高/低低 第6章 51单片机的中断系统 T0T1串行口串行口 当当 某几个中断源在某几个中断源在IP寄存器相应位同为寄存器相应位同为1或同为零或同为零时,由内部查询确定优先级,查询的顺序是:时,由内部查询确定优先级,查询的顺序是:CPU优先响应先查询的中断请求优先响应先查询的中断请求T2INT0INT1第6章 51单片机的中断系统 MCS_51系列单片机的中断结构系列单片机的中断结构 第6章 51单片机的中断系统 6.2 中断响应过程中断响应过程 一、中断处理过
12、程一、中断处理过程 中断处理过程分为四个阶段:中断处理过程分为四个阶段:中断请求中断请求;中断响应中断响应;中断处理中断处理;中断返回。中断返回。MCS-51系列单片机的中断过程流程如图系列单片机的中断过程流程如图6.2所示。所示。NNYYYN执执 行行 指指 令令中断标志中断标志1?(中断请求中断请求?)指令指令最后一个最后一个T周期周期?EA=1?允允 许许 位位=1?CPU 判判 别优别优 先权先权,响响 应优应优 先权高先权高 的中断的中断断点的断点的PC进栈进栈,中断服务入口地址送中断服务入口地址送PC撤撤 除除 中中 断断 标标 志志中中 断断 服服 务务中中 断断 返返 回回,断
13、断 点点 出出 栈栈 送送 PC 中断请求中断请求.中断响应中断响应中断服务中断服务中断返回中断返回第6章 51单片机的中断系统 中断请求、中断响应过程由硬件完成。中断请求、中断响应过程由硬件完成。中断服务程序应根据需要进行编写。程序中要注意保中断服务程序应根据需要进行编写。程序中要注意保护现场和恢复现场。护现场和恢复现场。中断返回是通过执行一条中断返回是通过执行一条RETI中断返回指令,使堆栈中断返回指令,使堆栈中被压入的断点地址送中被压入的断点地址送PC,从而返回主程序的断点继,从而返回主程序的断点继续执行主程序。另外续执行主程序。另外RETI还有恢复优先级状态触发器还有恢复优先级状态触发
14、器 的作用,因此不能以的作用,因此不能以RET指令代替指令代替“RETI”指令。指令。第6章 51单片机的中断系统 若某个中断源通过编程设置,处于被打开的状态,若某个中断源通过编程设置,处于被打开的状态,并满足中断响应的条件,然而下面三种情况单片机不响并满足中断响应的条件,然而下面三种情况单片机不响应此中断:应此中断:当前正在执行的那条指令没执行完;当前正在执行的那条指令没执行完;当前响应了同级或高级中断;当前响应了同级或高级中断;正在操作正在操作IEIE、IPIP中断控制寄存器或执行中断控制寄存器或执行RETIRETI指令。指令。在正常的情况下,从中断请求信号有效开始,到中断在正常的情况下,
15、从中断请求信号有效开始,到中断得到响应,通常需要得到响应,通常需要3个机器周期到个机器周期到8个机器周期。个机器周期。第6章 51单片机的中断系统 二、中断请求的撤除二、中断请求的撤除 CPU响应中断后,应撤除该中断请求标志,否则会响应中断后,应撤除该中断请求标志,否则会再次中断。再次中断。对定时计数器对定时计数器T0、T1的溢出中断,的溢出中断,CPU响应中断响应中断后,硬件自动清除中断请求标志后,硬件自动清除中断请求标志TF0和和TF1。对边沿触发的外部中断对边沿触发的外部中断INT1和和INT0,CPU响应中响应中断后硬件自动清除中断请求标志断后硬件自动清除中断请求标志IE0和和IE1。
16、第6章 51单片机的中断系统 对电平触发的外部中断,对电平触发的外部中断,CPU在响应中断时也不会在响应中断时也不会自动清除中断标志,因此,在自动清除中断标志,因此,在CPU响应中断后应立即撤响应中断后应立即撤除除INT1或或INT0的低电平信号。的低电平信号。对于串行口中断,对于串行口中断,CPU响应中断后,没有用硬件清除响应中断后,没有用硬件清除中断请求标志中断请求标志TI、RI,即这些中断标志,即这些中断标志 不会自动清除,不会自动清除,必须用软件清除,这是在编串行通信中断服务中应该注意必须用软件清除,这是在编串行通信中断服务中应该注意的。的。第6章 51单片机的中断系统 6.3 6.3
17、 中断的汇编语言程序和中断的汇编语言程序和C C语言程序设计语言程序设计 用户对中断的控制和管理,实际是对用户对中断的控制和管理,实际是对4个与中断有关个与中断有关的寄存器的寄存器IE、TCON、IP、SCON进行控制或管理。这几进行控制或管理。这几个寄存器在单片机复位时是清零的,因此必须根据需要对个寄存器在单片机复位时是清零的,因此必须根据需要对这几个寄存器的有关位进行预置。这几个寄存器的有关位进行预置。第6章 51单片机的中断系统 6.3 6.3 中断的汇编语言程序和中断的汇编语言程序和C C语言程序设计语言程序设计 在中断程序的编制中应注意:在中断程序的编制中应注意:开中断总控开关开中断
18、总控开关EA,置位中断源的中断允许位。,置位中断源的中断允许位。对外部中断对外部中断INT0、INT1应选择中断触发方式应选择中断触发方式多个中断源中断,应设定中断优先级,预置多个中断源中断,应设定中断优先级,预置IP。第6章 51单片机的中断系统 若要在执行当前中断程序时禁止更高优先级中断,若要在执行当前中断程序时禁止更高优先级中断,可以采用软件关可以采用软件关CPU中断。或禁止某中断源中断,在中中断。或禁止某中断源中断,在中断返回前再开放中断。断返回前再开放中断。编写中断服务程序,并注意用保护现场和恢复现场,编写中断服务程序,并注意用保护现场和恢复现场,以免中断返回时,丢失原寄存器、累加器
19、中的信息。以免中断返回时,丢失原寄存器、累加器中的信息。第6章 51单片机的中断系统 汇编语言的中断服务程序按规定的中断矢量地汇编语言的中断服务程序按规定的中断矢量地址存入,由于五个中断矢量地址址存入,由于五个中断矢量地址0003H、000BH、0013H、001BH、0023H之间相距很近,往往装不下之间相距很近,往往装不下一个中断服务程序,通常将中断服务程一个中断服务程序,通常将中断服务程 序安排在程序安排在程序存贮器的其他地址空间,而在矢量地址的单元中序存贮器的其他地址空间,而在矢量地址的单元中安排一条转移指令。安排一条转移指令。一、汇编语言中断程序的设计一、汇编语言中断程序的设计一、汇
20、编语言中断程序的设计一、汇编语言中断程序的设计第6章 51单片机的中断系统 例例1.1.在图在图6.36.3中中P1.4P1.4P1.7P1.7接有四个发光二极管,接有四个发光二极管,P1.0P1.0P1.3P1.3接有四个开关,消抖电路用于接有四个开关,消抖电路用于 产生中断请求信号,产生中断请求信号,当消抖电路的开关来回拔动一次将产生一个下降沿信号,当消抖电路的开关来回拔动一次将产生一个下降沿信号,通过通过INT0INT0向向CPUCPU申请中断,要求:初时发光二极管全黑,申请中断,要求:初时发光二极管全黑,每中断一次,每中断一次,P1.0P1.0P1.3P1.3所接的开关状态反映到发光二
21、所接的开关状态反映到发光二极管上,且要求开关断开的对应发光二极管亮,电路和极管上,且要求开关断开的对应发光二极管亮,电路和现象如下:现象如下:第6章 51单片机的中断系统 、第6章 51单片机的中断系统 ORG 0000H ORG 0000H AJMP AJMP MAIN MAIN ORG 0003H ORG 0003H ;INT0INT0中断入口中断入口 AJMP AJMP WBIWBI ;转中断服务程序转中断服务程序 ORG 0030H ORG 0030H ;主程序;主程序 MAIN:MAIN:MOV P1 MOV P1,#0FH#0FH ;高;高4 4位灯灭,低四位输入先写位灯灭,低四位
22、输入先写1 1 SETB IT0 SETB IT0 ;边沿触发中断边沿触发中断 SETB EX0 SETB EX0 ;允许外中断;允许外中断0 0中断中断 SETB EA SETB EA ;开中断开关;开中断开关 SJMP$SJMP$;等待中断;等待中断 WBIWBI:MOV P1MOV P1,#0FH#0FH ;P1P1先写入先写入“1 1”且灯灭且灯灭 MOV AMOV A,P1 P1 ;输入开关状态换到高;输入开关状态换到高4 4位位 SWAP A SWAP A ;低;低4 4位开关状态电平位开关状态电平 MOV P1MOV P1,A A ;输出到;输出到P1P1高高4 4位位 RETI
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 中断

限制150内