微机原理与接口技术7中断课件.ppt

上传人(卖家):晟晟文业 文档编号:3703804 上传时间:2022-10-06 格式:PPT 页数:82 大小:460.81KB
下载 相关 举报
微机原理与接口技术7中断课件.ppt_第1页
第1页 / 共82页
微机原理与接口技术7中断课件.ppt_第2页
第2页 / 共82页
微机原理与接口技术7中断课件.ppt_第3页
第3页 / 共82页
微机原理与接口技术7中断课件.ppt_第4页
第4页 / 共82页
微机原理与接口技术7中断课件.ppt_第5页
第5页 / 共82页
点击查看更多>>
资源描述

1、第7章 中断系统7.1 7.1 中断的概念中断的概念7.1.1 7.1.1 为什么要用中断?为什么要用中断?7.1.2 7.1.2 中断源中断源7.1.3 7.1.3 中断系统的功能中断系统的功能 7.1.47.1.4 中断优先权中断优先权7.2 7.2 中断处理中断处理7.2.1 CPU7.2.1 CPU响应可屏蔽中断的条件响应可屏蔽中断的条件 7.2.2 CPU7.2.2 CPU响应中断要响应中断要自动完成自动完成的任务的任务7.2.3 7.2.3 中断处理过程中断处理过程7.3 7.3 中断服务程序设计举例中断服务程序设计举例7.3.17.3.1 中断服务程序设计步骤中断服务程序设计步骤

2、7.3.27.3.2中断向量表的装入与修改中断向量表的装入与修改7.4 可编程中断控制器8259A7.5.1 8259A的芯片内部结构7.5.2 8259A的工作方式7.5.3 8259A的级联使用7.5.4 8259A 的控制字和工作方式7.5 8259A在微机系统中的使用7.6.1 8259编程命令7.6.2 8259A的使用学学 习习 目目 的的 通过对本章的学习,通过对本章的学习,您应该能够达到下列要求:您应该能够达到下列要求:中断的概念及中断的用途中断的概念及中断的用途中断类型及中断向量中断类型及中断向量中断过程中断过程8259A8259A中断原理中断原理中断在微机系统中的应用中断在

3、微机系统中的应用重重 点点中断的概念中断的概念7.1 中断的概念外设向外设向CPU发中断请求,发中断请求,CPU接收到中断请求并接收到中断请求并在一定条件下,暂时停止执行原来的程序而转去在一定条件下,暂时停止执行原来的程序而转去处理中断,处理好中断服务再返回继续执行原来处理中断,处理好中断服务再返回继续执行原来的程序,就称为一个中断过程。中断是的程序,就称为一个中断过程。中断是CPU被动被动的响应外设要求服务。的响应外设要求服务。同步操作、并行处理;同步操作、并行处理;实时监控与信息捕捉;实时监控与信息捕捉;故障处理。故障处理。1.中断源中断源:系统外部中断源:系统外部中断源:I/O设备:如键

4、盘、打印机等;设备:如键盘、打印机等;数据通道:如软盘、硬盘等;数据通道:如软盘、硬盘等;实时时钟:如外部的定时电路;实时时钟:如外部的定时电路;用户故障源:电源掉电等。用户故障源:电源掉电等。内部中断源:内部中断源:执行中断指令;执行中断指令;除法错;除法错;单步执行、断点中断、溢出中断等。单步执行、断点中断、溢出中断等。2.中断源识别目的中断源识别目的:形成该中断服务程序的形成该中断服务程序的入口地址?入口地址?中断向量或中断查询中断向量或中断查询中断源的分类中断源的分类硬件中断:硬件中断:非屏蔽中断非屏蔽中断NMI(中断向量号为(中断向量号为2)可屏蔽中断可屏蔽中断INTR软件中断:溢出

5、中断软件中断:溢出中断INTO(中断向量号为(中断向量号为4)除法出错中断(中断向量号为除法出错中断(中断向量号为0)单步中断(中断向量号为单步中断(中断向量号为1)断点中断断点中断INT3(中断向量号为(中断向量号为3)指令中断指令中断INTn(中断向量号为(中断向量号为n)中断向量号:中断向量号:中断向量:中断向量:中断向量表:中断向量表:=中断类型码(中断类型码(256256个)个)CS(CS(高字高字)+IP()+IP(低字低字),其首地址,其首地址=中断类型码中断类型码*4 4由中断向量构成,即中断入口地址表由中断向量构成,即中断入口地址表分为分为5个阶段:个阶段:(1)中断请求)中

6、断请求(2)中断判优)中断判优(3)中断响应)中断响应(4)中断处理)中断处理(5)中断返回)中断返回(1)中断请求)中断请求 中断源发送请求信号,外部中断由硬件产生,中断源发送请求信号,外部中断由硬件产生,内部中断由指令产生。内部中断由指令产生。外部中断:外部中断:CPUCPU在每条指令执行的最后一个周在每条指令执行的最后一个周期采样中断请求信号。期采样中断请求信号。(2)中断判优)中断判优 如果有多个中断源提出中断申请,如果有多个中断源提出中断申请,CPUCPU可通过查可通过查询式或硬件电路自动完成中断优先权排队,然后询式或硬件电路自动完成中断优先权排队,然后响应优先权最高的中断申请响应优

