第四讲 16位微处理器.ppt

  1. 1、本文档共115页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
执行主程序 主程序 继续执行主程序 断点 中断请求 中断响应 执行中断处理程序 中断返回 二、中断概念 分时操作 实时响应 可靠性高 CPU可以分时为多个I/O设备服务,提高了计算机的利用率 CPU能够及时处理应用系统的随机事件,系统的实时性大大增强; CPU具有处理设备故障及掉电等突发性事件能力,从而使系统可靠性提高。 三、中断优越性 四、中断源 引起中断的原因或能发出中断申请的来源称为中断源。 一般的输入/输出设备(如键盘、打印机) 数据通道中断源(磁盘、磁带等) 实时时钟 故障源(如电源掉电) 为调试程序而设置的中断源(断点和单步执行) 五、8086中断源 图4.19 8086/8088的中断分类 硬件中断 (1)非屏蔽中断 中断请求 NMI 特点: 对NMI请求的响应不受中断标志位IF的控制 中断矢量号为2 NMI中断优先级别高于可屏蔽中断 用途: 用于处理系统的重大故障,如掉电事故(处理?) (2)可屏蔽中断 特点: 对INTR请求的响应受中断标志位IF的控制 中断矢量号为不固定, 中断优先级及屏蔽状态有中断控制器8259A控制 中断响应需要两个总线周期 中断请求 中断响应 INTR INTA 发送两个负脉冲信号,第一个通知外设,它发生的中断请求已被响应,第二个通知中断源送出中断矢量号 六、中断优先级及中断嵌套 能实现中断优先权排队 当多个中断源同时发出中断申请时,CPU能找到优先级别最高的中断源,响应它的中断请求;在优先级别最高的中断源处理完之后,再响应级别较低的中断源。 8086:软件中断、NMI、INTR、单步执行最低。 能实现中断嵌套 当CPU在进行中断处理时,能同时处理其他的中断源的请求。 请求的中断源级别比当前的级别高时,中断嵌套。 请求的中断源级别与当前的级别相同或低时,暂不响应,等当前的中断处理完后,再响应。 七、CPU对中断的响应 开中断 中断服务 关中断 恢复现场 开中断 中断返回 A 中断源发出中断申请 中断响应条件 是否满足? 保护断点 转入中断服务程序 关中断 保护现场 A Y N 把断点处的IP及 CS值入栈保存 把断点处的相关寄存器及标志寄存器压栈保护 必须找到相应的中断服务程序的入口地址,即中断源的识别 八、中断向量和中断向量表 ——中断源识别 中断向量:每种中断处理程序的入口地址称为中断向量。每个中断向量占4字节,前两个字节为IP,后两个为CS。 中断向量表:8086将内存最低地址的1K字节单元作为中断向量表(地址00000H ~ 003FFH),存放256种中断处理程序的入口地址。 图4.20 8086/8088的中断向量表 九、8086的中断响应 8086对不同的中断源的响应和处理的过程,主要区别在于获取相应类型码的方式不相同。 在取得中断类型码后的处理过程是一样的。 INTR中断,在第2个中断响应周期的T4状态前沿,采样数据线获得中断类型码。 NMI的中断,内部自动产生中断类型码为2。 软件中断,中断类型码也是自动生成的。 图4.22 8086/8088的中断响应总线周期 把中断响应总线周期中CPU的动作和前面讲到的中断响应过程结合起来看,当一个可屏蔽中断被响应时,CPU实际执行的总线时序如下: (1) 执行两个中断响应总线周期,之间用2~3个空闲状态隔开。被响应的外设端口在第二个中断响应总线周期中通过低8位数据线送回一个单字节的中断类型码。CPU接收中断类型码,将它左移两位后,成为中断向量的起始地址,存入暂存器。 (2) 执行一个总线写周期,在这个周期中,把标志寄存器的值推入堆栈。 (3) 将标志寄存器的中断允许标志IF和单步标志TF置成0,这样禁止了中断响应过程中有其他可屏蔽中断进入,还禁止了中断处理过程中出现单步中断。 (4) 执行一个总线写周期,在这个周期内,将CS的内容推入堆栈。 (5) 执行一个总线写周期,在这个周期内,将IP的内容推入堆栈。 (6) 执行一个总线读周期,在这个周期中,从中断向量所在的前两个字节中读得中断处理子程序入口地址的偏移量送到IP寄存器中。 (7) 执行一个总线读周期,在这个周期中,从中断向量所在的后两个字节中读得中断处理子程序入口地址的段值送到CS寄存器中。 如果是非屏蔽中断或者软件中断,则跳过步骤(1),而从步骤(2)开始按次序执行到步骤(7)。 中断处理子程序的结构模式 所有的中断处理子程序都有如下的结构模式: (1) 中断处理子程序的开始必须通过一系列推入堆栈指令来进一步保护中断时的现场,即保护CPU各寄存器的值(当然有时未必需要保存所有寄存器的值)。 (2) 在一般情况下,应该用指令设置中断允许标志IF来开放中断,以允许级别较高的中断请求进入。 (3) 中断处理的具

文档评论(0)

2232文档 + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档