微型计算机原理及其应用.ppt_第1页
微型计算机原理及其应用.ppt_第2页
微型计算机原理及其应用.ppt_第3页
微型计算机原理及其应用.ppt_第4页
微型计算机原理及其应用.ppt_第5页
已阅读5页,还剩50页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1,微型计算机原理及其应用 第七章:微型计算机的中断系统,合肥工业大学计算机与信息学院,2,第七章:微型计算机的中断系统,中断的概念及处理过程 8086中断系统 中断控制器8259A,3,第七章:微型计算机的中断系统,中断的概念及处理过程 8086中断系统 中断控制器8259A,4,第七章:微型计算机的中断系统概念及处理过程,什么是中断? 在CPU执行程序的过程中,由于某种突发事件的发生,强迫CPU暂时停止正在执行的程序,转向对该突发事件进行处理,对这个事件处理结束后又能回到原中止的程序,接着中止前的状态继续执行原来的程序,这一个过程就称为中断。把引起中断的原因或触发中断请求的来源称为中断源。,5,第七章:微型计算机的中断系统概念及处理过程,中断请求信号的产生 中断方式提高了CPU的工作效率,但是它同时也提高了系统的硬件开销。因为系统需增加含有中断功能接口电路,用来产生中断请求信号。以输入方式为例,接口电路如图所示。 外设发STB数据入锁存器,中断请求触发器置1若没有屏蔽则产生INTRCPU满足条件(允许中断;指令执行完)发(进入中断服务子程序)读数据,发,和地址清中断请求触发器,数据送D0D7。,6,第七章:微型计算机的中断系统概念及处理过程,中断优先级 中断优先级 (1)如果有多个不同优先级的中断源同时提出中断请求时,CPU应当先响应最高优先级的中断源。 (2)如果CPU正在对某一中断源服务时,比它优先级更高的中断源提出中断请求时,CPU能够暂停正在执行的中断服务程序转向对优先级高的中断源进行服务,当服务结束后再返回原优先级较低的中断服务程序继续执行。 中断嵌套 正在运行的中断处理程序,被优先级高的中断源中断,从而转入新的中断处理程序,当新的中断处理程序执行完再回到原来的中断处理程序,这一现象称为中断嵌套。,7,第七章:微型计算机的中断系统概念及处理过程,中断优先级 当系统中有多个设备提出中断请求时,就有一个该响应谁的问题,也就是一个优先级的问题,解决优先级的问题一般可有三种方法:软件查询法、简单硬件方法及专用硬件方法。 软件查询方法 只需有简单的硬件电路,如将A、 B、C三台设备的中断请求信号“或” 后作为系统INTR,这时,A、B、C 三台设备中只要至少有一台设备提 出中断请求,都可以向CPU发中断 请求。进入中断服务子程序后,再 用软件查询的方式分别对不同的设 备的服务,查询程序的设计思想同 查询式,查询的前后顺序就给出了 设备的优先级。,8,第七章:微型计算机的中断系统概念及处理过程,中断优先级简单硬件方法 将所有的设备连成一条链,靠近CPU的设备优先级最高,越远的设备优先级别越低,则发出中断响应信号,若级别高的设备发出了中断请求,在它接到中断响应信号的同时,封锁其后的较低级设备使得它们的中断请求不能响应,只有等它的中断服务结束以后才开放,允许为低级的设备服务。,9,第七章:微型计算机的中断系统概念及处理过程,中断优先级专用硬件方法 采用可编程的中断控制器芯片,如Intel8259A。,10,第七章:微型计算机的中断系统概念及处理过程,中断过程 是指中断请求、中断响应、中断处理、中断返回这四个过程。中段请求、中断响应由硬件完成,中断处理、中断返回由软件完成。 中断请求 1)外部设备发中断请求的条件:当外设准备就绪或本身工作已经完成时,才向CPU提出中断请求。 2)外部设备中断请求的标志:当外设要求和CPU进行数据交换时,将中断请求信号送往中断请求触发器或中断控制器,经它们处理后,向CPU发出中断请求。 中断响应 如果CPU处于开中断状态,经判优后响应其中最高优先级的中断请求,关中断,将断点压入堆栈中(有的微机还将程序状态字和相关寄存器的内容压入堆栈)保存,以备返回原程序,紧接着将相应的中断处理程序入口地址或中断向量送CPU,转入中断服务程序。,11,第七章:微型计算机的中断系统概念及处理过程,中断过程 中断处理 保护现场。将在中断处理程序中使用的有关寄存器的内容压入堆栈保护起来。在现场保护的过程中,绝对不允许被中断(应禁止中断),否则现场将被破坏。当现场保护好后应开中断。 中断服务。即该中断所要执行的具体指令内容。 恢复现场。当中断服务结束后,应用中断结束命令清除中断标志,立即关中断,以保证恢复现场的过程不受干扰。恢复现场就是把原来压入堆栈的有关寄存器的内容弹出。现场恢复后应开中断,以便CPU响应更高级的中断请求。 中断返回 将压入的断点地址弹出,保证被中断的程序按原来状态执行下去。,12,第七章:微型计算机的中断系统概念及处理过程,中断过程 中断处理和中断返回中的所有内容,也叫做中断服务程序。即:,13,第七章:微型计算机的中断系统,中断的概念及处理过程 8086中断系统 中断控制器8259A,14,第七章:微型计算机的中断系统8086的中断系统,中断分类及中断类型码 中断源可以分为两大类,即外部(硬件)中断和内部(软件)中断。 硬件中断:即通过外部的硬件产生的中断,如打印机、键盘等。硬件中断又可分为:可屏蔽中断和不可屏蔽中断。 不可屏蔽中断:由NMI引脚引入,它不受中断允许标志的影响,每个系统中仅允许有一个,都是用来处理紧急情况的,如掉电处理。这种中断一旦发生,系统会立即响应。 可屏蔽中断:由INTR引脚引入,它受中断允许标志的影响,也就是说,只有当IF1时,可屏蔽中断才能进入,反之则不允许进入,可屏蔽中断可有多个,一般是通过优先级排队,从多个中断源中选出一个进行处理。 软件中断:即根据某条指令或者对标志寄存器中某个标志的设置而产生,它与硬件电路无关,常见的如除数为0,或用INT n指令产生。,15,第七章:微型计算机的中断系统8086的中断系统,中断分类及中断类型码 8086/8088系统最多可处理256级不同类型的中断。,16,第七章:微型计算机的中断系统8086的中断系统,中断分类及中断类型码,17,第七章:微型计算机的中断系统8086的中断系统,中断分类及中断类型码 中断类型码:8086为每个中断源分配了一个中断类型码,其取值范围为0255,即可处理256种中断。其中包括软件中断,系统占用的中断以及开放给用户使用的中断。 中断类型码或者包含在指令中,或者预先规定; 所有内部中断和NMI中断都不执行INTA总线周期; 除单步中断外,任何内部中断都无法禁止且都比外部中断优先级高;,18,第七章:微型计算机的中断系统8086的中断系统,中断向量和中断向量表 中断向量:把各个中断服务子程序的入口都称为一个中断向量; 中断向量表:将这些中断向量按一定的规律排列成一个表,就是所谓的中断向 量表,当中断源发出中断请求时,即可查找该表,找出其中断向量,就可转入 相应的中断服务子程序。 向量表地址:中断向量在中断向量表中的位置。 8086中断系统中的中断向量表是位于0段的03FFFH的存贮区内,每个中断向量占四个单元,其中前两个单元存放中断处理子程序的入口地址的偏移量(IP),低位在前,高位在后;后两个单元存放中断处理子程序入口地址的段地址(CS),也是低位在前,高位在后,整个中断向量的排列是按中断类型号进行的。,19,第七章:微型计算机的中断系统8086的中断系统,中断向量和中断向量表,20,第七章:微型计算机的中断系统8086的中断系统,中断向量和中断向量表 00H04H-系统专用 10H1FH-BIOS用 40HFFH-用户用 08H0FH-硬件中断 20H3FH-DOS用,21,第七章:微型计算机的中断系统8086的中断系统,中断响应过程与时序,22,第七章:微型计算机的中断系统8086的中断系统,中断响应过程与时序,23,第七章:微型计算机的中断系统,中断的概念及处理过程 8086中断系统 中断控制器8259A,24,第七章:微型计算机的中断系统中断控制器8059A,8259A性能概述 1. 具有8级中断优先控制,通过级连可以扩展至64级优先权控制; 2. 每一级中断都可以通过初始设置为允许或屏蔽状态; 3. 8259A的工作方式,可以通过编程进行设置,因此,使用非常灵活; 4. 8259A采用NMOS制造工艺,只需要单一的+5V电源。,25,第七章:微型计算机的中断系统中断控制器8059A,8259A的内部结构和工作原理,26,第七章:微型计算机的中断系统中断控制器8059A,8259A的内部结构和工作原理 数据总线缓冲器:它是8259A与系统数据总线的接口,是8位双向三态缓冲器。CPU与8259A之间的控制命令信息、状态信息以及中断类型信息,都是通过该缓冲器传送的。 读/写控制逻辑:CPU通过它实现对8259A的读/写操作。 级连缓冲器:用以实现8259A芯片之间的级连,使得中断源可以由8级扩展至64级。 控制逻辑电路:对整个芯片内部各部件的工作进行协调和控制。 中断请求寄存器IRR:8位,用以分别保存8个中断请求信号,当相应的中断请求输入引脚有中断请求时,该寄存器的相应位置1。 中断屏蔽寄存器IMR:8位,相应位用以对8个中断源的中断请求信号进行屏蔽控制。当其中某位置”0”时,则相应的中断请求可以向CPU提出;否则,相应的中断请求被屏蔽,即不允许向CPU提出中断请求。该寄存器的内容为8259A的操作命令字OCW1,可以由程序设置或改变。 中断服务寄存器ISR: 8位,当CPU正在处理某个中断源的中断请求时,ISR寄存器中的相应位置1。 优先级比较器PR:用以比较正在处理的中断和刚刚进入的中断请求之间的优先级别,以决定是否产生多重中断或中断嵌套。,27,第七章:微型计算机的中断系统中断控制器8059A,8259A的外部引脚,28,第七章:微型计算机的中断系统中断控制器8059A,8259A的外部引脚 D7-D0:双向数据输入/输出引脚,用以与CPU进行信息交换。 IR7-IR0:8级中断请求信号输入引脚。 INT:中断请求信号输出引脚,高电平有效,用以向CPU发中断请求,应接在CPU的INTR输入端。 INTA#:中断响应应答信号输入引脚,低电平有效,接在CPU的中断应答信号输出端。 RD#、WR#:读/写控制信号输入引脚,低电平有效,实现对8259A内部有关寄存器内容的读操作。 CS#:片选信号输入引脚,低电平有效,决定了8259A的端口地址范围。 A0:8259A两组内部寄存器的选择信号输入引脚,决定8259A的端口地址。 CAS2-CAS0:级连信号引脚,当8259A为主片时,为输出;否则为输入,与信号配合,实现芯片的级连,这三个引脚信号的不同组合000111,刚好对应于8个从片。 SP#/EN#:为级连管理信号输入引脚,在非缓冲方式下,若8259A在系统中作从片使用,则SP=1;否则SP=0;在缓冲方式下,用作8259A外部数据总线缓冲器的启动信号。 +5V、GND:电源和接地引脚。,29,第七章:微型计算机的中断系统中断控制器8059A,8259A的工作过程 当有一条或若干条中断请求输入(IR7-IR0)有效时,则使中断请求寄存器的IRR的相应位置位。 若CPU处于开中断状态,则在当前指令执行完之后,响应中断,并且发应答信号(两个连续的INTA#负脉冲)。 第一个INTA#负脉冲到达时,IRR的锁存功能失效,对于IR7-IR0上发来的中断请求信号不予理睬。 使中断服务寄存器ISR的相应位置1,以便为中断优先级比较器的工作做好准备。 使中断请求寄存器的相应位复位,即清除中断请求。 第二个INTA#负脉冲到达时,将中断类型寄存器中的内容ICW2,送到数据总线的D7-D0上,CPU以此作为相应中断的类型码。 若ICW4中的中断结束位为1,那么,第二个INTA#负脉冲结束时,8259A将ISR寄存器的相应位清零。否则,直至中断服务程序执行完毕,才能通过输出操作命令字EOI,使该位复位。,30,第七章:微型计算机的中断系统中断控制器8059A,8259A的工作方式 优先权的管理方式 中断源的屏蔽方式 结束中断处理的方式 系统总线的连接方式 引入中断的请求方式,31,第七章:微型计算机的中断系统中断控制器8059A,8259A的工作方式 优先权的管理方式 中断源的屏蔽方式 结束中断处理的方式 系统总线的连接方式 引入中断的请求方式,32,第七章:微型计算机的中断系统中断控制器8059A,8259A的工作方式优先权的管理方式 1. 全嵌套方式 这是8259A默认的优先权设置方式,在全嵌套方式下,8259A所管理的8级中断优先权是固定不变的,其中IR0的中断优先级最高,IR7的中断优先级最低。 CPU响应中断后,请求中断的中断源中,优先级最高的中断源,在中断服务寄存器ISR中的相应位置位,而且把它的中断矢量送至系统数据总线,在此中断源的中断服务完成之前,与它同级或优先级低的中断源的中断请求被屏蔽,只有优先级比它高的中断源的中断请求才是运算的,从而出现中断嵌套。 2. 特殊全嵌套方式 特殊全嵌套方式与全嵌套方式基本相同,所不同的是,当CPU处理某一级中断时,如果有同级中断请求,那么CPU也会作出响应,从而形成了对同一级中断的特殊嵌套。 特殊全嵌套方式通常应用在有8259A级连的系统中,在这种情况下,对主8259A编程时,通常使它工作在特殊全嵌套方式下。这样,一方面,CPU对于优先级别较高的主片的中断输入是允许的,另一方面,CPU对于来自同一从片的优先级别较高(但对于主片来讲,优先级别是相同的)的中断也是允许、能够响应的。,33,第七章:微型计算机的中断系统中断控制器8059A,8259A的工作方式优先权的管理方式 3. 优先级自动循环方式 在实际应用中,中断源优先级的情况是比较复杂的,要求8级中断的优先级在系统工作过程中,可以动态改变。即一个中断源的中断请求被响应之后,其优先级自动降为最低。系统启动时,8级中断优先级默认为IR0IR7,这时,刚好IR4发出了中断请求,CPU响应之后,若8259A工作在优先级自动循环方式下,则中断优先级自动变为IR5、IR6、IR7、IR0、 IR1、 IR2、 IR3、 IR4。 优先级特殊循环方式 优先级特殊循环方式与自动循环方式相比,只有一点不同,即初始化的优先级是由程序控制的,而不是默认的IR0IR7。,34,第七章:微型计算机的中断系统中断控制器8059A,8259A的工作方式 优先权的管理方式 中断源的屏蔽方式 结束中断处理的方式 系统总线的连接方式 引入中断的请求方式,35,第七章:微型计算机的中断系统中断控制器8059A,8259A的工作方式中断源的屏蔽方式 1. 普通屏蔽方式 8259A的每个中断请求输入,都要受到屏蔽寄存器中相应位的控制。若相应位为“1”,则中断请求不能送CPU。屏蔽是通过对屏蔽寄存器IMR的编程(操作命令字OCW1),来加以设置和改变的。 2. 特殊屏蔽方式 有些场合下,希望一个中断服务程序的运行过程中,能动态地改变系统中的中断优先级结构,即在中断处理的一部分,禁止低级中断,而在中断处理的另一部分,又能够允许低级中断,于是引入了对中断的特殊屏蔽方式。 设置了特殊屏蔽方式后,用OCW1对屏蔽寄存器中的某一位复位时,同时也会使中断服务寄存器ISR中的相应位复位,这样就不只屏蔽了正在处理的等级中断,而且真正开放了其它优先级别较低的中断请求。 特殊屏蔽是在中断处理程序中使用的,用了这种方式之后,尽管系统正在处理高级中断,但对外界来讲,只有同级中断被屏蔽,而允许其它任何级别的中断请求。,36,第七章:微型计算机的中断系统中断控制器8059A,8259A的工作方式 优先权的管理方式 中断源的屏蔽方式 结束中断处理的方式 系统总线的连接方式 引入中断的请求方式,37,第七章:微型计算机的中断系统中断控制器8059A,8259A的工作方式结束中断的处理方式 1. 中断自动结束方式 这种方式仅适用于只有单片8259A的场合,在这种方式下,系统一旦响应中断,那么CPU在发第二个INTA#脉冲时,就会使中断响应寄存器ISR中相应位复位,这样一来,虽然系统在进行中断处理,但对于8259A来讲,ISR没有相应的指示,就象中断处理结束,返回主程序之后一样。CPU可以再次响应任何级别的中断请求。 2. 一般的中断结束方式 一般的中断结束方式适用用在全嵌套的情况下,当CPU用输出指令向8259A发一般中断结束命令OCW2时,8259A才会使中断响应寄存器ISR中优先级别最高的位复位。 3. 特殊的中断结束方式 在特殊全嵌套模式下,系统无法确定哪一级中断为最后相应和处理的中断,也就是说,CPU无法确定当前所处理的是哪级中断,这时就要采用特殊的中断结束方式。 特殊的中断结束方式是指在CPU结束中断处理之后,向8259A发送一个特殊的EOI中断结束命令,这个特殊的中断结束EOI命令,明确指出了中断响应寄存器ISR中需要复位的位。,38,第七章:微型计算机的中断系统中断控制器8059A,8259A的工作方式 优先权的管理方式 中断源的屏蔽方式 结束中断处理的方式 系统总线的连接方式 引入中断的请求方式,39,第七章:微型计算机的中断系统中断控制器8059A,8259A的工作方式系统总线的连接方式 1. 缓冲方式 在多片8259A级连的大系统中,8259A通过外部总线驱动器和数据总线相连,这就是缓冲方式。在缓冲方式下,8259的输出信号作为缓冲器的启动信号,用来启动总线驱动器,在8259A与CPU之间进行信息交换。 2. 非缓冲方式 当系统中只有一片或几片8259A芯片时,可以将数据总线直接与系统数据总线相连,这时8259A处于非缓冲方式下。在这种方式下,8259A的作为输入端设置,主片应接高电平,从片应接低电平。,40,第七章:微型计算机的中断系统中断控制器8059A,8259A的工作方式 优先权的管理方式 中断源的屏蔽方式 结束中断处理的方式 系统总线的连接方式 引入中断的请求方式,41,第七章:微型计算机的中断系统中断控制器8059A,8259A的工作方式引入中断请求的方式 1. 边沿触发方式 8259A将中断请求输入端出现的上升沿,作为中断请求信号,上升沿后相应引脚,可以一直保持高电平。 2. 电平触发方式 8259A将中断请求输入端出现的高电平作为中断请求信号,在这种方式下,必须注意:中断响应之后,高电平必须及时撤除,否则,在CPU响应中断,开中断之后,会引起第二次不应该有的中断。 3. 中断查询方式 当系统中的中断源很多,超过64个时,则可以使8259A工作在查询方式下,中断查询方式的特点是: a.中断源仍往8259A发中断请求,但8259A却不使用INT信号向CPU发中断请求信号。 b. CPU内部的中断允许标志复位,所以CPU对INT引脚上出现的中断请求呈禁止状态。 c. CPU 用软件查询的方法来确定中断源,从而实现对设备的中断服务,可见,中断查询方式,既有中断的特点,又有查询的特点,从外设的角度来看,是靠中断的方式来请求服务,但从CPU的角度来看,是用查询方式来确定发中断请求的中断源。,42,第七章:微型计算机的中断系统中断控制器8059A,8259A的编程8259A的控制字 8259A的命令字有两种。一种是初始化命令字(ICW),在8259A启动之前写入,使其处于预定的初始状态。另一种是操作命令字(OCW),使处于初始状态的8259去执行具体的某种操作方式。操作命令字可在8259初始化后的任何时刻写入。,43,第七章:微型计算机的中断系统中断控制器8059A,8259A的编程8259A的控制字 1.初始化命令字 1)ICW1:芯片控制初始化命令字,在A0=0,D4=1时写入。,44,第七章:微型计算机的中断系统中断控制器8059A,8259A的编程8259A的控制字 1.初始化命令字 2)ICW2:设置中断向量码初始化命令字。,45,第七章:微型计算机的中断系统中断控制器8059A,8259A的编程8259A的控制字 1.初始化命令字 3)ICW3:主片/从片初始化命令字。,46,第七章:微型计算机的中断系统中断控制器8059A,8259A的编程8259A的控制字 1.初始化命令字 4)ICW4:方式控制字初始化命令字。ICW4用来设定8259A的工作模式。,47,第七章:微型计算机的中断系统中断控制器8059A,8259A的编程8259A的控制字,48,第七章:微型计算机的中断系统中断控制器8059A,8259A的编程8259A的控制字 2.操作命令字 1)OCW1:中断屏蔽操作命令字,在A0=1时写入到中断屏蔽寄存器IMR中,当某一位为1时,就屏蔽与之相应的IR输入。,49,第七章:微型计算机的中断系统中断控制器8059A,8259A的编程8259A的控制字 2.操作命令字 2)OCW2:优先循环方式和中断结束方式操作字。其中R是优先级循环控制位,R=1为循环优先级,R=0 为固定优先级。,50,第七章:微型计算机的中断系统中断控制器8059A,8259A的编程8259A的控制字 2.操作命令字 3)OCW3:特殊屏蔽方式和查询方式操作字。OCW3的功能有三个方面:一是设置和撤消特殊屏蔽方式,二是设置中断查询方式,三是用来设置对8259A内部的寄存器的读出命令。在A0=0,D4D3=01时写入OCW3。,51,第七章:微型计算机的中断系统中断控制器8059A,8259A的编程8259A的级联,52,第七章:微型计算机的中断系统中断控制器8059A,8259A的编程 例7-1 IBMPC机中,只有一片8259A,可接受外部8级中断。在I/O地址中,分配8259A的端口地址为20H和21H,初始化为:边沿触发、缓冲连接、中断

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论