7、先权最高的中断申请(3)中断响应)中断响应 如果为内部中断或如果为内部中断或NMINMI中断,中断,CPUCPU自动形成中自动形成中断类型码断类型码 如果是如果是INTRINTR中断,在中断,在IF=1IF=1的前提下,进入中的前提下,进入中断响应周期,从断响应周期,从DBDB获取中断类型码获取中断类型码 可屏蔽中断的响应周期:可屏蔽中断的响应周期:第一个总线周期:第一个总线周期:CPUCPU送出中断响应信号送出中断响应信号INTAINTA 第二个总线周期:被响应的外设通过数据总第二个总线周期:被响应的外设通过数据总线送中断类型码给线送中断类型码给CPUCPU 关中断关中断 保护保护断点断点

8、(FLAG(FLAG、CS CS、IPIP入栈入栈)给出中断服务入口给出中断服务入口 执行执行中断服务程序中断服务程序 保护现场(寄存器入栈)保护现场(寄存器入栈)开中断开中断 (允许中断嵌套允许中断嵌套)中断服务程序(需完成的功能)中断服务程序(需完成的功能)CPU CPU关中断关中断 恢复现场恢复现场 中断返回中断返回 断点恢复(断点恢复(IPIP、CSCS、FLAGFLAG出栈)出栈)CPUCPU响应响应INTRINTR中断的中断的条件条件是是 (1)中断请求信号)中断请求信号 (2)开放总中断)开放总中断 (3)在现行指令结束后响应中断)在现行指令结束后响应中断80868086系统中中

9、断源种类很多,但只有系统中中断源种类很多,但只有INTRINTR中断可以由用户开发提供给外设使用中断可以由用户开发提供给外设使用(1)需要中断请求)需要中断请求中断请求触发器中断请求触发器(2)多个外设需分别处理)多个外设需分别处理中断屏蔽触发器中断屏蔽触发器(3)CPU与外设的数据中转与外设的数据中转数据缓冲器数据缓冲器(4)选择外设的端口号)选择外设的端口号端口地址译码器端口地址译码器(5)CPU执行完当前指令执行完当前指令,在最后的一个,在最后的一个T状态才采样状态才采样INTR线线7.3.2 中断优先权同时有多个中断请求,同时有多个中断请求,CPU如何如何选择选择中断中断源?源?中断嵌

10、套时,中断嵌套时,CPU是否响应新的中断请求?是否响应新的中断请求?软件查询软件查询 最简单的一种确定优先级的方法。即查询的最简单的一种确定优先级的方法。即查询的顺序就是中断的优先级顺序就是中断的优先级先查询的高。先查询的高。屏蔽法程序查询屏蔽法程序查询移位法程序查询移位法程序查询硬件优先权排队电路硬件优先权排队电路编码器与比较器组成的优先权排队电路编码器与比较器组成的优先权排队电路中断控制器(中断控制器(8259A8259A)(1)(1)屏蔽法屏蔽法IN AL,20HTEST AL,80HJNZ POWERTEST AL,40HJNZ DISKTEST AL,02HJNZ INPUT若有若有

11、8个中断源,则将它们的个中断源,则将它们的中断请求触发器组合起来,作为中断请求触发器组合起来,作为一个端口,假设端口号为一个端口,假设端口号为20H。70电源故障电源故障磁盘磁盘打印输出打印输出键盘输入键盘输入INTR20H(2)(2)移位法移位法XOR AL,ALIN AL,20HRCL AL,1JC POWERRCL AL,1JC DISK若有若有8个中断源,则将它们的个中断源,则将它们的中断请求触发器组合起来,作为中断请求触发器组合起来,作为一个端口,假设端口号为一个端口,假设端口号为20H。70电源故障电源故障磁盘磁盘打印输出打印输出键盘输入键盘输入INTR20H软件查询优缺点:软件查

12、询优缺点:询问次序就是优先级次序,原理简单询问次序就是优先级次序,原理简单省硬件,中断源优先级可由用户程序灵活确定省硬件,中断源优先级可由用户程序灵活确定缺点是询问很耽误时间,尤其在中断源很多时缺点是询问很耽误时间,尤其在中断源很多时1)优先级编码电路优先级编码电路2接接CPUCPU的的INTRINTRABAB 比比 较较 器器优先权优先权寄存器寄存器数据总线数据总线1优先权优先权编码组编码组中断输入中断输入优先权失效优先权失效图图编码器和比较编码器和比较器的优先权排队电路器的优先权排队电路中断嵌套中断嵌套主程序主程序 中断服务子程序中断服务子程序1 1 中断服务子程序中断服务子程序2 2中断

