1、第八章 中断系统,8.1 中断概念 8.2 8086、8088的中断系统,8.1 中断概念,中断:是指CPU在正常运行程序时,由程序预先安排好的事件,或者由内、外部事件引起CPU中断正在运行的程序,转到为预先安排的事件或内、外部事件服务的程序中去。这些引起程序中断的事件称为中断源。PC的中断指令在CPU中预先设定。 8.1.1应用中断的好处: 1.同步操作 2.实现实时处理 3.故障处理,8.1.2 中断源引起中断产生的事件或发出中断请求的来源,称为中断源。 1.一般的输入输出 2.数据通道中断源 3.实时时钟 4.故障源 5.为调试程序而设置的中断源,8.1.3 中断系统的功能 1.实现中断
2、及返回 2.能实现优先排队 3.高级中断源能中断低级的中断处理,中断常用术语 (1)中断返回当计算机对紧急事件处理完成后,要返回原程序A,实际上是将从断点处继续执行原程序,这个过程称为中断返回。 (2)中断服务程序非寻常事件的处理程序B,称为中断服务程序。中断服务程序是程序员事先安排好的程序,非寻常事件一般是指事件发生的时间是无法预知的,但事件的性质及处理方法是已知的。,8.1 中断的概念,(3)中断现场和保护现场计算机正在运行程序A,收到紧急事件的要求,中断了当前程序A;在中断时刻,程序A运行的当前状态称为中断现场。它应包括状态寄存器的状态,以及CPU内部寄存器的当前内容。为了使中断返回后这
3、些信息不会丢失,必须加以保护,这称为保护现场。保护的方法有些是靠硬件自动完成的,有些则靠程序来实现。 (4)断点计算机正在执行程序A,由于某一个非寻常事件发生,暂停A程序的运行,而执行紧急事件处理程序B,程序A被中断时的下一条指令的地址称为断点或断点地址。,8.1 中断的概念,8.2 CPU响应中断的条件和过程,8.2.1 CPU响应中断的条件 1.设置中断请求触发器 2.设置中断屏蔽触发器 3.中断是开放的 4.CPU在现行指令结束后响应中断,8.2 CPU响应中断的条件和过程,8.2.2 CPU对中断的响应 1.关中断 2.保留断点 3.保护现场 4.给出中断入口,转入相应的中断服务程序
4、5.恢复现场 6.开中断与返回,8.2 CPU响应中断的条件和过程,三态 缓冲器,输 入 设 备,地址 译码器,1,数据,RDY,DB,AB,IO/M,RD,CPU,&,中断请求 触发器,数据 锁存器,+5V,Q,D,INT,状态信号,数据 锁存器,三态 缓冲器,1,&,中断方式的输入过程: 外设准备好数据,发出选通信号 选通信号将数据锁存,同时产生中断信号 若中断屏蔽触发器不屏蔽(即允许中断),则将中断信号传送给CPU CPU接收到中断信号,且IF=1,则CPU响应中断,发INTA响应信号,清除传来的中断请求信号,并获取外设的中断向量 CPU执行相应的中断服务子程序,即读取数据,8.2 CP
5、U响应中断的条件和过程,8.3 中断优先权及多重中断,8.3.1 中断优先权 判别和确定各个中断源的优先权可以用软件和硬件两种方法。 1.用软件确定中断优先权 把8个外设的中断请求触发器组合起来,作为一个端口,并赋以设备号,把各个外设的中断请求信号相“或”后,作为INTR信号,故任一外设有中断请求,都可向CPU送出INTR信号。当CPU响应中断后,把中断寄存器的状态,作为一个外设读入CPU,逐位检测它们的状态,若有中断请求就转到相应的服务程序的入口。,中断源有许多个,需要用中断控制器来进行优先级管理: a.当多个中断同时发生时,优先级高的得到响应。 b.优先级高的中断可以中断优先级低的中断,8
6、.6.2 8086的中断系统,8.3 中断优先权及多重中断,7.3.1 中断优先权 查询程序有两种实现方法 (1)屏蔽法 IN AL,20H ;输入中断请求触发器的状态 TEST AL,80H ;检查最高位 JNE PWF ;外设A中断服务程序 TEST AL,40H ;检查次高位 JNE DISS ;外设B中断服务程序 TEST AL,20H ;检查次高位 JNE MT ;外设C中断服务程序 ,8.3 中断优先权及多重中断,8.3.1 中断优先权 (2)移位法 XOR AL,AL IN AL,20H ;输入中断请求触发器的状态 RCL AL, 1 JC PWF ;外设A中断服务程序 RCL
7、AL, 1 JC DISS ;外设B中断服务程序 ,8.3 中断优先权及多重中断,8.3.1 中断优先权 2. 硬件优先权排队电路 (1)中断优先权编码电路 若有8个中断源,当任意一个有中断请求时,通过或门,即可有一个中断请求信号产生,能否送至CPU的中断请求线,还要受比较器的控制。 (2)雏菊花环(Daisy Chain)式或称为链式优先权排队电路,8.3 中断优先权及多重中断,中断响应(来自CPU),中断请求输入1,中断请求输入2,中断请求输入3,中断请求输入4,中断输出1,中断输出2,中断输出3,中断输出4,链式优先权排队电路,2)简单硬件方式(菊花链法),8.3 中断优先权及多重中断,
8、8.3.2 多级中断的概念多级中断系统是指计算机系统有相当多的中断源,根据各中断事件的轻重缓急而分成若干级别,每一中断级分配一个优先权。根据系统的配置不同,多级中断又可分为一维多级中断和二维多级中断。一维多级中断是指每一中断中只有一个中断源,而二维多级中断是指每一级中断中又有多个中断源。,8.3 中断优先权及多重中断,8.3 中断优先权及多重中断,8.4 8086/8088的中断方式,1.软中断:软件中断是CPU根据程序中的某条指令或程序对标志寄存器中某个标志的设置而产生的。 (1)DIV(除)或IDIV(整除)指令 (2)INT指令 (3)INTO指令 (4)单步执行,8.4 8086/80
9、88的中断方式,2.硬中断:硬件中断也称为外部中断,CPU提供了两个外部中断输入引脚,18脚(INTR)可屏蔽中断输入引脚,17脚(NMI)非屏蔽中断输入引脚。 (1)可屏蔽中断,出现在INTR线上 (2)非屏蔽中断,出现在NMI线上,8.4 8086/8088的中断方式,8086中断分类,8086中断,3.中断向量表 中断向量:中断处理子程序的入口地址; 中断向量表:在内存的前1KB(地址为00000H003FFH) 区域存放着256个中断向量(或256个中断类型) ,每个中断向量占用4字节空间。,8.4 8086/8088的中断方式,3.中断向量表 每一种中断类型对应一个中断向量; 每个中
10、断向量占4个字节,前两个字节存放中断处理子程序入口地址的偏移量(IP),后两个字节存放中断处理子程序入口地址的段地址(CS); 256个中断中:0-4为专用中断,5-31为系统保留(21个),32以上共224个为用户自定义中断。,8.4 8086/8088的中断方式,8086中断向量表 指出了中断向量类型码与中断向量之间的关系,类型255,类型33,类型32,类型31,类型5,类型4,类型3,类型2,类型1,类型0,3FEH 3FCH,084H 080H 07EH,014H 010H 00CH 008H 004H 000H,中断服务程序起始地址的计算: CS基址所在单元 TYPE*4+2 IP
11、偏移量所在单元 TYPE*2 例:外设的编码类型为33,计算该外设的中断服务程序入口地址 CS基址所在单元 33*4+2=134=86H IP偏移量所在单元 33*4=132=84H,8.4 8086/8088的中断方式,4. 中断响应和处理过程 (1)类型码乘4,作为中断向量表指针; (2)CPU标志寄存器入栈; (3)复制追踪标志T的状态,清除I和T标志,屏蔽新的INTR中断和单步中断; (4)保存主程序中的断点,即把主程序断点处的IP和CS的值推入堆栈保护,先推入CS的值,再推入IP的值; (5)从中断向量表中取中断服务程序的入口地址,分别送至CS和IP中,先取CS的值; (6)按新地址
12、执行中断服务程序。,5、中断服务过程,8.5 IBM PC/XT的中断方式,IBM PC/XT的中断类型 (1)内部中断即软中断 (2)非屏蔽中断NMI (3)可屏蔽中断INTR,8.5 IBM PC/XT的中断方式,8.5 IBM PC/XT的中断方式,2. IBM PC/XT系统保留的中断 8086CPU最多能处理256种不同的中断,其中5个保留为CPU专用;一部分是由磁盘操作系统DOS保留为系统使用,用户可以使用200个左右中断。,8.5 IBM PC/XT的中断方式,第九章 DMA控制器,DMA:direct memory access 直接存储器访问技术,适合高速的数据交换,DMA控
13、制原理(工作过程) (1) 外设向DMA控制器发出DMA请求; (2) DMA控制器向CPU发出总线请求信号; (3) CPU执行完现行的总线周期后,向DMA控制器发出响应请求的回答信号; (4) CPU将控制总线,地址总线及数据总线让出,由DMA控制器进行控制; (5) DMA控制器向外部设备发出DMA请求回答信号; (6) 进行DMA传送; (7) 数据传送完毕,CPU重新控制总线。,1.简答三态门概念及其性能? 2.什么是中断和中断向量? 3.已知SS=3000H,SP=10H,AX=5634H,BX=3412H,执行下列指令 PUSH AX PUSH BX POP AX POP BX 画出进栈、出栈示意图并标明SP变化过程。 最终AX,BX的内容是什么?,