- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
9.中断与中断管理.ppt
本 章 要 点 中断的基本概念 8086 CPU的中断系统 中断服务程序的编写 9.1 中断原理 什么是中断 中断就是CPU暂停执行现行的程序,转而处理随机事件,处理完毕后再回到被中断的程序继续执行,这一过程称为中断。 中断源:引发CPU中断的来源称为中断源 中断响应:接受中断请求 中断向量:中断服务子程序的入口地址 中断向量表:存放中断向量的内存区域(00000H~003FFH) 中断优先权:有多个中断源请求中断时, 系统响应中断申请的级别 中断屏蔽 :由软件设置,使中断请求不能被响应,称为中断屏蔽。 中断申请 当需要CPU中断以处理一些紧急事件,向CPU发出的请求。引发CPU中断的来源称为中断源 。 中断响应 为了及时处理中断,中断系统(或中断装置)定时查询有无中断申请,若有且未屏蔽,则引出处理中断的程序称为该中断被响应。 CPU响应I/O中断的三个条件: (1)无总线请求 (2)中断允许 (3)CPU执行完现行指令 中断处理 执行相应的中断处理程序(例行中断服务子程序)。 CPU响应中断要自动完成三件事: (1)关闭中断 (2)CS、IP及FR的内容入栈 (3)中断服务程序的段地址送入CS,偏移地址送IP 9.3 中断源识别及中断优先权 1.软件查询 9.4 8086CPU中断系统 8086的中断系统采用向量中断机制 能够处理256个中断 用中断类型号0~255区别 可屏蔽中断还需要借助专用中断控制器Intel 8259A实现优先权管理 8086中断分类 外部中断(硬件中断) 外部中断是由于CPU外部提出中断请求引起的程序中断,也称为硬件中断。 不可屏蔽中断:类型号为2 外部通过非屏蔽中断NMI请求,必须响应 非屏蔽中断主要用于处理系统的意外或故障 可屏蔽中断:类型号来自中断控制器 外部通过可屏蔽中断INTR请求,由IF控制是否响应;响应时产生INTA信号 可屏蔽中断主要用于与外设交换数据 中断标志IF的状态 IF=0:可屏蔽中断不会被响应 关中断、禁止中断、中断屏蔽 系统复位,使IF=0 任何一个中断被响应,使IF=0 执行指令CLI,使IF=0 IF=1:可屏蔽中断会被响应 开中断、允许中断、中断开放 执行指令STI,使IF=1 执行指令IRET恢复原IF状态 内部中断(软件中断) 内部中断是由于CPU内部执行程序出现异常引起的程序中断,所以又称软件中断。内部中断的中断类型号已定(内部中断是不可屏蔽的) 除法错中断:类型号为0 指令中断:类型号为n 断点中断:类型号为3 溢出中断:类型号为4 单步中断:类型号为1 软件中断 由中断指令INT引起的中断 由CPU运算错误引起的中断 由Debug设置的中断 9.5.1 8086CPU的中断处理顺序 内部中断 除法错中断 指令中断 溢出中断 不可屏蔽中断(NMI) 可屏蔽中断 (INTR) 单步中断 8086的中断向量表 中断向量:中断服务程序的入口地址(首地址) 逻辑地址含有段地址CS和偏移地址IP(32位) 每个中断向量的低字是偏移地址、高字是段地址,需占用4个字节 8086微处理器从物理地址00000H开始,依次安排各个中断向量。 256个中断向量占用1KB区域,形成中断向量表 8086的中断向量表 中断类型号的获取 对除法错、单步中断、NMI、断点中断、溢出中断,CPU自动提供中断类型号0~4。 对INT n,中断类型号由n确定。 对I/O中断(由INTR引脚引入),通过8259获得中断类型号。 9.5.3 中断入口地址(中断向量)设置 设置中断向量 AL=中断类型号 DS:DX=中断服务程序入口地址 AH=25H INT 21H 取中断向量 AL=中断类型号 AH=35H INT 21H 返回:ES:BX=中断服务程序入口地址 内部中断服务程序 编写内部中断服务程序与编写子程序类似 利用过程定义伪指令PROC/ENDP 保护完现场后要用开中断指令STI置IF=1 恢复现场前要用关中断指令CLI置IF=0 最后用中断返回指令IRET 通常采用寄存器传递参数 主程序需要调用中断服务程序 调用前,需要设置中断向量 利用INT n指令调用中断服务程序 例:内部中断服务程序 编写80H号中断服务程序 功能:显示以“0”结尾字符串的功能 利用显示器功能调用INT 21H的2号模块 字符串缓冲区首地址为入口参数 DS:DX(段地址:偏移地址)传递参数 Intoff dw ? Intseg dw ? Intmsg db ‘A
文档评论(0)