13、断点中断断点1 1 中断断点中断断点2 2 IRET IRET IRET IRET中断嵌套条件:中断嵌套条件:1 1、中断、中断1 1的服务程序中,应在保护现场后的服务程序中,应在保护现场后开中断开中断STISTI;2 2、当中断、当中断2 2的优先级高于中断的优先级高于中断1 1时,才会发生中断时,才会发生中断嵌套,否则,不会发生中断嵌套嵌套,否则,不会发生中断嵌套主程序主程序CPU关中断:关中断:CLI设置中断向量设置中断向量CPU开中断:开中断:STI等待中断等待中断l中断服务子程序中断服务子程序 中断子程序名中断子程序名 PROC 属性属性 保护现场保护现场 STI 恢复现场恢复现场

14、CLI IRET 中断子程序名中断子程序名 ENDP例例:类型号为类型号为20H的中断服务程序入口符号地址为的中断服务程序入口符号地址为INT-5,中断向量的装入方法。中断向量的装入方法。中断服务程序框架:中断服务程序框架:INT-5PROCNEAR.IRETINT-5ENDP中断向量指针:中断向量指针:20H 4=0010000000=80H20H 4+2=82H用用MOVMOV指令中断向量的装入指令中断向量的装入参考程序参考程序:CLIPUSH DSPUSH AXXOR AX,AXMOV DS,AXMOV AX,OFFSET INT-5MOV WORD PTR 080H,AXMOV AX,

15、SEG INT-5MOV WORD PTR 082H,AXPOP AXPOP DSSTI用串操作,用串操作,中断向量的装入中断向量的装入:CLICLDPUSH ESXOR AX,AX MOV ES,AXMOV DI,4*20HMOV AX,OFFSET INT-5STOSW ;DI+1DIAX,DI DI+2MOV AX,SEG INT-5STOSWPOP ESSTI中断向量表的修改中断向量表的修改用用DOS系统功能调用系统功能调用INT21H的的35H功能获功能获取原中断向量(中断向量取原中断向量(中断向量=ES:BX.类型号类型号=AL),并保存;),并保存;用用DOS系统功能调用系统功能

16、调用INT21H的的25H功能设功能设置新中断向量(中断向量置新中断向量(中断向量=DS:DX.类型号类型号=AL););用用DOS系统功能调用的系统功能调用的25H功能恢复原中功能恢复原中断向量。断向量。例:用例:用INT21H/35H设置新中断向量设置新中断向量CLIPUSHDSMOVAL,NMOVDX,OFFSETINT-SEVMOVAX,SEGINT-SEVMOVDS,AXMOVAH,25HINT21HPOPDSSTI思考题思考题1.中断响应周期中,第一个中断响应脉冲信号向外部电路中断响应周期中,第一个中断响应脉冲信号向外部电路说明什么?第二个脉冲呢?说明什么?第二个脉冲呢?解:第一个

17、中断响应信号脉冲表示当前中断请求已被响解:第一个中断响应信号脉冲表示当前中断请求已被响应,第二个中断响应信号表示将最高优先级的中断类型码应,第二个中断响应信号表示将最高优先级的中断类型码放在数据总线上。放在数据总线上。2.中断向量地址是中断向量地址是。3.硬件中断可分为硬件中断可分为两种。两种。4.8086/8088最多能处理种最多能处理种中断。中断。5.非屏蔽中断的中断类型码是非屏蔽中断的中断类型码是。6.对于掉电的处理,对于掉电的处理,8086/8088是通过是通过来处理的来处理的。中断服务程序入口地址中断服务程序入口地址非屏蔽中断和可屏蔽中断非屏蔽中断和可屏蔽中断2562非屏蔽中断非屏蔽

18、中断7.在下面的中断中,只有在下面的中断中,只有需要硬件提供中断类需要硬件提供中断类型码。型码。A.INTOB.INTnC.NMID.INTRINTO是指溢出中断,是类型为是指溢出中断,是类型为4的内部中断;的内部中断;INTn是指软件中断,其类型码即为指令中的是指软件中断,其类型码即为指令中的n;NMI是非屏蔽中断,它的中断类型码为是非屏蔽中断,它的中断类型码为2;而只;而只有可屏蔽中断需要硬件提供中断类型码。有可屏蔽中断需要硬件提供中断类型码。8.在中断响应周期内,将中断标志位在中断响应周期内,将中断标志位IF清清0是由是由完成的。完成的。D硬件自动硬件自动7.4 可编程中断控制器 Int

