第5章中断与定时.ppt





《第5章中断与定时.ppt》由会员分享,可在线阅读,更多相关《第5章中断与定时.ppt(82页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、第第5 5章章 单片机的中断单片机的中断/定时系统定时系统 主要介绍:主要介绍:5.1 80C51的中断系统5.2 80C51的中断处理过程的中断处理过程5.3 80C51的定时的定时/计数器计数器 与上对比,单片机中也有同样的问题。与上对比,单片机中也有同样的问题。CPU正正 在执行原程序,突然,被意外事情打断,转去执行在执行原程序,突然,被意外事情打断,转去执行 新程序。新程序。CPU执行新程序结束后,又回到原程序中执行新程序结束后,又回到原程序中 继续执行。这样的过程就叫继续执行。这样的过程就叫 。中断中断 什么叫中断?什么叫中断?举例:某同学正在教室写作业,忽然被人叫出去,回来举例:某
2、同学正在教室写作业,忽然被人叫出去,回来 后,继续写作业。这就是生活中中断的例子。后,继续写作业。这就是生活中中断的例子。5.1 80C51的中断系的中断系统统 5.1.1 80C515.1.1 80C51的中断系的中断系统结统结构构一、中断的概念一、中断的概念 CPUCPU在在处处理某一事件理某一事件A A时时,发发生了另一事件生了另一事件B B请请求求CPUCPU迅速去迅速去处处理(理(中断中断发发生生););CPUCPU暂时暂时中断当前的工作,中断当前的工作,转转去去处处理事件理事件B B(中中断响断响应应和中断服和中断服务务););待待CPUCPU将事件将事件B B处处理完理完毕毕后,
3、再回到原来事件后,再回到原来事件A A被被中断的地方中断的地方继续处继续处理事件理事件A A(中断返回中断返回),),这这一一过过程称程称为为中断中断 。引起引起CPU中断的根源,称为中断的根源,称为中断源中断源。中断源向。中断源向CPU提出提出的中断请求。的中断请求。CPU暂时中断原来的事务暂时中断原来的事务A,转去处理事件,转去处理事件B。对事件对事件B处理完毕后,再回到原来被中断的地方(即处理完毕后,再回到原来被中断的地方(即断点断点),),称为中断返回。实现上述中断功能的部件称为称为中断返回。实现上述中断功能的部件称为中断系统中断系统(中断机构)。(中断机构)。随着计算机技术的应用,人
4、们发现中断技随着计算机技术的应用,人们发现中断技术不仅解决了快速主机与慢速术不仅解决了快速主机与慢速I/O设备的数据设备的数据传送问题,而且还具有如下优点:传送问题,而且还具有如下优点:n 分时操作分时操作。CPU可以分时为多个可以分时为多个I/O设备服设备服务,提高了计算机的利用率;务,提高了计算机的利用率;n实时响应实时响应。CPU能够及时处理应用系统的随能够及时处理应用系统的随机事件,系统的实时性大大增强;机事件,系统的实时性大大增强;n可靠性高可靠性高。CPU具有处理设备故障及掉电等具有处理设备故障及掉电等突发性事件能力,从而使系统可靠性提高。突发性事件能力,从而使系统可靠性提高。二、
5、二、80C51中断系统的结构中断系统的结构 80C5180C51单片机的中断源共有单片机的中断源共有5 5个,其中个,其中2 2个为外部中个为外部中断源、断源、2 2个定时中断源和个定时中断源和1 1个串行中断源。个串行中断源。1 1、2 2个外部中断源个外部中断源 外外部部中中断断是是由由外外部部事事件件引引起起的的中中断断,分分别别由由引引脚脚P3.2P3.2和和P3.3 P3.3 引引入入外外部部中中断断请请求求。有有两两种种信信号号方方式式 ,可可通通过过设设置置控控制位制位ITXITX(X=0X=0,1 1)进行定义。)进行定义。2 2、2 2个定时中断源个定时中断源 定时中断是为单
6、片机的计数定时中断是为单片机的计数/定时器设置的中断。当定时定时器设置的中断。当定时器器TxTx对单片机内部定时脉冲或对外部计数脉冲进行计数发对单片机内部定时脉冲或对外部计数脉冲进行计数发生溢出时,置位生溢出时,置位TFxTFx,并向,并向CPUCPU申请中断。申请中断。3 3、1 1个串行中断个串行中断 串行中断是为串行数据传送的需要而设置的中断。当串串行中断是为串行数据传送的需要而设置的中断。当串行口接收完一帧串行数据时置位行口接收完一帧串行数据时置位RIRI或当串行口发送完一帧或当串行口发送完一帧串行数据时置位串行数据时置位TITI,向,向CPUCPU申请中断。申请中断。二、二、80C5
7、1中断系统的结构中断系统的结构 80C51的中断系统有的中断系统有5个中断源,个中断源,2个优先级,个优先级,可实现二级中断嵌套可实现二级中断嵌套。二、中断请求标志二、中断请求标志1、TCON的中断标志的中断标志IT0(TCON.0),外部中断),外部中断0触发方式控制位。触发方式控制位。当当IT0=0时,为电平触发方式。时,为电平触发方式。当当IT0=1时,为边沿触发方式(下降沿有效)。时,为边沿触发方式(下降沿有效)。IE0(TCON.1),外部中断),外部中断0中断请求标志位。中断请求标志位。IT1(TCON.2),外部中断),外部中断1触发方式控制位。触发方式控制位。IE1(TCON.
8、3),外部中断),外部中断1中断请求标志位。中断请求标志位。TF0(TCON.5),定时),定时/计数器计数器T0溢出中断请求标志位。溢出中断请求标志位。TF1(TCON.7),定时),定时/计数器计数器T1溢出中断请求标志位。溢出中断请求标志位。利用中断请求标志位来通知利用中断请求标志位来通知CPU中断请求!中断请求!TF1 T1的溢出中断标志的溢出中断标志 硬件置硬件置1,硬件清,硬件清0(也可软件清(也可软件清0)TF0 T0的溢出中断标志。(用法同的溢出中断标志。(用法同TF1,针对,针对T0的)的)IE1 外部中断外部中断1(/INT1)请求标志。请求标志。外部有中断请求时,硬件使外
9、部有中断请求时,硬件使IE1置置1,硬件清,硬件清0。IE0 外部中断外部中断0(/INT0)请求标志。请求标志。(用法同(用法同IE1)IT1 外部中断外部中断1(/INT1)触发类型控制位。触发类型控制位。IT1=0,低电平触发。低电平触发。IT1=1 IT1=1,下降沿触发。,下降沿触发。IT0 外中断外中断0(/INT0)触发类型控制位,用法同触发类型控制位,用法同IT1。2、SCON的中断标志的中断标志nRI(SCON.0),串行口接收中断标志位。当允),串行口接收中断标志位。当允许串行口接收数据时,每接收完一个串行帧,由许串行口接收数据时,每接收完一个串行帧,由硬件置位硬件置位RI
10、。但是,。但是,RI必须由软件清除必须由软件清除。nTI(SCON.1),串行口发送中断标志位。当),串行口发送中断标志位。当CPU将一个发送数据写入串行口发送缓冲器时,将一个发送数据写入串行口发送缓冲器时,就启动了发送过程。每发送完一个串行帧,由硬就启动了发送过程。每发送完一个串行帧,由硬件置位件置位TI。CPU响应中断时,不能自动清除响应中断时,不能自动清除TI,TI必须由软件清除必须由软件清除。一、中断允许控制一、中断允许控制 CPU对中断系统所有中断以及某个中断源的开放和屏对中断系统所有中断以及某个中断源的开放和屏蔽是由中断允许寄存器蔽是由中断允许寄存器IE控制的。控制的。5.1.3
11、80C515.1.3 80C51中断的控制中断的控制 nEX0(IE.0),外部中断,外部中断0允许位;允许位;nET0(IE.1),定时,定时/计数器计数器T0中断允许位;中断允许位;nEX1(IE.2),外部中断,外部中断1允许位;允许位;nET1(IE.3),定时,定时/计数器计数器T1中断允许位;中断允许位;nES(IE.4),串行口中断允许位;,串行口中断允许位;nEA(IE.7),CPU中断允许(总允许)位。中断允许(总允许)位。若为若为“1”,开关接通,允许,开关接通,允许例如例如 SETB EA若为若为“0”,开关断开,不允,开关断开,不允许许例如例如 CLR IE.7为什么要
12、有为什么要有中断优先级中断优先级?CPU同同一一时时间间只只能能响响应应一一个个中中断断请请求求。若若同同时时来来了了两两个个或或两两个个以上中断请求,就必须有先有后。以上中断请求,就必须有先有后。!为此将为此将5个中断源分成高级、低级两个级别,高级优先,由个中断源分成高级、低级两个级别,高级优先,由IP控制。控制。二、中断优先级控制二、中断优先级控制 80C51单片机有两个中断优先级,即可实现二单片机有两个中断优先级,即可实现二级中断服务嵌套。每个中断源的中断优先级都是由级中断服务嵌套。每个中断源的中断优先级都是由中断优先级寄存器中断优先级寄存器IP中的相应位的状态来规定的中的相应位的状态来
13、规定的。nPX0(IP.0),外部中断),外部中断0优先级设定位;优先级设定位;nPT0(IP.1),定时),定时/计数器计数器T0优先级设定位;优先级设定位;nPX1(IP.2),外部中断),外部中断1优先级设定位;优先级设定位;nPT1(IP.3),定时),定时/计数器计数器T1优先级设定位;优先级设定位;nPS(IP.4),串行口优先级设定位。),串行口优先级设定位。该位是该位是“1”时,为高级优先时,为高级优先级级该位是该位是“0”时,为低级优先时,为低级优先级级 同一优先级中的中断申请不止一个时,则有中同一优先级中的中断申请不止一个时,则有中断优先权排队问题。断优先权排队问题。同一优
14、先级的中断优先权同一优先级的中断优先权排队,排队,由中断系统硬件确定的由中断系统硬件确定的自然优先级自然优先级形成,其排列如形成,其排列如所示:所示:80C51单片机的中断优先级有三条原则:单片机的中断优先级有三条原则:nCPU同时接收到几个中断时,同时接收到几个中断时,首先响应优先级别最首先响应优先级别最高的中断请求。高的中断请求。n正在进行的中断过程正在进行的中断过程不能被新的同级或低优先级的不能被新的同级或低优先级的中断请求所中断。中断请求所中断。n正在进行的低优先级中断服务,正在进行的低优先级中断服务,能被高优先级中断能被高优先级中断请求所中断。请求所中断。为了实现上述后两条原则,为了
15、实现上述后两条原则,中断系统内部设有两中断系统内部设有两个用户不能寻址的优先级状态触发器。个用户不能寻址的优先级状态触发器。其中一个置其中一个置1,表示正在响应高优先级的中断,它将阻断后来所,表示正在响应高优先级的中断,它将阻断后来所有的中断请求;另一个置有的中断请求;另一个置1,表示正在响应低优先级,表示正在响应低优先级中断,它将阻断后来所有的低优先级中断请求。中断,它将阻断后来所有的低优先级中断请求。同一级中的同一级中的5个中断源的优先顺序是个中断源的优先顺序是:/INT0中断中断 T0溢出中断溢出中断 /INT1中断中断 T1溢出中断溢出中断 串口中断串口中断 高高低低出厂前已由厂家固化
16、顺序出厂前已由厂家固化顺序事先约定自然优先级事先约定自然优先级中断优先原则:(概括为四句话)中断优先原则:(概括为四句话)1、低级不打断高级、低级不打断高级2、高级不睬低级、高级不睬低级3、同级不能打断、同级不能打断4、同级、同时中断,事先约定。、同级、同时中断,事先约定。事件事件1事件事件2子程序子程序2子程序子程序1中断中断嵌套嵌套的概念:的概念:主程序主程序中断中断中断中断5.2 80C51单片机中断处理过程单片机中断处理过程 一、中断响应条件一、中断响应条件n 中断源有中断请求;中断源有中断请求;n 此中断源的中断允许位为此中断源的中断允许位为1;n CPU开中断(即开中断(即EA=1
17、)。)。同时满足时,同时满足时,CPU才有可能响应中断。才有可能响应中断。5.2.1 5.2.1 中断响中断响应应条件和条件和时间时间 CPU每个机器周期都需要顺序检查每个中断源,当检测到有中每个机器周期都需要顺序检查每个中断源,当检测到有中断请求时,能否响应,还要看下述情况是否存在:断请求时,能否响应,还要看下述情况是否存在:(1)CPU正处理相同级别或更高级别的中断;正处理相同级别或更高级别的中断;(2)正在执行指令,还未到最后一个机器周期;)正在执行指令,还未到最后一个机器周期;(3)正在执行的指令是)正在执行的指令是RETI或访问或访问IP、IE指令,则执行完上指令,则执行完上 述指令
18、后,再执行一条指令后,才会响应新中断。述指令后,再执行一条指令后,才会响应新中断。日常生活中日常生活中的中断与的中断与单片机单片机中断的比较:中断的比较:某同学某同学 单片机单片机 过程说明过程说明正在看书正在看书 执行主程序执行主程序有人找出去有人找出去 中断信号中断信号 中断请求中断请求暂停看书暂停看书 暂停执行主程序暂停执行主程序 中断响应中断响应书中作记号书中作记号 当前当前PCPC入栈入栈 保护断点保护断点出去做事出去做事 执行中断程序执行中断程序 中断服务中断服务回来继续看回来继续看 返回主程序返回主程序 中断返回中断返回中断服务的进入:中断服务的进入:CPU执行程序过程中,在每个
19、机器周期的执行程序过程中,在每个机器周期的S5P2期间,中断系统对各个中断源进行采样期间,中断系统对各个中断源进行采样。这些采样值在这些采样值在下一个下一个机器周期内按优先级和机器周期内按优先级和内部顺序被依次查询。内部顺序被依次查询。如果某个中断标志在上一个机器周期的如果某个中断标志在上一个机器周期的S5P2时被置成了时被置成了1,那么它将于现在的查询,那么它将于现在的查询周期中及时被发现。接着周期中及时被发现。接着CPU便执行一条由便执行一条由中断系统提供的硬件中断系统提供的硬件LCALL指令,转向被称指令,转向被称作中断向量的特定地址单元(作中断向量的特定地址单元(入口地址入口地址),)
20、,进入相应的中断服务程序。进入相应的中断服务程序。遇以下任一条件,硬件将受阻,不产生遇以下任一条件,硬件将受阻,不产生LCALL指令:指令:nCPU正在处理同级或高正在处理同级或高优先级中断;优先级中断;n当前查询当前查询的机器周期的机器周期不是所执行指令的最后一个机不是所执行指令的最后一个机器周期器周期。即在完成所执行指令前,不会响应中断,从。即在完成所执行指令前,不会响应中断,从而保证指令在执行过程中不被打断;而保证指令在执行过程中不被打断;n正在执行正在执行的指令为的指令为RET、RETI或任何访问或任何访问IE或或IP寄寄存器的指令。即只有在这些指令后面至少再执行一条存器的指令。即只有
21、在这些指令后面至少再执行一条指令时才能接受中断请求。指令时才能接受中断请求。若由于上述条件的阻碍中断未能得到响应,当条件若由于上述条件的阻碍中断未能得到响应,当条件消失时该中断标志却已不再有效,那么该中断将不被消失时该中断标志却已不再有效,那么该中断将不被响应。就是说,中断标志曾经有效,但未获响应,查响应。就是说,中断标志曾经有效,但未获响应,查询过程在下个机器周期将重新进行。询过程在下个机器周期将重新进行。二、中断响应时间二、中断响应时间某中断的响应时序如图:某中断的响应时序如图:n若若M1周期的周期的S5P2前某中断生效,在前某中断生效,在S5P2期间其中期间其中断请求被锁存到相应的标志位
22、中去;断请求被锁存到相应的标志位中去;M2恰逢指令的恰逢指令的最后一个机器周期,且该指令不是最后一个机器周期,且该指令不是RETI或访问或访问IE、IP的指令。于是,的指令。于是,M3和和M4便可以执行硬件便可以执行硬件LCALL指指令,令,M5周期将进入了中断服务程序。周期将进入了中断服务程序。n80C51的中断响应时间(从标志置的中断响应时间(从标志置1到进入相应的中到进入相应的中断服务),至少要断服务),至少要3个完整的机器周期。个完整的机器周期。n将相应的优先级状态触发器置将相应的优先级状态触发器置1(以阻断(以阻断后来的同级或低级的中断请求)。后来的同级或低级的中断请求)。n执行一条
23、硬件执行一条硬件LCALL指令,即把程序计指令,即把程序计数器数器PC的内容压入堆栈保存,再将相应的的内容压入堆栈保存,再将相应的中断服务程序的入口地址送入中断服务程序的入口地址送入PC。n执行中断服务程序。执行中断服务程序。5.2.2 5.2.2 中断响中断响应过应过程程 中断响应过程的前两步是由中断系统内中断响应过程的前两步是由中断系统内部自动完成的,而中断服务程序则要由用部自动完成的,而中断服务程序则要由用户编写程序来完成。户编写程序来完成。5.2.3 5.2.3 中断返回中断返回RETI指令的具体功能是:指令的具体功能是:n将中断响应时压入堆栈保存的断点地址从栈将中断响应时压入堆栈保存
24、的断点地址从栈顶弹出送回顶弹出送回PC,CPU从原来中断的地方继续从原来中断的地方继续执行程序;执行程序;n 将相应中断优先级状态触发器清将相应中断优先级状态触发器清0,通知中,通知中断系统,中断服务程序已执行完毕。断系统,中断服务程序已执行完毕。注意,不能用注意,不能用RET指令代替指令代替RETI指令。在中指令。在中断服务程序中断服务程序中PUSH指令与指令与POP指令必须成对指令必须成对使用,否则不能正确返回断点使用,否则不能正确返回断点 。若外部中断定义为若外部中断定义为电平触发方式电平触发方式,中断标志位,中断标志位的状态随的状态随CPU在每个机器周期采样到的外部中断在每个机器周期采
25、样到的外部中断输入引脚的电平变化而变化,这样能提高输入引脚的电平变化而变化,这样能提高CPU对对外部中断请求的响应速度。但外部中断源若有请外部中断请求的响应速度。但外部中断源若有请求,必须把有效的求,必须把有效的低电平保持到请求获得响应时低电平保持到请求获得响应时为止为止,不然就会漏掉;,不然就会漏掉;而在中断服务程序结束之而在中断服务程序结束之前,中断源又必须撤消其有效的低电平前,中断源又必须撤消其有效的低电平,否则中,否则中断返回之后将再次产生中断。断返回之后将再次产生中断。电平触发方式适合于外部中断输入以低电平输入电平触发方式适合于外部中断输入以低电平输入且中断服务程序能清除外部中断请求
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 中断 定时

限制150内