- 1、本文档共10页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
-中断处理和定时计数技术.ppt
2. 中断源:是指能够引发中断的事件。 内部中断源:CPU内部产生 a. 软件中断。INT等软中断 b. 执行指令出错。如除法错误等 外部中断源:外部设备产生 a.输入、输出设备中断 b.实时时钟中断 c.实时监控系统中断等 d. 计算机掉电、I/O通道出错、内存读、写出错等 2.中断检测与响应 3. 中断矢量表 中断矢量表给出了不同中断源与其终端入口地址的对应关系。响应中断时CPU能根据中断源提供的中断类型号在中断矢量表中找到相应中断服务子程序入口地址。 4.中断屏蔽 中断屏蔽是指CPU通过软件能够实现中断禁止的一种功能。 7.1.2 中断处理过程 3)中断响应 CPU对内部中断源提出的中断请求必须接受,而对外部中断源产生的中断请求是否响应则取决于外中断源类型及响应条件。如CPU对非屏蔽中断请求会立即做出响应,而对可屏蔽中断请求则要根据当时的条件做出反应。CPU在每条指令执行的最后一个时钟周期对外部中断进行检测。 中断相应过程是硬件软件相互配合的过程,不同系统有不同的实现方法,一般有一下两种: 中断隐指令:CPU相应中断后,由硬件电路直接向CPU提供调用指令的机器码,接着CPU执行这条,而转入中断程序入口地址。 中断矢量:由请求中断的外设向CPU提供中断矢量,CPU在中断矢量表中查找对应中断矢量的中断入口地址,并转去执行中断服务程序。 XOR AL, AL MOV DX, 340H IN AL, DX RCR AL, 1 JC SV0 RCR AL, 1 JC SV1 RCR AL, 1 JC SV2 RCR AL, 1 JC SV3 7.2 8086微处理器的中断方式 7.3 中断管理 8088的中断系统采用向量中断机制,也叫矢量中断或者类型中断。 能够处理256个中断。用中断向量号0-255区别。 这256种不同类型的中断可以来自外部,即由硬件产生,也可以来自内部,即由软件(中断指令)产生,或者满足某些特定条件后引发CPU中断。 可屏蔽中断还需要借助专用中断控制器Intel 8259A实现优先权管理 8086的中断类型 内部中断 除法错中断 单步中断 断点中断 溢出中断 指令中断 1. 外部中断 外部中断是由于8086外部提出中断请求引起的程序中断。 利用外部中断,微机系统可以实时响应外部设备的数据传送请求,能够及时处理外部意外或紧急事件。 外部中断是由处理器外部随机产生的,是真正的中断(Interrupt)。 内部中断是处理器执行程序出现异常,所以经常被称为异常(Exception)。 ⑴ 非屏蔽中断 通过非屏蔽中断请求信号NMI向微处理器提出的中断请求,微处理器无法禁止,将在当前指令执行结束予以响应,这个中断被称为非屏蔽中断。 8086的非屏蔽中断的向量号为2。 非屏蔽中断主要用于处理系统的意外或故障。例如: 电源掉电前的数据保护 存储器读写错误的处理 ⑵ 可屏蔽中断( INTR ) 外部通过可屏蔽中断请求信号向微处理器提出的中断,微处理器在允许可屏蔽中断的条件下,在当前指令执行结束予以响应,同时输出可屏蔽中断响应信号,这个中断就是可屏蔽中断 8086的可屏蔽中断请求和响应信号分别是INTR和INTA*;由IF标志控制可屏蔽中断是否允许响应;向量号来自外部中断控制器 8086通常需要配合中断控制器8259A共同处理可屏蔽中断 可屏蔽中断主要用于主机与外设交换数据 INTR中断处理过程(无嵌套) 2. 内部中断 内部中断是由于8086内部执行程序出现异常引起的程序中断 利用内部中断,微处理器为用户提供了发现、调试并解决程序执行时异常情况的有效途径 例如,ROM-BIOS和DOS系统利用内部中断为程序员提供了各种功能调用 (1)除法错中断 类型号为00H 在执行除法指令时,若除数为0或商超过了寄存器所能表达的范围,则产生一个向量号为0的内部中断,称为除法错中断。 例如: (2)单步中断(陷阱中断) 类型号为01H 若CPU内的标志寄存器FLAGS中的跟踪标志TF=1且中断允许标志IF=1时,每执行完一条指令,CPU将引起一次类型号为1的内部中断,称为单步
文档评论(0)