19、el 8259A8259A8259A的的功能功能:具有具有8 8级优先权管理级优先权管理,可用可用9 9片扩展为片扩展为6464级中断系统级中断系统接受中断请求,提供中断类型号接受中断请求,提供中断类型号具有屏蔽与开放中断的功能具有屏蔽与开放中断的功能可编程选择不同工作方式可编程选择不同工作方式8259A8259A特点特点:具有对中断服务程序入口地址的寻址能力具有对中断服务程序入口地址的寻址能力单片单片82598259可处理可处理8 8级中断级中断级联时级联时:最多可用最多可用9 9片处理片处理6464级中断级中断8259A8259A的片内的片内寻址寻址A A0 0=1=1、0,0,用于选择内

20、部不同寄存器用于选择内部不同寄存器VCCA0INTAIR7IR6IR5IR4IR3IR2IR1IR0INTSP/ENCAS2CSWRRDD7D6D5D4D3D2D1D0CAS0CAS1GND1 282273264 25 5 24 6 23 7 22 82192010 19111812 1713 161415双列直插式芯片28个引脚数数据据总总线线外设外设的的8 8级中级中断请断请求输求输入入读信号:状态信息读信号:状态信息和中断向量和中断向量写信号:初始化命写信号:初始化命令字和操作命令字令字和操作命令字向向CPUCPU发送中发送中断请求信号断请求信号中断响中断响应信号应信号地址线地址线级联信

21、号:用于连级联信号:用于连接主从芯片完成多接主从芯片完成多片间的信息传输片间的信息传输主从设备选择控制主从设备选择控制信号信号/允许缓冲线允许缓冲线IRR:IRR:用于保存用于保存IR0IR7IR0IR7的中断请求,的中断请求,Di=1Di=1:IRiIRi有中断请求有中断请求ISRISR:用于存放正在被服务的中断源,:用于存放正在被服务的中断源,Di=1 Di=1:IRi IRi正在被服务正在被服务IMRIMR:用于存放对应中断请求信号的屏蔽状态,:用于存放对应中断请求信号的屏蔽状态,Di=1 Di=1:IRi IRi被禁止被禁止有有请求输入请求输入时,将时,将IRRIRR相应位置位;相应位

22、置位;经经IMRIMR屏蔽电路处理后(屏蔽电路处理后(IRRIRR与与IMRIMR相与),送相与),送PRPR;PRPR检测出最高的中断请求位,并经嵌套处理考虑是否发送检测出最高的中断请求位,并经嵌套处理考虑是否发送INTINT;若可发若可发INTINT信号,则控制逻辑将信号,则控制逻辑将INTINT信号送给信号送给CPUCPU的的INTRINTR引脚引脚若若CPUCPU处在处在开中断开中断,则在当前,则在当前指令完成指令完成后,发两个后,发两个INTAINTA信号;信号;8259A8259A接到第一个接到第一个INTAINTA信号后,使信号后,使ISRISR位置位,位置位,IRRIRR相应位

23、复位;相应位复位;CPUCPU启动另一个响应周期,输出第二个启动另一个响应周期,输出第二个INTAINTA脉冲,脉冲,8259A8259A 向数据总线送出向数据总线送出中断类型码中断类型码;同时,;同时,CPUCPU取出此向量乘以取出此向量乘以4 4,得到中断服务程序的入口地址;得到中断服务程序的入口地址;中断响应周期完成,中断响应周期完成,CPUCPU执行中断服务程序,执行中断服务程序,8259A8259A工作工作 在自动结束在自动结束AEOIAEOI或普通结束或普通结束EOIEOI模式下,使模式下,使ISRISR清清0 0。假设:假设:8259A的端口地址为:的端口地址为:20H,21H,

24、某某8位位CPU和和8259A的地址线如何连接的地址线如何连接?地址地址译码译码CPUD7D0A7A1D7D0A0A0INTAINTRINTAINT8259IR0IR7CSA7A00010000020H0010000121H分为分为3类类(1 1)中断触发方式)中断触发方式(2 2)中断优先权管理方式:)中断优先权管理方式:中断屏蔽方式中断屏蔽方式 设置优先权方式设置优先权方式 中断结束处理方式中断结束处理方式(3 3)连接系统总线方式)连接系统总线方式1.中断触发方式中断触发方式(此方式由此方式由ICW1ICW1来设置来设置)(1)(1)边沿触发方式:边沿触发方式:上升沿触发,要求高电平信上

25、升沿触发,要求高电平信号具有一定的宽度,可避免毛刺现象引发的中断号具有一定的宽度,可避免毛刺现象引发的中断误判误判(2)(2)电平触发方式电平触发方式:当中断输入端持续出现当中断输入端持续出现2 2个脉冲的高电平,表个脉冲的高电平,表示有示有1 1个中断请求,当该请求得到响应后,输入端个中断请求,当该请求得到响应后,输入端必须及时撤除高电平,否则引发第二次中断。必须及时撤除高电平,否则引发第二次中断。(3)(3)中断查询方式中断查询方式:CPUCPU用软件查询用软件查询,通过读取查询通过读取查询字来确认是否有中断产生字来确认是否有中断产生2.中断屏蔽方式中断屏蔽方式(1 1)普通屏蔽方式)普通

