- 1、本文档共39页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
7.1 中断系统概述 7.1.1 中断的基本概念 什么是中断? 与生活场景的比较 1. 中断的定义 2. 中断源 引起CPU中断的事件——中断源。例如: 外设——请求输入输出数据,报告故障等 事件——掉电、硬件故障、软件错误、非法操作、定时时间到等 中断源分为:外部中断、内部中断 内部中断:CPU内部执行程序时自身产生的中断 外部中断:CPU以外的设备、部件产生的中断 中断嵌套 7. 2 8086的中断系统 与中断有关的控制线为:NMI、INTR、INTA# 8086系统的中断源 内部中断 除法溢出:类型号0,商大于目的操作数所能表达的范围时产生。 单步中断:类型号1,TF=1时产生 断点中断:类型号3,这是一个软中断 溢出中断:类型号4,软中断即INTO指令。 软件中断:即INT n指令,类型号n(0-255)。 外部中断 非屏蔽中断NMI:类型号2,不可用软件屏蔽,CPU必须响应它。 可屏蔽中断INTR:类型号由PIC提供。IF=1时CPU才能响应。 中断源的识别 8086系统采用中断类型码来识别不同的中断源,每个中断源都有一个与它相对应的中断类型码 。 溢出、断点、除法溢出、单步、非屏蔽中断的类型码为固定值 软件中断的类型码由指令给出 可屏蔽中断的类型码由PIC给出 PC/AT系统硬件中断表 中断向量表的初始化 初始化——将中断服务程序的入口地址放入向量表 例:中断类型码为48H的中断处理子程序的名字为int48h,编写程序段将该中断处理子程序的入口地址放入向量表。 中断向量表的初始化 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 5. 中断处理过程 一个中断处理过程应该包含以下五个过程: (1)中断请求 (2)中断排队 (3)中断响应 (4)中断服务 (5)中断返回 1)中断请求 外设接口(中断源)发出中断请求信号,送到CPU的INTR或NMI引脚; 中断请求信号:边沿请求,电平请求 例如,NMI为边沿请求,INTR为电平请求 中断请求信号应保持到中断被处理为止; CPU响应中断后,中断请求信号应及时撤销。 在8086/8088系统中,外设的中断要经过8259A可编程中断控制器(PIC)的排队判优后向CPU发出: (I/O接口) → 8259A → CPU(INTR) 2)中断排队 中断源识别 中断源有很多,CPU必须识别是哪一个设备产生中断。识别中断源有两个方法: 软件查询。将中断信号从数据总线读入,用程序进行判别。 中断矢量法。由中断源提供中断类型号,CPU根据类型确定中断源。(8086/8088即采用此种方法) 2)中断排队 中断判优 确定当前所有中断请求中优先级最高的中断源。 因为CPU一次只能响应一个中断,所以必须首先处理最紧急最重要的中断。 根据中断源的轻重缓急给予一个中断优先权级别,优先权级别最高的中断源将首先得到响应。 中断优先级的控制方法 硬件判优——链式判优、并行判优(中断向量法) 软件判优——顺序查询中断请求,先查询的先服务(即先查询的优先级别高) x86系统中,这项任务由8259A和CPU共同完成。 3)中断响应 CPU通过中断排队确定了要响应的中断源后,进入中断响应,自动完成以下步骤: ① 标志寄存器入栈 ②关中断;0 → IF ③保护断点,将正要执行的程序地址(CS:IP)入栈; ④形成中断服务程序入口地址。 3)中断响应(续) CPU中断响应时,要做下述三项工作: 向中断源发出INTA中断响应信号; 断点保护,包括FLAGS和CS、IP 。这主要是保证中断结束后能返回被中断的程序。 获得中断服务程序首地址(入口)。 [中断类型码*4] =IP [中断类型码*4+2] =CS 4)中断处理(中断服务) 中断服务是指CPU执行中断服务程序。 中断服务程序应包括: ①保护现场,CPU响应中断时自动保护断点,寄存器则由程序员决定是否要入栈; ②开中断,CPU响应中断时,自动执行关中断操作。要实现中断嵌套,必须在中断服务程序中开中断; 4)中断处理(中断服务) ③中断处理,对中断源作相应的处理,是中断服务程序的核心; ④关中断,若中断服务程序设置了开中断,则此时应该关中断,以保证恢复现场的操作不被打断; ⑤恢复现场,按后进先出的原则,PUSH和POP应配对使用; ⑥中断返回,从堆栈中弹出断点,返回主程序。 5)中断返回 执行中断返回指令IRET IRET指令将使C
文档评论(0)