- 1、本文档共67页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
LJY_第5章中断系统剖析
67/ * 5.10 多外部中断源系统设计 5.10.2 中断和查询结合的方法 问题:现有五个中断源,其中IR0级别最高,其余四个等同。 只要IR1~4有一个为高电平,INT1引脚就为低电平 67/ * 5.10 多外部中断源系统设计 5.10.2 中断和查询结合的方法 ORG 0013H ; INT1的中断入口 LJMP INT1 ; INT1: CLR EA ;CPU关中断 PUSH PSW ;保护现场 PUSH ACC SETB EA ;CPU开中断 JB P1.0,IR1 ;P1.0高,IR1有请求 JB P1.1,IR2 ;P1.1高,IR2有请求 JB P1.2,IR3 ;P1.2高,IR3有请求 JB P1.3,IR4 ;P1.3高,IR4有请求 67/ * 5.10 多外部中断源系统设计 5.10.2 中断和查询结合的方法 INTIR: POP ACC;恢复现场 POP PSW RETI ;中断返回 IR1: IR1的中断处理程序 AJMP INTIR IR2: AJMP INTIR IR3: AJMP INTIR ? IR4: AJMP INTIR 67/ * 67/ * 67/ * 5.4 中断控制 5.4.2 中断优先级寄存器IP 例5-2 设置IP寄存器的初始值,使2个外中断请求为高优先级,其它中断请求为低优先级。 (1)用位操作指令 SETB PX0 ;2个外中断为高优先级 SETB PX1 CLR PS ;串口、2个定时器/计数器为低优先级中断 CLR PT0 CLR PT1 67/ * 5.4 中断控制 5.4.2 中断优先级寄存器IP 例5-2 设置IP寄存器的初始值,使2个外中断请求为高优先级,其它中断请求为低优先级。 (2)用字节操作指令 MOV IP,#05H 或: MOV 0B8H,#05H ;B8H为IP寄存器的字节地址 67/ * 5.5 响应中断请求的条件 67/ * 5.5 响应中断请求的条件 一个中断请求被响应,需满足以下必要条件: (1)IE寄存器中的中断总允许位EA=1。 (2)该中断源发出中断请求,即该中断源对应的中断请求标志为“1”。 (3)该中断源的中断允许位=1,即该中断没有被屏蔽。 (4)无同级或更高级中断正在被服务。 中断响应就是 CPU 对中断源提出的中断请求的接受。当 CPU 查询到有效的中断请求时,在满足上述条件时,紧接着就进行中断响应。 67/ * 5.5 响应中断请求的条件 中断响应的主要过程: 由硬件自动生成一条长调用指令:LCALL addr16。Addr16就是程序存储区的相应的中断入口地址,接着就由CPU执行该指令。 1)将PC的内容压入堆栈以保护断点; 2)再将中断入口地址装入PC,使程序转向中断请求的中断入口地址。 67/ * 5.5 响应中断请求的条件 各中断源服务程序的入口地址: 中断源 入口地址 外部中断0 0003H 定时器/计数器T0 000BH 外部中断1 0013H 定时器/计数器T1 001BH 串行口中断 0023H 67/ * 5.5 响应中断请求的条件 中断响应是有条件的,遇到下列三种情况之一时,中断响应被封锁: (1)CPU正在处理同级的或更高优先级的中断。 (2)所查询的机器周期不是所当前正在执行指令的最后一个机器周期。只有在当前指令执行完毕后,才能进行中断响应。 (3)正在执行的指令是RETI或是访问IE或IP的指令。需要再去执行完一条指令,才能响应新的中断请求。 如果存在上述三种情况之一,CPU将丢弃中断查询结果,不能对中断进行响应。 67/ * 5.6 外部中断的响应时间 一、外部中断的最短的响应时间为3个机器周期: (1)中断请求标志位查询占1个机器周期。 (2)硬件子程序调用指令LCALL转到相应的中断服务程序入口,需2个机器周期。 67/ * 5.6 外部中断的响应时间 二、外部中断响应的最长时间为8个机器周期: 发生在CPU进行中断标志查询时,刚好是开始执行RETI或是访问IE或IP的指令,则需把当前指令执行完再继续执行一条指令后,才能响应中断。 67/ * 5.6 外部中断的响应时间 计算: 1、执行 RETI 或 IE、IP 指令,需 2 个机器周期。 2、接着再执行一条指令,按最长指令(乘法指令 MUL 和除法
文档评论(0)