26、屏蔽方式 用用OCW1OCW1命令将中断屏蔽寄存器命令将中断屏蔽寄存器IMR的相应位置的相应位置“1 1”。高优先级的中断才能中止低优先级的中断高优先级的中断才能中止低优先级的中断(2 2)特殊屏蔽方式)特殊屏蔽方式 用于中断处理程序中。当要允许优先级低的中用于中断处理程序中。当要允许优先级低的中断进入断进入,可采用特殊屏蔽方式可采用特殊屏蔽方式.可用可用OCW3OCW3的的D D6 6D D5 5=11=11设置设置,用用OCW1OCW1命令将中断命令将中断屏蔽寄存器屏蔽寄存器IMR的相应位置的相应位置“1 1”,同时将,同时将ISR对应对应位清位清“0”。此时除此时除IMRIMR中置中置1

27、 1位对应的中断被屏蔽位对应的中断被屏蔽外外,其它置其它置0 0位对应的中断无论优先级高低都可得位对应的中断无论优先级高低都可得到响应。到响应。3.优先级的管理方式优先级的管理方式:一般全嵌套方式一般全嵌套方式特殊全嵌套方式特殊全嵌套方式优先级自动循环方式优先级自动循环方式优先级特殊循环方式优先级特殊循环方式(1)(1)全嵌套方式:全嵌套方式:8259A默认工作方式默认工作方式.特点特点:在全嵌套方式中,中断请求按在全嵌套方式中,中断请求按固定优先级固定优先级IR0IR7进行处理,进行处理,IR0级中断的优先级最高。级中断的优先级最高。当一个中断被响应时,中断类型码被放到数据总线当一个中断被响

28、应时,中断类型码被放到数据总线上,上,ISR中的对应位中的对应位ISn被置被置1,然后进入中断服务程序。然后进入中断服务程序。一般情况下(除了中断自动结束方式外),一般情况下(除了中断自动结束方式外),在在CPU发出发出中断结束命令(中断结束命令(EOI)前,此对应位一直保持)前,此对应位一直保持“1”,需,需使使AEOI=0。仅级别高的中断才能中断级别低的中断仅级别高的中断才能中断级别低的中断。(2)(2)特殊全嵌套方式特殊全嵌套方式用途用途:多片级联方式多片级联方式,特殊全嵌套方式仅设置在主片中特殊全嵌套方式仅设置在主片中.特点特点:和全嵌套方式基本相同和全嵌套方式基本相同,不同的是不同的

29、是:在处理中断时在处理中断时,可响应同级中断可响应同级中断,从而实现对同从而实现对同级中断请求的特殊嵌套级中断请求的特殊嵌套.思考题:当有思考题:当有3 3片片8259A8259A级联时,主片采用特殊全嵌套方式,级联时,主片采用特殊全嵌套方式,从片采用全嵌套方式,其中断的优先级顺序应该为?从片采用全嵌套方式,其中断的优先级顺序应该为?(3)(3)优先级自动循环方式优先级自动循环方式:(由(由OCW2决定)决定)用途用途:多个中断源优先级相等的场合。多个中断源优先级相等的场合。特点特点:优先级是在变化的优先级是在变化的。优先权初始化顺序为优先权初始化顺序为IR0IR7,一个设备中断被响应后,一个

30、设备中断被响应后,其优先级自动其优先级自动降为最低,比它低一级的中断降为最低,比它低一级的中断源优先级升到最高源优先级升到最高。如:如:IR4中断请求被响应后,此方式下,中断优先级自动变中断请求被响应后,此方式下,中断优先级自动变为:为:IR5IR6IR7IR0IR1IR2IR3IR4 (4)(4)优先级特殊循环方式优先级特殊循环方式与优先级自动循环方式不同点:用户用程序指定初与优先级自动循环方式不同点:用户用程序指定初始的最低优先级的中断源。始的最低优先级的中断源。例如设置例如设置IRi为最低优先为最低优先级,则最高优先级为级,则最高优先级为IRi+1,其它各级按循环方式类,其它各级按循环方

31、式类推推。4.中断结束处理的方式中断结束处理的方式中断自动结束方式中断自动结束方式一般的中断结束方式一般的中断结束方式特殊的中断结束方式特殊的中断结束方式(1 1)中断自动结束方式:)中断自动结束方式:用于系统中只有一片用于系统中只有一片8259A8259A,多个中断不会嵌,多个中断不会嵌套的情形。系统一进入中断处理,就将当前中断服套的情形。系统一进入中断处理,就将当前中断服务寄存器务寄存器ISRISR的对应位清除。对的对应位清除。对8259A8259A来说,好像已来说,好像已经结束了当前中断。经结束了当前中断。在命令字在命令字ICW4ICW4中将中将AEOIAEOI(D1D1)位置)位置“1

