最新微机原理中断技术PPT课件.ppt
《最新微机原理中断技术PPT课件.ppt》由会员分享,可在线阅读,更多相关《最新微机原理中断技术PPT课件.ppt(48页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、微机原理中断技术微机原理中断技术第7章 输入/输出与中断 图7.10 中断过程示意图第7章 输入/输出与中断 第7章 输入/输出与中断 第7章 输入/输出与中断 第7章 输入/输出与中断 第7章 输入/输出与中断 第7章 输入/输出与中断 第7章 输入/输出与中断 3)保护断点 CPU一旦响应中断,需要对其正在执行程序的断点信息进行保护,以便在中断处理结束后仍能回到该断点处继续执行。对于8086/8088 CPU,保护断点的过程由硬件自动完成,主要工作是关中断、将标志寄存器内容入栈保存以及将CS和IP内容入栈保存。第7章 输入/输出与中断 4)中断处理 中断处理的过程实际就是CPU执行中断服务
2、程序的过程。用户编写的用于CPU为中断源进行中断处理的程序称为中断服务程序。由于不同中断源在系统中的作用不同,所要完成的功能不同,因此,不同中断源的中断服务程序内容也各不相同。例如,对于图7.11所示的输入设备,其中断服务程序的主要任务是用输入指令(IN)从接口中的数据端口向CPU输入数据。第7章 输入/输出与中断 另外,主程序中有些寄存器的内容在中断前后需保持一致,不能因中断而发生变化,但在中断服务程序中又用到了这些寄存器,为了保证在返回主程序后仍能从断点处继续正确执行,还需要在中断服务程序的开头对这些寄存器内容进行保护(即保护现场),在中断服务程序的末尾恢复这些寄存器的内容(即恢复现场)。
3、保护现场和恢复现场一般用PUSH和POP指令实现,所以要特别注意寄存器内容入栈和出栈的次序。第7章 输入/输出与中断 5)中断返回 执行完中断服务程序,返回到原先被中断的程序,此过程称为中断返回。为了能正确返回到原来程序的断点处,在中断服务程序的最后应专门放置一条中断返回指令(如8086/8088的IRET指令)。中断返回指令的作用实际上是恢复断点,也就是保护断点的逆过程。第7章 输入/输出与中断 7.3.2 中断优先级和中断的嵌套中断优先级和中断的嵌套 1中断优先级 中断请求是随机发生的,当系统具有多个中断源时,有时会同时出现多个中断请求,CPU只能按一定的次序予以响应和处理,这个响应的次序
4、称为中断优先级。对于不同级别的中断请求,一般的处理原则是:(1)不同优先级的多个中断源同时发出中断请求,按优先级由高到低依次处理。第7章 输入/输出与中断 (2)低优先级中断正在处理,出现高优先级请求,应转去处理高优先级请求,服务结束后再返回原优先级较低的中断服务程序继续执行。(3)高优先级中断正在处理,出现低优先级请求,可暂不响应。(4)中断处理时,出现同级别请求,应在当前中断处理结束以后再处理新的请求。第7章 输入/输出与中断 2中断优先级的确定 在微机系统中通常用三种方法来确定中断源的优先级别,即软件查询法、硬件排队电路法和专用中断控制芯片法。本节简要介绍前两种方法,第三种方法将在本章的
5、最后一节作详细介绍。1)软件查询法 软件查询法需要简单的硬件电路支持。以8个中断源为例,其硬件电路如图7.13所示,将8个外设的中断请求组合起来作为一个端口(中断寄存器),并将各个外设的中断请求信号相或,产生一个总的INT信号。第7章 输入/输出与中断 任一个外设有中断请求,该电路都可向CPU发中断请求信号(INT),CPU响应后进入中断处理程序,在中断处理程序的开始先把中断寄存器的内容读入CPU,再对寄存器内容进行逐位查询,查到某位状态为1,表示与该位相连的外设有中断请求,于是转到与其相应的中断服务程序,同时该外设撤消其中断请求信号。软件查询方式的流程图如图7.14所示。第7章 输入/输出与
6、中断 图7.13 软件查询法的硬件电路 第7章 输入/输出与中断 图7.14 软件查询方式的流程图 第7章 输入/输出与中断 对于图7.13所示电路,设中断寄存器端口号为n,则软件查询的程序段如下:IN AL,n TEST AL,80H ;1号外设有请求?JNZ II1;有,转1号中断服务程序 TEST AL,40H ;2号外设有请求?JNZ II2 ;有,转2号中断服务程序第7章 输入/输出与中断 可以看出,采用软件查询方式,各中断源的优先级是由查询顺序决定的,最先查询的设备,其优先级最高,最后查询的设备,其优先级最低。采用软件查询方式的优点是节省硬件。但是,由于CPU每次响应中断时都要对各
7、中断源进行逐一查询,所以其响应速度较慢。对于优先级较低的中断源来说,该缺点更为明显。第7章 输入/输出与中断 2)硬件排队电路硬件排队电路 采用硬件排队电路法,各个外设的优先级与其接口在排队电路中的位置有关。常用的硬件优先权排队电路有链式优先权排队电路、硬件优先级编码加比较器的排队电路等。图7.15给出了一个链式优先级排队电路。第7章 输入/输出与中断 图7.15中,当响应信号沿链式电路进行传递时,最靠近CPU并发出中断请求的接口将首先拦截住响应信号,CPU进入相应外设的中断处理程序,在服务完成后,该外设撤消其中断请求,解除对下一级外设的封锁。例如,当CPU收到中断请求信号并响应中断时,若1号
8、外设有中断请求(高电平),则立即向1号外设接口发出应答信号,同时封锁2号、3号等外设的中断请求,转去对1号外设服务;若1号外设没有中断请求,而2号外设有中断请求时,响应信号便传递给2号外设,向2号外设接口发出应答信号,同时封锁3号外设的中断请求;若CPU在为2号外设进行中断服务时1号外设发出了中断请求,CPU会挂起对2号外设的服务转去对1号外设服务,1号外设处理结束后,再继续为2号外设服务。第7章 输入/输出与中断 图7.15 链式中断优先级电路 第7章 输入/输出与中断 上述两种方法虽然可以解决中断优先级控制问题,但实现起来在硬件和软件上都要做大量的工作,十分麻烦。目前,最方便的办法就是利用
9、厂家提供的可编程中断控制器,这样的器件在各种微机中得到普遍应用。本章后面将介绍广泛应用于80 x86微机系统中的专用可编程中断控制芯片8259A。第7章 输入/输出与中断 3中断嵌套中断嵌套 CPU在执行低级别中断服务程序时,又收到较高级别的中断请求,CPU暂停执行低级别中断服务程序,转去处理这个高级别的中断,处理完后再返回低级别中断服务程序,这个过程称为中断嵌套,如图7.16所示。图7.16 中断嵌套示意图 第7章 输入/输出与中断 一般CPU响应中断请求后,在进入中断服务程序前,硬件会自动实现关中断,这样,CPU在执行中断服务程序时将不能再响应其他中断请求。为了实现中断嵌套,应在低级别中断
10、服务程序的开始处加一条开中断指令STI。能够实现中断嵌套的中断系统,其软、硬件设计都非常复杂,如果采用了可编程中断控制器,就会方便很多。第7章 输入/输出与中断 7.4 8086/8088中断系统中断系统 7.4.1 8086/8088的中断源类型的中断源类型 8086/8088 CPU可以处理256种不同类型的中断,每一种中断都给定一个编号(0255),称为中断类型号,CPU根据中断类型号来识别不同的中断源。8086/8088的中断源如图7.17所示。从图中可以看出8086/8088的中断源可分为两大类:一类来自CPU的外部,由外设的请求引起,称为硬件中断(又称外部中断);另一类来自CPU的
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 最新 微机 原理 中断 技术 PPT 课件
限制150内