第 7 章 中断技术
description
Transcript of 第 7 章 中断技术
![Page 1: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/1.jpg)
第 7 章 中断技术
![Page 2: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/2.jpg)
7.1 中断的基本概念 什么是中断 ?
与生活场景的比较
正在看书电话铃响
接电话继续看书
执行程序事件发生事件处理
继续执行程序中断处理
中断请求及响应
实际场景 计算机
中断返回
![Page 3: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/3.jpg)
中断的定义 CPU 执行程序时,由于发生了某种随机的事件 ( 外部或内部 ) ,引起 CPU 暂时中断正在运行的程序,转去执行一段特殊的服务程序 ( 称为中断服务程序或中断处理程序 ) ,以处理该事件,该事件处理完后又返回被中断的程序继续执行,这一过程称为中断。
![Page 4: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/4.jpg)
中断源 引起 CPU 中断的事件——中断源。例如:
外设——请求输入输出数据,报告故障等 事件——掉电、硬件故障、软件错误、非法操作、定时时间到等
中断源分为:外部中断、内部中断 内部中断: CPU 内部执行程序时自身产生的中断 外部中断: CPU 以外的设备、部件产生的中断
8086/8088 的外部中断信号: INTR、NMI INTR—— 可屏蔽中断请求,高电平有效,受 IF 标志的控制。 IF=1 时,执行完当前指令后 CPU 对它作出响应。 NMI—— 非屏蔽中断请求,上升沿有效,任何时候 CPU都要响应此中断请求信号。
![Page 5: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/5.jpg)
为何计算机中要引入中断? 提高数据传输率; 避免了 CPU 不断检测外设状态的过程,提高了 CPU 的利用率。 实现对特殊事件的实时响应。如多任务系统操作系统中:
缺页中断 设备中断 各类异常 实时钟,。。。等
![Page 6: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/6.jpg)
中断过程 五个步骤:
中断请求 中断判优 ( 有时还要进行中断源识别 ) 中断响应 中断服务 中断返回以下以外部中断为主介绍这五个步骤。
![Page 7: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/7.jpg)
1 )中断请求 外设接口(中断源)发出中断请求信号,送到
CPU的 INTR或NMI 引脚; 中断请求信号:边沿请求,电平请求
例如, NMI 为边沿请求, INTR 为电平请求 中断请求信号应保持到中断被处理为止; CPU 响应中断后,中断请求信号应及时撤销。 在 8086/8088 系统中,外设的中断要经过
8259A 可编程中断控制器 (PIC) 的排队判优后向CPU 发出:
(I/O 接口 ) → PIC → CPUn1
![Page 8: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/8.jpg)
2.1 )中断源识别 计算机中的中断源有很多, CPU 必须识别是哪一个设备产生中断。识别中断源有两个方法:
软件查询。将中断信号从数据总线读入,用程序进行判别,如教材图 7-3 和图 7-4 。 中断矢量法。由中断源提供中断类型号, CPU根据类型确定中断源。( 8086/8088 即采用此种方法)
![Page 9: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/9.jpg)
2.2 )中断判优 多个中断源产生中断, CPU 首先为谁服务?
—— 中断优先级排队问题。 中断优先级控制要处理两种情况:
对同时产生的中断:应首先处理优先级别较高的中断;若优先级别相同,则按先来先服务的原则处理; 对非同时产生的中断:低优先级别的中断处理程序允许被高优先级别的中断源所中断——即允许中断嵌套。
中断优先级的控制方法 硬件判优——链式判优、并行判优(中断向量法) 软件判优——顺序查询中断请求,先查询的先服务(即先查询的优先级别高)
通常将中断判优与中断源识别合并在一起进行处理。 x86 系统中,这项任务由 PIC和 CPU 共同完成。
![Page 10: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/10.jpg)
INTAin
CPU
INTA
INTR
外设 1 外设 2
外设接口1
菊花链逻辑电路
外设接口2
外设 3
外设接口3
≥1
菊花链逻辑电路
菊花链逻辑电路
┇
IREQ IREQ IREQ
中断确认
链式判优电路原理图(教材图 7-5 )
INTAin INTAin
中断确认 中断确认
![Page 11: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/11.jpg)
菊花链逻辑电路
INTAin
IREQ
INTR
&
=1 ≥1
INTAout
DB
三态门 中断向量码E
外设接口
中断确认菊花链逻辑电路
![Page 12: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/12.jpg)
3 )中断响应 在每条指令的最后一个时钟周期, CPU 检测 INTR或 NMI 信号。若以下条件成立,则CPU 响应中断: 当前指令执行完。对 INTR ,还应满足以下条件
当前指令是 STI和 IRET ,则下条指令也要执行完。 当前指令带有 LOCK、 REP 等指令前缀时,则把它们看成一个整体,要求完整地执行完;
对 INTR, CPU 应处于开中断状态,即 IF=1 ; 当前没有复位 (RESET) 和保持 (HOLD) 信号。 若 NMI 和 INTR 同时发生,则首先响应 NMI 。
![Page 13: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/13.jpg)
3 )中断响应(续) CPU 中断响应时,要做下述三项工作:
向中断源发出 INTA 中断响应信号; 断点保护,包括 CS、 IP和 PSW( FLAGS )。这主要是保证中断结束后能返回被中断的程序。 获得中断服务程序首地址(入口)。
如何得到中断处理程序的首地址? 固定入口法 中断向量法——常用
![Page 14: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/14.jpg)
4 )中断处理(中断服务) 中断服务子程序特点
为”远”过程(类型为 FAR ) 要用 IRET 指令返回
中断服务子程序要做的工作 保护现场 (PUSH reg’s) 开中断 (STI) 进行中断处理 恢复现场 (POP reg’s) 中断返回 (IRET)
![Page 15: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/15.jpg)
5 )中断返回 执行中断返回指令 IRET
IRET 指令将使 CPU 把堆栈内保存的断点信息弹出到 IP、 CS和 FLAG 中,保证被中断的程序从断点处能够继续往下执行。IPL
IPH
CSL
CSH
FLAGL
FLAGH
SP IPL
IPH
CSL
CSH
FLAGL
FLAGH
SP
IP
CS
FLAG
进入中断服务程序时 中断返回后
![Page 16: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/16.jpg)
8088 的中断系统 与中断有关的控制线为: NMI、 INTR、 INTA# 8088 系统的中断源
内部中断 除法溢出:类型号 0 ,商大于目的操作数所能表达的范围时产生。 单步中断:类型号 1 , TF=1 时产生(当前指令需执行完) 断点中断:类型号 3 ,这是一个软件中断,即 INT 3 指令。 溢出中断:类型号 4 ,这是一个软件中断,即 INTO 指令。 软件中断:即 INT n 指令,类型号 n(0-255) 。
外部中断 非屏蔽中断 NMI :类型号 2 ,不可用软件屏蔽, CPU 必须响应它。 可屏蔽中断 INTR :类型号由 PIC 提供。 IF=1时 CPU 才能响应。
![Page 17: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/17.jpg)
NMI
INTR
中断逻辑
软件中断指令
溢出中断
除法错
单步中断
非屏蔽中断请求
中断控制器
8259APIC
8086/8088CPU 内部逻辑
断点中断
8086/8088 中断源类型
可屏蔽中断请求
n
4
3
0
1
2
![Page 18: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/18.jpg)
中断源的识别 8088 系统采用中断类型码来识别不同的中断源,每个中断源都有一个与它相对应的中断类型码 。
溢出、断点、除法溢出、单步、非屏蔽中断的类型码为固定值 软件中断的类型码由指令给出 可屏蔽中断的类型码由 PIC给出
CPU 响应 INTR 中断时,会产生两个中断响应总线周期 ( 教材图 6.24) ,要求 PIC 在第2 个中断响应总线周期把中断类型码放到数据总线上,供 CPU 读入。
![Page 19: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/19.jpg)
中断向量表( IVT ) 存放各类中断的中断服务程序的入口地址(段和偏移)——中断向量 表的地址位于内存的 00000H~ 003FFH ,大小为 1KB ,共 256 个中断向量 每个中断向量占用 4 Bytes ,低字为段内偏移,高字为段基址 根据中断类型号获得中断服务程序入口的方法 : (n 为中断类型号 ) 中断向量在 IVT 中的存放地址= 4×n
![Page 20: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/20.jpg)
中断向量表的初始化 初始化——将中断服务程序的入口地址放入向量表 例:中断类型码为 48H 的中断处理子程序的名字为 int48h ,编写程序段将该中断处理子程序的入口地址放入向量表。
![Page 21: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/21.jpg)
中断向量表的初始化 CLI MOV AX, 0 MOV DS, AX MOV SI, 48H*4 MOV AX,OFFSET int48h MOV [SI], AX MOV AX, SEG int48h MOV [SI+2], AX STI
![Page 22: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/22.jpg)
8086/8088 CPU 的中断响应过程 内部中断响应过程
无 INTA# 周期 中断类型码固定或由指令给出 响应过程主要步骤:
① PUSH FLAG ② IF=0
③ PUSH CS ④ PUSH IP
⑤ 取中断向量送入 IP和 CS
![Page 23: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/23.jpg)
中断响应过程(续) 外部中断响应过程
非屏蔽中断,与内部中断响应过程类似 可屏蔽中断 ( 时序见教材图 6.24)
① INTA#( 1 ), PIC 进行优先级排队判优处理 ② INTA#( 2 ), PIC把中断类型码放到 DB 上, CPU 读入 ③ PUSH FLAG ④ IF=0
⑤ PUSH CS ⑥ PUSH IP ⑦ 取中断向量送入 IP和 CS
与内部中断一样
![Page 24: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/24.jpg)
8088 系统中各中断的优先级 优先级从高到低顺序如下:
内部中断 NMI INTR 单步中断
![Page 25: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/25.jpg)
N
Y
N
Y
N
N
N
N
N
Y Y
执行指令
执行完否 ?
取指令
IF=1?
内部中断 ?
NMI?
INTR?
TF=1?
类型码 =0~255
类型码 =2
类型码 =1
中断响应,读回类型码
FLAG 入栈TEMP←TF
TF=TF=0
CS、 IP 入栈计算向量表地址
高字→ CS低字→ IP
执行中断服务程序
NMI?
TEMP=1?
转入中断服务程序
恢复 CS和 IP
恢复 FLAGS
返回被中断的程序
Y
Y
Y
Y
N
IRET指令的操作
8086/8088 的中断处理流程
![Page 26: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/26.jpg)
NMI、 INTR 、单步和除法错中断同时产生时的中断处理过程
DIV
TF=1IF=1
INTR NMI
PUSH FLAGS、 CS、 IPCLEAR IF & TF ,中断入口→ CS:IP
除法错
NMI(IF、 TF = 0)
PUSH FLAGS、 CS、 IPCLEAR IF & TF ,中断入口→ CS:IP
NMI 中断处理程序
除法错中断处理程序(IF、 TF = 0) 返回
执行下条指令识别出 INTR
(IF、 TF = 1) 返回INTR仍然有效
继续单步执行程序
INTR 中断处理程序
INTRPUSH FLAGS、 CS、 IP
CLEAR IF & TF ,中断入口→ CS:IP单步 (IF、 TF =
0)PUSH FLAGS、 CS、 IP
CLEAR IF & TF ,中断入口→ CS:IP
单步中断处理程序(IF、 TF = 0) 返回
(IF、 TF = 1) 返回
![Page 27: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/27.jpg)
7.3 可编程中断控制器8259A
PIC, Programmable Interrupt Controller
可对 8 个中断源实现优先级控制 可扩展至对 64 个中断源实现优先级控制 可编程设置不同工作方式 根据中断源向 x86 提供不同中断类型码 引脚分配及功能见教材图 7-7
![Page 28: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/28.jpg)
8259A 的内部结构 8259A 的内部结构(教材图 7.6 )
中断请求寄存器 IRR 保存从 IR0~ IR7来的中断请求信号,某位=1表示对应的 IRi有中断请求
中断服务寄存器 ISR 保存所有正在服务的中断源,某位=1表示对应的 IRi 中断正在被服务
中断屏蔽寄存器 IMR 存放中断屏蔽字,某位=1表示对应的 IRi 输入被屏蔽
中断优先权判别电路 确定是否向 CPU 发出中断请求,中断响应时确定 ISR 的哪位应置位及把相应中断的类型码放到数据总线上
![Page 29: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/29.jpg)
8259A 的工作过程 8259A 对中断请求的处理过程如下:
当某 IRi 有效时, IRR 相应位置 1 若有效的 IRi 未被屏蔽,则向 CPU 发出中断请求 检测到第 1 个 INTA# 信号后,置 ISRi=1, IRRi=0 检测到第 2 个 INTA# 信号后,把 ISRi=1 中最高优先级的中断类型码放到 DB 上 若工作在 AEOI 方式,在第 2 个 INTA# 结束时,使
ISRi 复位;否则由 CPU 发出 EOI 命令使 ISRi 复位
![Page 30: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/30.jpg)
8259A 的工作方式 8259A 的工作方式有如下几类:
中断优先方式与中断嵌套 中断结束处理方式 屏蔽中断源的方式 中断触发方式 级联工作方式
![Page 31: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/31.jpg)
中断优先方式与中断嵌套 中断优先方式
两类优先级控制方式:固定优先级和循环优先级 固定优先级方式
所有中断请求 IRi的中断优先级固定不变 优先级排列顺序可编程改变 加电后 8259A 的默认方式,默认优先级顺序从高到低为 IR0~ IR7
IR7 IR6 IR5 IR4 IR3 IR2 IR1 IR0
7 6 5 4 3 2 1 0 3 2 1 0 7 6 5 4
最低级 最高级 最高级 最低级优先级
IR7 IR6 IR5 IR4 IR3 IR2 IR1 IR0
默认优先级 优先级可编程改变
![Page 32: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/32.jpg)
中断优先方式与中断嵌套(续) 循环优先级方式
中断源轮流处于最高优先级,即自动中断优先级循环 初始优先级顺序可用编程改变 某中断请求 IRi被处理后,其优先级别自动降为最低,原来比它低一级的中断上升为最高级
IR7 IR6 IR5 IR4 IR3 IR2 IR1 IR0
7 6 5 4 3 2 1 0 2 1 0 7 6 5 4 3
最低级 最高级 最高级 最低级
ISR 内容IR7 IR6 IR5 IR4 IR3 IR2 IR1 IR0
IR4 的服务结束以前
0 1 0 1 0 0 0 0 0 1 0 0 0 0 0 0
IR4 的服务结束以后
ISRi
![Page 33: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/33.jpg)
中断优先方式与中断嵌套(续) 中断嵌套方式
在中断处理过程中允许被更高优先级的事件所中断称为中断嵌套。 8259A 有两种中断嵌套方式: 普通全嵌套方式(默认方式)
一中断正被处理时,只有更高优先级的事件可以打断当前的中断处理过程而被服务。 特殊全嵌套方式
一中断正被处理时,允许同级或更高优先级的事件可以打断当前的中断处理过程而被服务。注 : 特殊全嵌套仅用于多个 8259A 级连时的主 8259A ,而不能用于从属 8259A 或单 8259A 系统。
![Page 34: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/34.jpg)
D.
主 8259A
IR0
IR1
IR2
IR3
IR4
IR5
IR6
IR7
一般嵌套方式:从片的 INT 被主片封锁,故更高级别的 IR0-IR2 中 断也无法得到响应
特殊嵌套方式:因主片不封锁从片的INT ,故级别高的 IR0-IR2 中断可以得到响应。( 但 IR3-IR7 仍被本从片封锁 )
C.
假定 IR7 发生中断 , 并获得服务
一般嵌套方式:IR4 的中断被服务时 , 这些中 断 将被封锁。
B.
特殊嵌套方式:IR4 的中断被服务 时 ,只封锁IR5-IR7 。
A.
INT
E.
从 8259A
INT
IR0
IR1
IR2
IR3
IR4
IR5
IR6
IR7
一般全嵌套方式与特殊全嵌套方式的区别
去CPU
![Page 35: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/35.jpg)
中断结束处理方式 当某一 IRi中断被服务时, ISR 中的相应位
ISRi=1 。当服务结束后,则必须清零该ISRi位。使 ISRi=0 是通过向 8259A 发出中断结束命令( EOI命令)实现的。
三种 EOI命令 自动 EOI( AEOI)——(自动 EOI 方式) 非指定 EOI( NSEOI)——(正常 EOI 方式) 指定 EOI( SEOI)——(特殊 EOI 方式)
![Page 36: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/36.jpg)
AEOI :在第 2 个 INTA# 结束时,由 8259A使
ISRi 自动复位; 因不保留当前正在服务的中断的状态,故 AEOI 不能用于中断嵌套方式
SEOI :由 CPU 发出一条 SEOI 命令,该 EOI 命令中指出了所要复位的 ISR 的位号。 用于特殊屏蔽方式
NSEOI :由 CPU 发出正常 EOI 命令,该 EOI 命令使 ISRi=1 的位中优先级最高的那一位复位。 用于普通全嵌套方式
![Page 37: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/37.jpg)
中断服务程序┇
向从 PIC发 EOI 命令读从 PIC的 ISR
全 0 ?向主 PIC发 EOI 命令
Y
IRET
恢复现场
N
特殊全嵌套方式下的 EOI 处理只有当从 PIC 的中断全部处理完后,才能向主PIC发 EOI命令
![Page 38: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/38.jpg)
屏蔽中断源的方式 IMR 屏蔽字决定了允许或禁止某位 IRi所对应的中断: IMi=1 禁止, IMi=0 允许。 特殊屏蔽方式:
提供了允许较低优先级的中断能够得到响应的特殊手段。 原理:假定当前正在处理 IR6,先进入特殊屏蔽方式,然后设置 IM6=1 。这时,除 IR6外的所有中断请求均能得到响应。 特殊屏蔽方式中只能用 SEOI 命令结束中断。
![Page 39: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/39.jpg)
特殊屏蔽例:。 ; IR4 中断处理程序CLIMOV AL, 68H ; OCW3: 0 1 1 0 1 0 0 0OUT 0C0H, AL ;设置特殊屏蔽方式IN AL, 0C2H OR AL, 10H ;屏蔽 IR4OUT 0C2H, AL STI。 ; IR7 请求,响应,返回。CLI ;为设命令字IN AL, 0C2H ;读出屏蔽字AND AL, 0EFH ;清除 IMR4OUT 0C2H, ALMOV AL, 48H ;OCW3: 0 1 0 0 1 0 0 0OUT 0C0H, AL ;取消特殊屏蔽STI。 ;继续 IR4 中断服务MOV AL, 20H ;OCW2: 0 0 1 0 0 0 0 0 (EOI)OUT 0C0, ALIRET
![Page 40: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/40.jpg)
中断触发方式 边沿触发
IRi 出现上升沿表示有中断请求 电平触发
IRi 出现高电平表示有中断请求 在第 1 个 INTA#结束前, IRi 必须保持高电平
![Page 41: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/41.jpg)
级联工作方式 单片 8259A 可支持 8 个中断源; 采用多片 8259A 级连,可最多支持 64 个中断源。 n 片 8259A 可支持 7n+1 个中断源; 级连时只能有一片 8259A 为主片,其余的均为从属片; 涉及到的 8259A 引脚包括:
CAS0-CAS2 SP#/EN# IRi INT
![Page 42: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/42.jpg)
级连电路连接方法
8259A( 1)从片
D0-D7INTA INT
SP/EN IR7 IR0IR2IR3IR4IR5IR6 IR1
CAS0
CAS1
CAS2
8259A( 2)从片
D0-D7INTA INT
SP/EN IR7 IR0IR2IR3IR4IR5IR6 IR1
CAS0
CAS1
CAS2
8259A( )主片
D0-D7INTA INT
SP/EN IR7 IR0IR2IR3IR4IR5IR6 IR1
CAS0
CAS1
CAS2
VCC
AB DB CB系统总线 、 、
A0 CS A0 A0CS CSRD WR WRRD WRRD
![Page 43: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/43.jpg)
8259A 的编程使用 8259A 的控制命令分为
初始化命令字 ICW ICW1~ ICW4 向 8259A写入 ICW 的过程称为初始化编程
操作命令字 OCW OCW1~ OCW3 向 8259A写入 OCW 的过程称为操作方式编程
![Page 44: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/44.jpg)
8259A 内部寄存器的寻址方法
CS# RD# WR# A0 D4 D3 读写操作
0 1 0
0 0 0 写 OCW2写 OCW3写 ICW1写 ICW2,ICW3,ICW4,OCW1(顺序写入 )
0 0 10 1 x1 x x
0 0 1 01 x x 读出 IRR、 ISR读出 IMR
需要 CS#、 A0、 RD#、WR#和D4、 D3 的配合
内部寄存器的访问方法如下表:
![Page 45: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/45.jpg)
8259A 的初始化顺序 8259 的初始化流程如图
注意次序不可颠倒 写 ICW1
写 ICW2
级连?写 ICW3
需 ICW4?
写 ICW4
N
N
Y
Y
![Page 46: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/46.jpg)
8259A 的控制命令字 初始化 8259A 必须从 ICW1开始
写 ICW1意味着重新初始化 8259A 写入 ICW1 后, 8259A 的状态如下:
清除 ISR和 IMR(全 0) ; 将中断优先级设成初始状态: IR0 最高, IR7 最低; 设定为一般屏蔽方式; 采用非自动中断结束方式; 状态读出逻辑预置为读 IRR 。
![Page 47: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/47.jpg)
ICW1——初始化字
LTIM: 触发方式 =1 高电平触发 =0 上升沿触发
SNGL: 级连控制 =1 单片 =0 级连
IC4: ICW4 控制 =1 要写 ICW4 =0 不写 ICW4 (默认 ICW4 为全 0 )
A0 D7 D6 D5 D4 D3 D2 D1 D0 0 x x x 1 LTIM x SNGL IC4
![Page 48: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/48.jpg)
ICW2—— 中断向量码
T7~ T3: 中断向量码的高 5 位 T2~ T0: 最低 3 位为中断源的序号 IRn
000~ 111 分别对应 IR0~ IR7
由 8259A 根据中断源的序号自动填入 例如:若 ICW2命令字为 48H ,则 IR0 的中断向量码为48H, IR7 的中断向量码为 4FH ,等等。
A0 D7 D6 D5 D4 D3 D2 D1 D0 1 T7 T6 T5 T4 T3 x x x
![Page 49: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/49.jpg)
ICW3—— 级连控制字 主片的级联控制字
Si=1 对应 IRi 线上连接了从片
A0 D7 D6 D5 D4 D3 D2 D1 D0 1 S7 S6 S5 S4 S3 S2 S1 S0
从片的级联控制字 ID2~ ID0 标识码,说明本从片连接到主片的哪个
IR 引脚上。 000~ 111 分别对应 IR0~ IR7 。
A0 D7 D6 D5 D4 D3 D2 D1 D0 1 0 0 0 0 0 ID2 ID1 ID0
![Page 50: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/50.jpg)
ICW3—— 级连控制字(续) ICW3 必须与主从片的连接关系一致:
例如,主片的 IR4 与从片的 INT 线连接,则主片的 ICW3=10H ,从片的 ICW3=04H 。 中断响应时,主片通过级连线 CAS2-CAS0送出被允许中断的从片标识码,各从片用自己的 ICW3与 CAS2-CAS0 比较,二者一致的从片才可发送中断向量码。
![Page 51: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/51.jpg)
ICW4—— 中断结束方式字
SFNM: 特殊全嵌套1 特殊全嵌套方式0 一般全嵌套方式
AEOI: 自动 EOI1 自动 EOI 方式0 非自动 EOI 方式
A0 D7 D6 D5 D4 D3 D2 D1 D0 1 0 0 0 SFNM BUF M/S AEOI 1
BUF: 缓冲方式 M/S: 主 /从缓冲选择
BUF M/S 1 1 缓冲方式 /主 PIC 1 0 缓冲方式 /从 PIC 0 x 非缓冲方式 /正常
![Page 52: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/52.jpg)
8259A 的操作命令字OCW OCW 用于设置 8259 的工作状态 在初始化后写入 OCW 的写入顺序可任意 写入地址要求:
OCW1 必须写入奇地址端口 (A0=1) OCW2, OCW3 必须写入偶地址端口 (A0=0)
![Page 53: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/53.jpg)
OCW1—— 中断屏蔽字
Mi=1 中断请求线 IRi被屏蔽 ( 不允许中断 ) =0 允许该 IRi中断 OCW1 将写入 IMR寄存器。 A0=1 时读 OCW1 可读出设置的 IMR 内容。
A0 D7 D6 D5 D4 D3 D2 D1 D0 1 M7 M6 M5 M4 M3 M2 M1 M0
![Page 54: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/54.jpg)
OCW2—— 中断结束和优先级循环 L2~ L0: 优先级编码 R: 优先级自动循环 SL: 指定优先级 EOI: 结束中断命令 R SL EOI 0 0 1 非指定 EOI 命令 (NSEOI) ,全嵌套方式 0 1 1 指定 EOI 命令 (SEOI) ,全嵌套方式,按 L2-L0 编码复位 ISR 1 0 1 NSEOI 命令,优先级自动循环 1 0 0 自动 EOI ,设置优先级自动循环 0 0 0 自动 EOI ,取消优先级自动循环 (固定优先级 ) 1 1 1 SEOI 命令,按 L2-L0 编码循环优先级 (L2-L0 设为最低优先级 ) 1 1 0 按 L2-L0 编码循环优先级 (L2-L0 设为最低优先级 )
A0 D7 D6 D5 D4 D3 D2 D1 D0 0 R SL EOI 0 0 L2 L1 L0
![Page 55: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/55.jpg)
OCW3—— 屏蔽方式和读出控制字
ESMM: 允许使能特殊屏蔽方式 SMM: 特殊屏蔽方式ESMM SMM1 1 特殊屏蔽方式置位1 0 特殊屏蔽方式复位0 x 非特殊屏蔽方式P(Polling): =1 查询方式 =0 非查询方式
A0 D7 D6 D5 D4 D3 D2 D1 D0 0 0 ESMM SMM 0 1 P RR
RIS RR: 读寄存器 RIS: ISR/IRR选择RR RIS1 1 读 ISR1 0 读 IRR0 x 无效
![Page 56: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/56.jpg)
OCW3 (续) 查询方式允许 8259A 不工作于中断方式,而是以查询方式工作。
CPU 先写一个 D2=1的 OCW3 ,再对同一地址读入,即可得到如下状态字节: I x x x x R2 R1 R0 I=1表示有中断请求,中断请求号为 R2-R0 此查询步骤可反复执行,以响应多个同时发生 的中断。
读 IRR/ISR :写入此命令后,随后再对同一地址读,即可得到 IRR或 ISR 的内容。
![Page 57: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/57.jpg)
8259A 编程举例 按以下要求初始化 8259A :
接口地址为 20H和 21H ; 中断为上升沿触发;单片 8259A ;不写 ICW4 ; 与 IR0-IR3 对应的中断向量码为 08H-0BH ; IR4-IR7不使用。
根据要求,各初始化参数及工作参数如下: ICW1 = 00010010 = 12H ICW2 = 08H 中断向量码 OCW1 = 11110000 = 0F0H 中断屏蔽字
![Page 58: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/58.jpg)
8259A 编程举例(续)初始化程序如下:INIT8259A :
MOV DX, 20H ; A0=0 ,写 ICW1MOV AL, 12H ;上升沿触发,单片,不写 ICW4OUT DX, ALMOV DX, 21H ; A0=1 ,写 ICW2, OCW1MOV AL, 08H ; ICW2OUT DX, ALMOV AL, 0F0H ; OCW1 :屏蔽 IR4-IR7OUT DX, AL
![Page 59: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/59.jpg)
7.4 PC 机中断程序设计1 )主程序 保存原中断向量设置自己的中断向量初始化堆栈指针设置 8259A 的中断屏蔽字(其他的已由操作系统设置)
STI2 )中断服务程序 保存所用到的寄存器内容中断服务程序主体恢复进入时保存的寄存器内容
发 EOI命令(必要时可提前)STI (必要时可提前)IRET
![Page 60: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/60.jpg)
中断程序举例 PC 机中主 8259A的 I/O地址为 20H和 21H ,中断向量码为 08H ; 中断请求从 IR6 引入,故中断类型号为 0EH ; 主程序如下:
; 保存原来的中断向量mov ah, 35hmov al, 0eh ;中断类型码int 21h ;取原中断向量(在 es:bx 中)mov save_ip, bx ;保存原来的中断向量mov save_cs, es
![Page 61: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/61.jpg)
; 设置自己的中断向量push dsmov dx, offset my_intmov ax, seg my_intmov ds, ax ; DS:DX 的内容为 my_int 的首地址mov ah, 25hmov al, 0ehint 21h ;设置自己的中断向量pop ds;初始化堆栈指针mov sp,my_stack_top
; 设置 8259A 的中断屏蔽字in al, 21hand al, 10111111b ;开放 IR6 中断out 21h, alsti……
<其他代码放在这里 > ……
![Page 62: 第 7 章 中断技术](https://reader036.fdocuments.net/reader036/viewer/2022081508/56813fbb550346895daa99eb/html5/thumbnails/62.jpg)
子程序如下:my_int proc farpusha…
< 中断服务程序主体 >…popamov al, 20h ; EOI命令, 00100000B out 20h, al ;写 OCW2stiiretmy_int endp