32、 1”。(2 2)普通的中断结束方式)普通的中断结束方式(非自动非自动EOI)EOI):用在全嵌套的情形。用在全嵌套的情形。CPUCPU用用OUTOUT指令往指令往82598259A A偶偶地址地址发一个发一个EOIEOI命令,命令,82598259A A将使将使ISRISR中优先级别最中优先级别最高的非零位高的非零位(正在服务的最高优先级正在服务的最高优先级)清零清零。结束当结束当前正在处理的中断。前正在处理的中断。用操作命令字用操作命令字OCW2OCW2中的中的R=0,R=0,SL=0,EOI=1 SL=0,EOI=1 的设置来实现。的设置来实现。在命令字在命令字OCW2=OCW2=001

33、0010000B=20H0000B=20H(3 3)特殊的中断结束方式)特殊的中断结束方式(非自动非自动EOI)EOI)在非全嵌套方式下,通过向在非全嵌套方式下,通过向8259A8259A发一条特殊发一条特殊中断结束命令来判断要清除中断结束命令来判断要清除ISRISR中置中置1 1位中的位中的哪哪一位。一位。用操作命令字用操作命令字OCW2OCW2中的中的R=0,SL=1,EOI=1 R=0,SL=1,EOI=1 的的设置来实现,此时设置来实现,此时OCW2OCW2中的中的L2L2、L1L1、L0L0这这3 3位位指出了到底要清除指出了到底要清除ISRISR中的哪一位。中的哪一位。OCW2=0

34、1100L2L1L0 往偶地址端口输出往偶地址端口输出OCW2OCW2命令。命令。OCW2OCW2中:中:EOI=1EOI=1、SL=1SL=1、R=0R=0是特殊中断结束是特殊中断结束命令。命令。5.5.连接系统总线方式连接系统总线方式(1)(1)缓冲方式:缓冲方式:8259A通过通过总线驱动器总线驱动器和数据总线相连,这就是缓冲方和数据总线相连,这就是缓冲方式。式。用于多片用于多片8259A8259A级联时,此时主片级联时,此时主片SP/ENSP/EN作为总线驱动器作为总线驱动器的启动信号连接到的启动信号连接到CECE端,从片端,从片SP/ENSP/EN控制数据的方向。控制数据的方向。(2

35、)(2)非缓冲方式:非缓冲方式:当系统中只有单片当系统中只有单片8259A8259A时,一般将它直接与数据总线时,一般将它直接与数据总线相连。或者相连。或者8259A8259A片数不多的情况下,也可直接与数据总片数不多的情况下,也可直接与数据总线相连。线相连。单片时,单片时,8259A SP/EN8259A SP/EN接高电平;多片时,主片接高电平;多片时,主片SP/ENSP/EN接高电平,从片接高电平,从片SP/ENSP/EN接低电平接低电平8259A缓冲方式下级连结构缓冲方式下级连结构 B7B0 T 74LS245 OE A7A0 DT/R INTR DEN 局部数据总线 B7B0 T 7

36、4LS245 OE A7A0 SP/EN D7D0 从控B CAS2-0 INTA INT SP/EN D7D0 从控A CAS2-0 INTA INT SP/EN D7D0 主控制器 INT IR5 IR6 INTA CAS2-0+5V 1k B7B0 OE 74LS245 T A7A0+5V 1k +5V 1k 系统数据总线 INTA 8259A非缓冲方式下级连结构非缓冲方式下级连结构 地址总线 控制总线 数据总线 CS A0 DB INTA INT CAS0 8259A 从控 A CAS1A CAS1 CAS2 SP/EN IRQ7 IRQ0 CS A0 DB INTA INT CAS0

37、 CAS1 8259A主控 CAS2 IRQ7 IRQ0 SP/EN 7 6 5 4 3 2 1 0 CS A0 DB INTA INT CAS0 8259A 从控 B CAS1 CAS2 SP/EN IRQ7 IRQ0 GND 7 6 5 4 3 2 1 0 GND 7 6 5 4 3 2 1 0 VCC 7 6 5 4 3 2 1 0 CS A0 DB INTA INT CAS0 8259A 从控 B CAS1 CAS2 SP/EN IRQ7 IRQ0 CS A0 DB INTA INT CAS0 8259A 从控 B CAS1 CAS2 SP/EN IRQ7 IRQ0 CS A0 DB

38、INTA INT CAS0 8259A 从控 B CAS1 CAS2 SP/EN IRQ7 IRQ0 CS A0 DB INTA INT CAS0 8259A 从控 B CAS1B CAS1 CAS2 SP/EN IRQ7 IRQ0 361#从片从片挂在挂在主片主片的的IR6,2#从片从片挂在挂在主片主片的的IR3?主片:主片:IR3有申请有申请 IRR:0000 1000 ISR:0000 1000主片向主片向CPU发发INTR信信号号CPU发响应信号发响应信号INTA主片收到主片收到INTA主片向从片送识别码主片向从片送识别码:CAS0CAS2=011在在2#2#从片:从片:若若IR5有申

