610 likes | 796 Views
第 7 章. 第 7 章:教学重点. 教学重点 8088 CPU 的中断系统 内部中断服务程序的编写 中断控制器 8259A 的作用. 7.1 概述. 中断是微处理器与外部设备交换信息的一种方式。 程序中断 ( 定义 ) 中断处理程序 中断是提高计算机工作效率的一种手段,能较好的发挥处理器的能力 中断技术对实时微机控制系统来说特别有效 中断技术也广泛用来进行应急事件的处理. 7.1 概述. 微处理器中常用的 3 种中断技术: 单线中断 多级中断 矢量中断. 7.1 概述. 单线中断技术
E N D
第7章:教学重点 教学重点 • 8088 CPU的中断系统 • 内部中断服务程序的编写 • 中断控制器8259A的作用
7.1 概述 • 中断是微处理器与外部设备交换信息的一种方式。 • 程序中断(定义) • 中断处理程序 • 中断是提高计算机工作效率的一种手段,能较好的发挥处理器的能力 • 中断技术对实时微机控制系统来说特别有效 • 中断技术也广泛用来进行应急事件的处理
7.1 概述 • 微处理器中常用的3种中断技术: • 单线中断 • 多级中断 • 矢量中断
7.1 概述 • 单线中断技术 • 多个外设的中断请求必须用“或”逻辑连接在一起,共同接到微处理器的一条中断请求线上。 • 需解决的问题 • 中断源的识别 • 中断请求的优先权排队问题 • 中断的多级嵌套 • 多级中断技术 • 微处理器有几条优先级别不同的中断请求线,若每一个中断源都对应一条请求线,则发生中断时,微处理器就能识别中断源及其优先级别 • 特点:响应速度快,结构简单,但受引脚数的限制
7.1 概述 • 矢量中断技术 • 由每个中断源向CPU提供中断源的设备标志码,将程序转向相应中断源设备的中断处理程序,或中断源提供中断处理程序的入口地址 • 由于矢量中断不需要查询中断源,故中断处理速度较快
7.1 概述 • 异常 • 是在指令执行期间检测到的不正常的非法的状态,使指令不能成功执行。它与所执行的指令有直接的联系 • 异常的发生源于微处理器的内部,且总是与微处理器操作同步(中断是外部) • 例如:指令执行期间检测到段异常或页异常 • 处理器对中断和异常的处理通常在两条指令之间进行
7.1 概述 • 8088/386/486的中断系统采用向量中断机制,每个中断或异常都有它自己的中断矢量 • 中断矢量用8位二进制表示,能够处理256个中断 • 用中断向量号0 ~ 255区别 • 可屏蔽中断还需要借助专用中断控制器Intel 8259A实现优先权管理
7.2 中断 • 中断由异步的外部事件引起。外部设备根据其自身需要,使用微处理器芯片上特定的引脚,把实时中断请求信号传送给微处理器。 • 中断分类 • 可屏蔽中断 • 非屏蔽中断
第7章: ⑴可屏蔽中断 • 外部通过可屏蔽中断请求信号向微处理器提出的中断,微处理器在允许可屏蔽中断的条件下,在当前指令执行结束予以响应,同时输出可屏蔽中断响应信号,这个中断就是可屏蔽中断 • 8088的可屏蔽中断请求和响应信号分别是INTR和INTA*;由IF标志控制可屏蔽中断是否允许响应;向量号来自外部中断控制器 • 8088通常需要配合中断控制器8259A共同处理可屏蔽中断 • 可屏蔽中断主要用于主机与外设交换数据
第7章: ⑵ 非屏蔽中断 • 通过非屏蔽中断请求信号向微处理器提出的中断请求,微处理器无法禁止,将在当前指令执行结束予以响应,这个中断被称为非屏蔽中断 • 8088的非屏蔽中断的向量号为2,非屏蔽中断请求信号为NMI • 非屏蔽中断主要用于处理系统的意外或故障。例如: • 电源调电前的数据保护 • 存储器读写错误的处理
7.3 异常 • 异常分类 • 故障(Fault) • 引起该故障的程序可被恢复执行的异常,它也是在引起故障的指令执行之前就报告给系统的一种异常 • 陷阱(Trap) • 是在指令执行期间被检测到的,并在引起异常的指令执行之后向系统报告的一种异常 • 中断(Abort) • 是微处理器面临严重错误时产生的异常。
7.3 异常 • 异常错误码 • 产生异常时,为了帮助系统分析问题,微处理器在异常处理程序的栈中压入一个错误码,对于一些无错误信息的异常,压入错误码0 • 错误码格式—略 • 处理器定义的异常 • 是80X86处理器中保留自用的异常,共16个 • 异常0、1、3、4 较重要,其他了解即可
非屏蔽中断源 可屏蔽中断源 NMI 8259A 中断 控制器 IR0 IR1 IR2 IR3 IR4 IR5 IR6 IR7 CPU INTR 中断逻辑 外 设 中 断 源 INTA INT N 指令 INTO 指令 除法 错误 单步 中断 第7章 补充 • 内部中断 • 除法错中断 • 指令中断 • 溢出中断 • 单步中断 • 外部中断 • 非屏蔽中断 • 可屏蔽中断
第7章:1. 内部中断 • 内部中断是由于8088内部执行程序出现异常引起的程序中断 • 利用内部中断,微处理器为用户提供了发现、调试并解决程序执行时异常情况的有效途径 • 例如,ROM-BIOS和DOS系统利用内部中断为程序员提供了各种功能调用
第7章:⑴ 除法错中断 • 在执行除法指令时,若除数为0或商超过了寄存器所能表达的范围,则产生一个向量号为0的内部中断,称为除法错中断 例如: mov bl,0 idiv bl ;除数BL=0,产生除法错中断 mov ax,200h mov bl,1 div bl ;商=200H,不能用AL表达 ;产生除法错中断
第7章:⑵ 指令中断 • 在执行中断调用指令INT n时产生的一个向量号为n(0 ~ 255)的内部中断,称为指令中断 • 其中向量号为3的指令中断比较特别(生成一个字节的指令代码:11001100),常用于程序调试,被称为断点中断 例如:DEBUG.EXE调试程序的运行命令G设置的断点,就是利用INT 3指令实现的
第7章:⑶ 溢出中断 • 在执行溢出中断指令INTO时,若溢出标志OF为1,则产生一个向量号为4的内部中断,被称为溢出中断 例如: mov ax,2000h add ax, 7000h ;2000H+7000H=9000H,溢出:OF=1 into ;因为OF=1,所以产生溢出中断
第7章:⑷ 单步中断 • 若单步中断TF为1,则在每条指令执行结束后产生一个向量号为1的内部中断,称为单步中断 例如:DEBUG.EXE调试程序的单步命令T就利用单步中断实现对程序的单步调试
第7章:2. 外部中断 • 外部中断是由于8088外部提出中断请求引起的程序中断 • 利用外部中断,微机系统可以实时响应外部设备的数据传送请求,能够及时处理外部意外或紧急事件 • 外部中断的原因是处理器外部随机产生的,所以是真正的中断(Interrupt) • 内部中断的原因是处理器执行程序出现异常,所以经常被称为异常(Exception)
7.4 中断及异常的暂时屏蔽 • IF=0:可屏蔽中断不会被响应 • 关中断、禁止中断、中断屏蔽 • 系统复位,使IF=0 • 任何一个中断被响应,使IF=0 • 执行指令CLI,使IF=0 • IF=1:可屏蔽中断会被响应 • 开中断、允许中断、中断开放 • 执行指令STI,使IF=1 • 执行指令IRET恢复原IF状态 • RF=1,屏蔽排错故障 • 其他 明 确 IF 标 志 的 状 态 是 关 键
7.6 实方式下的中断 • 中断向量:中断服务程序的入口地址(首地址) • 逻辑地址含有段地址CS和偏移地址IP(32位) • 每个中断向量的低字是偏移地址、高字是段地址,需占用4个字节 • 8088微处理器从物理地址000H开始,依次安排各个中断向量,向量号也从0开始 • 256个中断占用1KB区域,就形成中断向量表 向量号为N的中断向量的物理地址=N×4
补充:内部中断服务程序 • 编写内部中断服务程序与编写子程序类似 • 利用过程定义伪指令PROC/ENDP • 第1条指令通常为开中断指令STI • 最后用中断返回指令IRET • 通常采用寄存器传递参数 • 主程序需要调用中断服务程序 • 调用前,需要设置中断向量 • 设置必要的入口参数 • 利用INT n指令调用中断服务程序 • 处理出口参数
例7.1 内部中断服务程序 • 编写80H号中断服务程序,并调用 • 功能:具有显示以“0”结尾字符串的功能,利用显示器功能调用INT 10H实现字符显示 • 字符串缓冲区首地址为入口参数: DS:DX(段地址:偏移地址)传递参数
第7章:例7.1的数据段 ;数据段 intoff dw ? ;用于保存偏移地址 intseg dw ? ;用于保存段基地址 intmsg db ‘A Instruction Interrupt !’, 0dh,0ah,0 回车、换行 以“0”结尾
第7章:例7.1的获取原中断向量 ;代码段 mov ax,3580h ;利用DOS功能35H号 int 21h ;获取原80H中断向量 mov intoff,bx ;保存偏移地址 mov intseg,es ;保存段基地址 获取中断向量(DOS功能调用INT 21H) 功能号:AH=35H 入口参数:AL=中断向量号 出口参数:ES:BX=中断向量(段地址:偏移地址)
第7章:例7.1的设置新中断向量 push ds mov dx,offset new80h ;取中断程序偏移地址 mov ax,seg new80h ;取中断程序段地址 mov ds,ax mov ax,2580h int 21h pop ds 设置中断向量(DOS功能调用INT 21H) 功能号:AH=25H 入口参数:AL=中断向量号 DS:DX=中断向量(段地址:偏移地址)
程序功能 第7章:例7.1的中断调用 ;设置入口参数: DS=段地址(已设置) DX=偏移地址 mov dx,offset intmsg int 80h;调用80H中断服务程序 A Instruction Interrupt !
第7章:例7.1的主程序返回 mov dx,intoff;恢复原中断向量 mov ax,intseg mov ds,ax;改变DS mov ax,2580h int 21h;因紧接着返回DOS mov ax,4c00h;故无需恢复DS int 21h 设置中断向量(DOS功能调用INT 21H) 功能号:AH=25H 入口参数:AL=中断向量号 DS:DX=中断向量(段地址:偏移地址)
第7章:例7.1的中断服务程序(1) ;80H号内部中断服务程序: ;显示字符串(以“0”结尾) ;入口参数:DS:DX=缓冲器首地址 new80h proc ;过程定义 sti;开中断 push ax ;保护寄存器 push bx push si
第7章:例7.1的中断服务程序(2) mov si,dx new1: mov al,[si] ;读取欲一个显示字符 cmp al,0;为结尾“0”,则结束 jz new2 mov bx,0;采用ROM-BIOS功能调用 mov ah,0eh ;bl内容为前景色 int 10h inc si;准备显示下一个字符 jmp new1
程序功能 第7章:例7.1的中断服务程序(3) new2: pop si ;恢复寄存器 pop bx pop ax iret;中断返回 new80h endp ;过程(中断服务程序)结束 A Instruction Interrupt !
7.8 中断优先级管理器8259A PIC • Intel 8259A是可编程中断控制器PIC • 用于管理Intel 8080/8085、8086/8088、80286/80386的可屏蔽中断 • 8259A的基本功能 • 一片8259A可以管理8级中断,可扩展至64级 • 每一级中断都可单独被屏蔽或允许 • 在中断响应周期,可提供相应的中断向量号 • 8259A设计有多种工作方式,可通过编程选择
INTA 控制逻辑 INT D7~D0 数据 总线 缓冲器 RD 中断服务寄存器 优先权判别电路 中断请求寄存器 IR0 WR 读/写 控制 逻辑 A0 CS IR7 CAS0 级联 缓冲器 比较器 CSA1 CAS2 中断屏蔽寄存器 SP/EN 第7章: 7.3.1 8259A的内部结构
第7章:8259A的内部寄存器 • 中断请求寄存器IRR • 保存8条外界中断请求信号IR0~IR7的请求状态 • Di位为1表示IRi引脚有中断请求;为0表示无请求 • 中断服务寄存器ISR • 保存正在被8259A服务着的中断状态 • Di位为1表示IRi中断正在服务中;为0表示没有被服务 • 中断屏蔽寄存器IMR • 保存对中断请求信号IR的屏蔽状态 • Di位为1表示IRi中断被屏蔽(禁止);为0表示允许
8259A的内部寄存器 • 优先权判别器PR • 根据CPU发来的命令字定义和修改IRR中各中断源的优先级别 • 多个中断源同时请求中断时,可根据各中断源的优先级别判断并选择出最高的优先级别,进而判断该优先权是否高于正在处理的中断 • 若当前申请中断的最高优先权高于正在处理的中断级,则向CPU发出中断请求信号
7.8.2 8259A的编程 • 8259A的中断操作能很强,包括中断的请求、屏蔽、排队、结束、级联以及提供中断类型号和查询等操作,并且其操作的方式也有不同。它既能实现向量中断,又能进行查询中断,它可用于16位机,也可用于8位机。 • 对8259A编程分两步: • 在系统加电和复位后,用初始化命令对8259A芯片进行初始化编程 • 在操作阶段,用操作命令字对8259A进行操作过程编程,即实现对8259A的状态、中断方式和中断响应次序等的管理
7.8.2 8259A的编程—初始化命令字及其编程 • ICW1命令字--中断请求触发方式 • 8259A为了判断有无外部设备提出中断请求,设有两种检测方法供选择:电平触发和边沿触发。 • 电平触发方式 • 在IR输入线上检测出一个高电平,并且在第一个INTA* 脉冲到来之后可维持高电平,就认为有外设提出中断请求,并使IRR相应位持续置1。电平触发方式提供了重复产生的中断,用于需要连续执行子程序直到中断请求IR变低为止的情况。应注意及时撤除高电平。 • 边沿触发方式 • 当在IR输入端检测到由低到高的上跳变时,且高电平保持到第一个INTA* 到来之后,8259A就认为有中断请求。
初始化命令字及其编程 • ICW1的格式如下: 其中:D4位为ICW1的特征位,必须为“1”。D3位决定电平触发方式(LTIM):D3=1,为电平触发;D3=0,为边沿触发。 D1位决定单片使用(SNGL):D1=1,为单片使用;D1=0,为多片级联方式。 D0位决定是否需要初始命令字ICW4配合,(对8088/8086一般都需使用ICW4),D0=1, 需要ICW4;D0=0,不需要ICW4。 其他位只对8位微机(8085)有效,故写0。
初始化命令字及其编程 例如,若8259A采用电平触发,单片使用,需要ICW4,则程序段为: MOV AL,1BH ;ICW1的内容00011011B OUT 20H,AL ;写入ICW1端口(A0=0) 8259A的命令字/状态字读写条件
初始化命令字及其编程 • ICW2命令字—中断类型号设定 • 8259A提供给CPU的中断类型号是一个8位代码,是通过初始化命令ICW2提供的。但由于ICW2的低3位被8位机占用,因此只有高5位是在初始化编程时,通过命令字ICW2写入的,它的低3位是由中断请求线IRi的二进制编码(如IR4的编码为100)决定,并且是在第一个INTA到来时,将这个编码写入低3位的。ICW2的格式如下:
初始化命令字及其编程 • 例如,在PC系列中断系统中,硬盘中断类型号的高5位是08H,它的中断请求线连到 8259A的IR5上,在向ICW2写入中断类型号时,只写中断类型号的高5位(08H),低3位可以取0: MOV AL,08H ;ICW2的内容(中断类型号高5位) OUT 21H,AL ;写入ICW2的端口(A。=1) 当CPU响应硬盘中断请求时,8259A把IR5的编码101作为低3位构成一个完整的8位中断类型号0DH(00001101B),经数据总线发送给CPU。 可见,外部硬中断中断源的中断号(8位代码)是由两部分构成的,即高5位(ICW2)+低3位(IRi的编码)。
初始化命令字及其编程 • ICW3命令字--中断级联方式的设定
初始化命令字及其编程 • ICW3对主控芯片和从控芯片要分开写,其格式分别为: 若主控输入端IRi上联接从控,则Si=1;否则,Si =0。例如,上页图中主控的IR3和IR6的两个输入端分别联接了从控A与B。故: 主控ICW3的值=01001000B=48H MOVAL,48H ;ICW3(主)内容 OUT21H,AL ;写入ICW3端口(A0=1)
初始化命令字及其编程 3位从控标志码可有8种编码,表示从控的中断请求线INT被联到主控的哪一个输入端IRi。 例如,图中从控A和B的请求线INT分别联到主控的IR3和IR6,故: 从控A的ICW3的内容=00000011B=03H 从控B的ICW3的内容=00000110B=06H MOV AL,03H ;ICW3(从片A)内容 OUT 0A1H,AL ;写入ICW3(从片A)端口(A0=1)
0 0 0 SFNM BUF M/S AEOI uPM 初始化命令字及其编程 • ICW4命令字--特殊完全嵌套方式的设定 • 只有ICW1中的IC4=1,才需设置ICW4,其格式如下: SFNM:置“1”表示特殊全嵌套方式. 否则是正常全嵌套方式. BUF:置“1”表示采用缓冲方式.SP/EN作为输出. 否则是非缓冲方式.SP/EN为输入.接高电平. M/S:当工作在缓冲方式下,该位置“1”是主片. AEOI:置“1”表示中断自动结束.第二个INTA脉冲. 否则中断正常结束.在处理程序中用命令字. uPM:置“1”表示8259A工作于8086/8088模式. 否则工作于8086/8085模式.