一章中断技术教材课程.pptVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
中断技术;6.1 中断概述 ;凡是能发出中断请求的外部设备及内部原因(包括软件中断和异常故障)被称为中断源。常见的中断源有: 外设中断:系统外设要求与CPU交换信息而产生的中断。如打印机、磁盘等。 指令中断:为方便用户使用系统资源或调试程序而设置的中断指令。 程序中断:程序在运行过程中出现的多种错误而产生的中断。如溢出中断、非法除数中断、地址越界中断、非法操作码中断等。 故障中断:机器在运行过程中,硬件出现错误而引起的中断。如校验错、电源故障等。 ;CPU响应中断??条件: 设置中断请求触发器(发出中断) 设置中断屏蔽触发器(屏蔽中断) 设置中断允许触发器(允许中断) CPU在现行指令结束后响应中断 具有中断屏蔽功能的接口电路示例 ;中断优先级(Priority),又称优先权,即在多个中断源同时请求中断时,确定服务的次序。解决中断的优先级的方法常有以下几种: 软件查询确定中断优先级(原理图) 硬件查询确定优先级(链式优先级排队原理图) 中断优先级编码电路(由编码器和比较器构成的优先级排队电路原理图) ;中断嵌套,或称多重中断,即当CPU执行优先级较低的中断服务程序时,允许响应比它优先级高的中断源请求中断,而挂起正在处理的中断。 多个中断源、单一中断请求线的多重中断流程 ;可屏蔽中断INTR 8086/8088的中断时序 不可屏蔽中断NMI(中断类型码固定为2),用于通知CPU发生了“灾难性”的事件,如电源掉电、存储器读写错误、总线奇偶位出错等 。;溢出中断(4号中断) 除法出错中断(0号中断) INT n指令中断 断点中断(3号中断) 单步(陷阱)中断(1号中断);中断向量:是中断服务程序的入口地址,包括中断服务程序的段基址CS和偏移地址IP(共占4个字节)。 中断向量表:是存放中断向量的表格,它存放在存储器的最低端,共1KB,存放256个中断向量。 向量地址:是在中断向量表中,每个中断向量在存储空间上的最低地址,是将中断类型码乘4以获取。 8086/8088的中断向量表结构;(1)保护断点。即把当前标志寄存器PSW、代码段寄存器CS和指令指针寄存器IP的内容压入堆栈: (SP)←(SP)- 2 ((SP)+1,(SP))←(PSW) (SP)←(SP)- 2 ((SP)+1,(SP))←(CS) (SP)←(SP)- 2 ((SP)+1,(SP))←(IP);(2)清除IF和TF,即IF←0,TF←0,以便禁止其它可屏蔽中断和单步中断 (3)获取中断向量。将中断类型码乘以4获得向量地址,根据向量地址查找中断向量表后,将对应的中断向量放入CS和IP,从而将控制转入中断服务程序: (IP)←[0000H:4×N] (CS)←[0000H:4×N+2];在中断服务程序执行完后,最后要执行一条中断返回指令IRET,将原压入堆栈的标志和断点重又弹回原处: (IP)←((SP)+1,(SP)) (SP)←(SP)+ 2 (CS)←((SP)+1,(SP)) (SP)←(SP)+ 2 (PSW)←((SP)+1,(SP)) (SP)←(SP)+ 2;【例】某外设中断类型号为13H,它的中断服务程序的入口地址为0070H:0FC9H,求其向量地址并具体描述中断向量的各字节在存储器中的存储情况。 【解】由13H×4=4CH,可得中断类型号为13H的向量地址为0000H:004CH,该中断向量在向量表中的具体存储情况如下: (0000H:004CH)=C9H (0000H:004DH)=0FH (0000H:004EH)=70H (0000H:004FH)=00H; INTER1 PROC FAR PUSH AX ;保护现场 PUSH BX …… ;中断服务程序 STI ;开中断,以便允许多重中断 …… ;继续执行中断服务程序 (发中断结束命令) ;中断控制器8259A所要求的 POP BX ;恢复现场 POP AX IRET ;中断返回 INTER1 ENDP;中断向量并非常驻内存,而是开机上电时,由程序装入内存指定的中断向量表中。系统配置和使用的中断所对应的中断向量由系统软件负责装入,而用户编写的中断,其中断向量则要由用户自行装入。 【例】某外设的中断服务程序为INTER1,其中断类型号为N,试编写一程序将该外设的中断向量装入到中断向量表中。(程序示例);thanks!;;;;;;;;;;;;;方法一: MOV AX, 0 ;中断向量表的段基址 MOV ES, A

文档评论(0)

yuzongjuan7808 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档