39、请有申请 IRR:0010 0000 ISR:0010 0000向主片发向主片发INT信号信号2#从片与识别码一致从片与识别码一致2#从片通过数据总线从片通过数据总线送出中断类型码送出中断类型码7 7 中断查询工作方式中断查询工作方式与前面所讲与前面所讲8259A8259A工作在向量中断方式不同,工作在向量中断方式不同,查询中断工作查询中断工作方式方式具有以下特点:具有以下特点:外设的中断请求信号送入外设的中断请求信号送入8259A8259A,但是,但是8259A8259A不使用不使用INTINT引脚向引脚向CPUCPU发送中断请求发送中断请求CPUCPU的的IF=0IF=0,即使得,即使得C

40、PUCPU不会响应不会响应INTINT引脚上产生的中断引脚上产生的中断CPUCPU通过软件定期或循环查询通过软件定期或循环查询8259A8259A的状态(的状态(读入查询读入查询字字)来确认中断源)来确认中断源8259A外设外设CPU中断中断查询查询8259A的的初始化命令字:初始化命令字:ICWi(i=14)ICW1:芯片控制初始化命令字芯片控制初始化命令字ICW2:中断类型码设置中断类型码设置ICW3:用于级联,主片用于级联,主片/从片的初始化命令字从片的初始化命令字ICW4:方式控制初始化命令字方式控制初始化命令字(1 1)ICW1ICW1(A A0 0=0=0)芯片控制初始化命令芯片控

41、制初始化命令ICW1必须写入必须写入偶偶地址端口中。地址端口中。D7D5:在系统中不用,为在系统中不用,为1为为0都可以,是都可以,是A7A5。D4:设置为设置为1,指示指示ICW1的标志。的标志。D3(LTIM)=1,表示中断请求为电平触发方式,表示中断请求为电平触发方式,=0,表示中断请求为边沿触发方式。,表示中断请求为边沿触发方式。D2(ADI):在在8086/8088中不起作用。中不起作用。D1(SNGL):指出指出8259A有否级联。有否级联。=1,表示系统中有一片,表示系统中有一片8259A,不需写不需写ICW3=0,表示系统中有多片,表示系统中有多片8259A,需要写需要写ICW

42、3D0(IC4):指出后面是否设置指出后面是否设置ICW4。使用。使用ICW4时时D0必须为必须为1。LTIMADISNGLIC41000D7D6D5D4D3D2D1D0(2 2)ICW2(AICW2(A0 0=1)=1)中断类型码的设置中断类型码的设置ICW2写入写入8259A的的奇奇地址端口。地址端口。T7T3:设置中断类型码的高:设置中断类型码的高5位,低位,低3位可以为位可以为0D2D0:由中断请求引脚:由中断请求引脚IR的编号自动插入的编号自动插入T3T4T6T5T7D7D6D5D4D3D2D1D0解:解:ICW1=0001 0011B ICW1=0001 0011B ICW2=00

43、00 1000BICW2=0000 1000B MOV AL,00010011BMOV AL,00010011B OUT 20H,ALOUT 20H,AL MOV AL,00001000BMOV AL,00001000B OUT 21H,ALOUT 21H,AL例例1:1:8259A8259A采用前沿触发,单片使用,需要采用前沿触发,单片使用,需要ICW4 ICW4,假设假设IR0IR0的类型码为的类型码为08H,08H,试确定试确定ICW1,ICW2ICW1,ICW2。已知已知8259A8259A端口地址端口地址:20H,21H:20H,21H 8259A8259A的的ICW2ICW2设置了

44、中断类型码的哪设置了中断类型码的哪几位?试说明对几位?试说明对8259A8259A的的ICW2ICW2分别设置为分别设置为:30H30H、38H38H、36H36H时有什么差别?时有什么差别?8259A8259A的的ICW2ICW2设置了中断类型码的设置了中断类型码的D7D7D3D3位。位。30H30H和和36H36H对应的高对应的高5 5位相同,均为:位相同,均为:0011000110,表示中断类型码区别于低,表示中断类型码区别于低3 3位;位;而而38H38H的高的高5 5位为:位为:0011100111,与前面,与前面的两者不可能是同片的两者不可能是同片82598259中断。中断。(3)

45、(3)初始化命令字初始化命令字ICW3:ICW3:级联方式结构级联方式结构需要分别对主片和从片进行设置需要分别对主片和从片进行设置(3 3)ICW3(AICW3(A0 0=1)=1)级连方式的设置级连方式的设置 ICW3写入写入8295A的的奇奇地址端口。地址端口。主片主片ICW3的格式的格式:指出主指出主8259哪个引脚连有从哪个引脚连有从8259,对应位置,对应位置1。从片从片ICW3的格式的格式:指出从片指出从片8259连在主连在主8259哪哪个引脚上,由个引脚上,由D2D1D0指出。指出。D7D6D5D4D3 D2D1D0 0 0 0 0 0 ID2 ID1ID0IR3IR2IR1IR

