微机原理与接口技术课件 7.中断向量表(已看).ppt

微机原理与接口技术课件 7.中断向量表(已看).ppt

  1. 1、本文档共53页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
微机原理与接口技术课件 7.中断向量表(已看)

第七讲 中断技术 中断之概念 “中断”意思为打断操作的顺序。CPU正在执行程序,有个“中断”打断了指令的正常执行顺序,使得CPU中止正在执行的程序转而去执行被称为中断服务程序(ISR)的其它程序。 中断之目的 计算机系统中引入中断的目的主要有两个: 数据的传送; 异常的处理; 中断之种类 外部中断:来自处理器外部的中断,如键盘引起的中断; 内部中断:由处理器电路或中断指令产生的中断,如除0中断,int指令等。 8086的中断向量表 存放各类中断的中断服务程序的入口地址CS:IP(段CS和偏移IP)——中断向量 表的地址位于内存的00000H~003FFH,大小为1KB,共256个中断向量(中断向量表) 每个中断向量占用4 Bytes,低字为段内偏移IP,高字为段基址CS 根据中断类型号n获得中断服务程序入口的方法: 中断向量在IVT中的存放地址=4×n (中断向量地址) 初始化——将中断服务程序的入口地址放入向量表 例:中断类型码n为48H的中断处理子程序的名字为int48h. 内部中断的种类 除法溢出:类型号0,执行除法指令时,若发现除数为0或商大于目的操作数所能表达的范围时产生。 单步中断:类型号1,TF=1时产生(当前指令需执行完)。 断点中断:类型号3,这是一个软件中断,即INT 3指令。一般用于程序调试,在断点中断服务程序中,可显示有关寄存器、存储单元等内容,以便程序员分析到断点为止程序是否正确。 溢出中断:类型号4,这是一个软件中断,即INTO指令。 若算术指令的执行结果发生举出(OF=1),则执行指令后立即产生一个中断类型码为4的中断。 软件中断:即INT n指令,类型号n(0-255)。 外部中断的种类 与(外部)中断有关的引脚 中断过程 五个步骤: 中断请求 中断判优/排队 (有时还要进行中断源识别) 中断响应 中断服务/处理 中断返回 中断源的识别 8088/8086系统采用中断类型码n来识别不同的中断源。每个中断源都有一个与它相对应的中断类型码n 。 溢出、断点、除法溢出、单步、非屏蔽中断的类型码为固定值(4、3、0、1、2) 软件中断的类型码由指令INT n 给出(n) 可屏蔽中断的类型码由PIC(8259)给出(n) CPU响应INTR中断时,会产生两个中断响应总线周期INTA,要求PIC在第2个中断响应总线周期把中断类型码 n 放到数据总线上,供CPU读入。 中断优先级 背景:系统有多个终端,而CPU同一个时刻只能响应一个中断,为了解决这个矛盾应按中断的轻重缓急来确定中断的优先级别. 8088/8086系统中各中断的优先级 优先级从高到低顺序如下: 软件中断、内部中断 (除单步中断外) NMI INTR 单步中断 中断判优 中断优先级控制要处理两种情况: 对同时产生的中断:应首先处理优先级别较高的中断;若优先级别相同,则按先来先服务的原则FIFO处理; 对非同时产生的中断:低优先级别的中断处理程序允许被高优先级别的中断源所中断——即允许中断嵌套。 通常将中断判优与中断源识别合并在一起进行处理。 x86系统中,这项任务由PIC(8259)和CPU(8086/8088)共同完成。 CPU响应中断的条件 内部中断请求:直接转入中断周期,由内部硬件自动执行预定的操作。 外部中断请求:中断屏蔽触发器开放;CPU内部是中断开放的;没有更高级的中断请求正在被响应或正在发出;CPU现行指令结束; 中断处理过程 在满足中断响应条件以后,CPU就响应中断请求,并自动关中断,然后进入中断服务程序,在中断服务程序中要完成以下工作: 保护现场 开中断 完成输入输出或异常处理的服务程序 关中断 恢复现场 开中断 中断返回 8086/8088 CPU的中断响应过程 内部中断响应过程 : 无INTA周期 中断类型码固定(0、1、3、4)或由指令给出(n) 响应过程主要步骤: ① PUSH FLAGS ② IF=TF=0(关可屏蔽中断和单步中断) ③ PUSH CS ④ PUSH IP ⑤ 取中断向量送入IP’和CS’ 中断响应过程(续) 外部中断响应过程 非屏蔽中断NMI,中断类型码为固定(2) 与内部中断响应过程类似 可屏蔽中断INTR ① INTA(1)PIC进行优先级排队判优处理 ② INTA(2)PIC把中断类型码n放到DB上,CPU读入 ③ PUSH FLAG ④ IF=TF=0(关可屏蔽中断和单步中断) ⑤ PUSH CS ⑥ PUSH IP ⑦ 取中断向量送入

文档评论(0)

ctuorn0371 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档