当前位置:首页 > 单片机 > 单片机
[导读]④处理机执行完一条指令后或者这条指令已无法执行完,则立即中止现行程序。接着,中断部件根据中断级去指定相应的主存单元,并把被中断的指令地址和处理机当前的主要状态信息存放在此单元中。

大多数中断系统都具有如下几方面的操作,这些操作是按照中断的执行先后次序排列的。

①接收中断请求。

②查看本级中断屏蔽位,若该位为1则本级中断源参加优先权排队。

③中断优先权选择。

④处理机执行完一条指令后或者这条指令已无法执行完,则立即中止现行程序。接着,中断部件根据中断级去指定相应的主存单元,并把被中断的指令地址和处理机当前的主要状态信息存放在此单元中。

⑤中断部件根据中断级又指定另外的主存单元,从这些单元中取出处理机新的状态信息和该级中断控制程序的起始地址。

⑥执行中断控制程序和相应的中断服务程序。

⑦执行完中断服务程序后,利用专用指令使处理机返回被中断的程序或转向其他程序。

按照时间顺序,单片机中断处理可分为以下几个阶段:中断请求、中断响应、中断服务、中断返回。

(1)中断请求

单片机通过查询的方式发现中断请求,对中断的查询发生在每个机器周期的S5P2阶段(见图2-12)。有中断请求发生时,对应的中断请求标志位被置1。对于MCS-51单片机,只要中断请求标志位为1,单片机就认为发生了对应的中断请求。

另外,除了真实有效的中断请求可以使中断请求标志位置1外,还可通过软件指令将中断请求标志位置1,如:指令“SETB TF1”可将TF1置1。并且单片机无法判断出中断请求标志位是因实际发生的中断请求而被置1,还是被程序指令置1。因此,通过指令将中断请求标志位置1,也可以产生有效的中断请求。

(2)中断响应条件

单片机响应中断时必须符合以下中断响应条件:

1)中断源没有被屏蔽。

2)中断请求符合中断优先级控制原则被确定。

3)不打断正在执行的指令。若正在执行的是RET、RETI指令或指令正在访问IE或IP寄存器,则单片机要在该指令结束后至少再执行一条指令,才能响应中断。这样处理的目的

是不干扰单片机的中断逻辑,因为指令RET、RETI和寄存器IE、IP都会直接影响当前单片机的中断逻辑和处理过程。

(3)中断响应过程

单片机的程序存放在程序存储器ROM中。在ROM中有一些存储单元的地址具有特殊意义,见表4-6,这些地址被称为中断入口地址,这些地址所对应的ROM存储单元用于存放中断服务处理程序。

由表4-6可知,相邻程序入口地址之差为8H。这意味着单片机系统中断服务处理程序的长度不能超过8B。但是通常单片机程序不会如此之短,所以在实际应用中总是将中断服务处理程序放在地址较大的其他存储单元,而仅在程序入口地址所对应的ROM单元中放一条可使程序跳转至中断服务处理程序的跳转指令,如:在图4-3所示程序中,指令“LJMP INT_0”用于控制程序跳转至外部中断0的中断服务处理程序“INT_0”。

图4-3典型中断服务处理程序结构

图4-3是一个包含中断服务处理程序的典型程序结构框架。该图中的箭头展示了从主程序执行、单片机暂停主程序、跳转至外部中断0中断服务程序直至返回主程序的全过程。其中,实线箭头是主程序执行过程;虚线箭头是中断服务处理程序的执行过程;空心圆圈代表中断发生的位置,即断点的位置。

在上述过程中,以下两个步骤非常关键:

1)中断请求被响应后,使程序跳转至正确的中断入口。

2)中断服务处理程序结束后,继续执行之前被中断的主程序。

单片机完成这两个关键步骤的方法或过程如下:

(1)跳转至中断服务处理程序

单片机硬件能够识别出被响应的中断源。当中断被响应后,单片机通过硬件LCALL指令实现向中断入口的跳转。该硬件LCALL指令首先将断点地址压入堆栈中(为中断返回做准备);然后将中断源的中断入口地址送入程序计数器(PC),以使程序跳转至中断入口去执行中断服务处理程序。

(2)从中断服务处理程序返回

中断服务处理程序通过指令RETI返回。RETI指令实际完成如下两个操作中:1)将被硬件LCALL指令压入堆栈的断点地址弹出并送入PC,以使程序返回断点处继续执行;2)通知CPU中断已处理完毕,可以开放与该中断同级别的中断。这里再次强调,RETI指令与RET指令不能互换使用,因为RET不具备清0中不进行RETI的操作2)。

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

8位单片机在嵌入式设计领域已经成为半个多世纪以来的主流选择。尽管嵌入式系统市场日益复杂,8位单片机依然不断发展,积极应对新的挑战和系统需求。如今,Microchip推出的8位PIC®和AVR®单片机系列,配备了先进的独立...

关键字: 单片机 嵌入式 CPU

在嵌入式系统开发中,程序烧录是连接软件设计与硬件实现的关键环节。当前主流的单片机烧录技术已形成ICP(在电路编程)、ISP(在系统编程)、IAP(在应用编程)三大技术体系,分别对应开发调试、量产烧录、远程升级等不同场景。...

关键字: 单片机 ISP ICP IAP 嵌入式系统开发

在嵌入式系统开发中,看门狗(Watchdog Timer, WDT)是保障系统可靠性的核心组件,其初始化时机的选择直接影响系统抗干扰能力和稳定性。本文从硬件架构、软件流程、安全规范三个维度,系统分析看门狗初始化的最佳实践...

关键字: 单片机 看门狗 嵌入式系统

本文中,小编将对单片机予以介绍,如果你想对它的详细情况有所认识,或者想要增进对它的了解程度,不妨请看以下内容哦。

关键字: 单片机 开发板 Keil

随着单片机系统越来越广泛地应用于消费类电子、医疗、工业自动化、智能化仪器仪表、航空航天等各领域,单片机系统面临着电磁干扰(EMI)日益严重的威胁。电磁兼容性(EMC)包含系统的发射和敏感度两方面的问题。

关键字: 单片机 电磁兼容

以下内容中,小编将对单片机的相关内容进行着重介绍和阐述,希望本文能帮您增进对单片机的了解,和小编一起来看看吧。

关键字: 单片机 复位电路

在这篇文章中,小编将为大家带来单片机的相关报道。如果你对本文即将要讲解的内容存在一定兴趣,不妨继续往下阅读哦。

关键字: 单片机 异常复位

今天,小编将在这篇文章中为大家带来单片机的有关报道,通过阅读这篇文章,大家可以对它具备清晰的认识,主要内容如下。

关键字: 单片机 仿真器

单片机将是下述内容的主要介绍对象,通过这篇文章,小编希望大家可以对它的相关情况以及信息有所认识和了解,详细内容如下。

关键字: 单片机 中断 boot

一直以来,单片机都是大家的关注焦点之一。因此针对大家的兴趣点所在,小编将为大家带来单片机的相关介绍,详细内容请看下文。

关键字: 单片机 数字信号 模拟信号
关闭