46、0IR4IR6IR5IR7D7D6D5D4D3D2D1D0主片主片从片从片例例2:现有一主片现有一主片8259A的的IR3和和IR6接了接了2个从片。个从片。主片端口地址主片端口地址:20H,21H;1#从片端口地址从片端口地址:A0H,A1H试设置试设置ICW3。主片主片:ICW3=01001000=48H从片从片1#:ICW3=00000011=03H从片从片2#:ICW3=00000110=06H主片主片ICW3的初始化程序段的初始化程序段:MOVAL,48HOUT21H,AL1#从片从片ICW3的初始化的初始化:MOVAL,03HOUT0A1H,AL解:解:(4)ICW4(4)ICW4

47、的格式(的格式(A A0 0=1=1)ICW4为方式控制初始化命令字,写入为方式控制初始化命令字,写入奇奇地址端口。地址端口。SFNM:=0,一般全嵌套方式一般全嵌套方式;=1,特殊全嵌套方式特殊全嵌套方式(SpecificFullNestedMode)BUF:=0,非缓冲方式非缓冲方式;=1,缓冲方式缓冲方式(buffered)M/S:主片主片(Master)/从片从片(Slave)若若BUF=1,M/S=1,作主片作主片,M/S=0,作从片作从片BUF=0,M/S无意义无意义AEOI:=0,中断非自动结束中断非自动结束;=1,中断自动结束中断自动结束(AutomaticEndOfInter

48、rupt)uPM:=0,用于用于8位机位机;=1,用于用于16位机位机D7D6D5D4D3D2D1D0 0 0 0SFNMBUF M/SAEOIuPM8259A的工作命令字:的工作命令字:OCWi(i=13)OCW1:中断屏蔽命令字;:中断屏蔽命令字;OCW2:优先级循环方式和中断结束方式;:优先级循环方式和中断结束方式;OCW3:查询方式:查询方式,特殊屏蔽方式特殊屏蔽方式,读状态等。读状态等。在对在对8259A8259A进行了初始化编程后,芯片已经进行了初始化编程后,芯片已经作好接收中断请求的输入准备。作好接收中断请求的输入准备。在在8259A8259A工作期间若需要改变工作期间若需要改变

49、8259A8259A的工作方的工作方式,可由式,可由CPUCPU发送操作命令字发送操作命令字OCWOCW进行控制。进行控制。(1 1)OCW1OCW1的格式(的格式(A A0 0=1=1)OCW1称为屏蔽命令字,写入称为屏蔽命令字,写入8259A的的奇奇地址端口地址端口。当当OCW1某位某位=1,表示对应的中断请求,表示对应的中断请求被屏蔽被屏蔽。D7D6D5D4D3D2D1D0M7M6M5M4M3M2M1M0用于设置优先级循环方式和中断结束方式,用于设置优先级循环方式和中断结束方式,写入写入偶偶地址单元。地址单元。D4D3:=00,特征位特征位D7(R):=1,优先级循环方式;,优先级循环方

50、式;R=0,固定方式。,固定方式。D5(EOI):=1,普通,普通EOI方式。在中断服务完毕,发中断结方式。在中断服务完毕,发中断结束命令,使当前束命令,使当前ISR的最高优先权的的最高优先权的ISn复位。复位。D5(EOI):=0,未定义。,未定义。D6(SL):=1,用,用L2、L1、L0指定中断等级。指定中断等级。在在ICW4中,若中,若AEOI=1,自动清除当前,自动清除当前ISn。AEOI=0,ISn要用要用EOI清除。清除。(2 2)OCW2OCW2的格式(的格式(A A0 0=0=0)D7D6D5D4D3D2D1D0 R SLEOI 0 0L2L1L0OCW2的的R、SL、EOI

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 办公、行业 > 各类PPT课件(模板)
版权提示 | 免责声明

1,本文(微机原理与接口技术7中断课件.ppt)为本站会员(晟晟文业)主动上传,163文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。
2,用户下载本文档,所消耗的文币(积分)将全额增加到上传者的账号。
3, 若此文所含内容侵犯了您的版权或隐私,请立即通知163文库(发送邮件至3464097650@qq.com或直接QQ联系客服),我们立即给予删除!


侵权处理QQ:3464097650--上传资料QQ:3464097650

【声明】本站为“文档C2C交易模式”,即用户上传的文档直接卖给(下载)用户,本站只是网络空间服务平台,本站所有原创文档下载所得归上传人所有,如您发现上传作品侵犯了您的版权,请立刻联系我们并提供证据,我们将在3个工作日内予以改正。


163文库-Www.163Wenku.Com |网站地图|