不想看《跟着Hugh学开发--51单片机篇》pdf版本?没关系,网页版 markdown 格式为你准好了!
在单片机中有两个重要的概念分别叫做中断、中断系统,那么他们分别又代表什么意义呢?当单片机 CPU 正在运行主程序时外界发生了紧急事件请求,要求单片机停止当前的工作,而去处理这个紧急事件,处理完成之后,再回到主程序原来的地方继续执行,这样的过程称之为中断,实现中断功能的部件称为中断系统。
一般单片机中都有多个中断源,当多个中断源同时发出请求的时候,单片机应该先响应哪一个呢?在单片机中可以设置中断源的优先级,同时出现时,单片机将优先响应优先级高的中断源。另外一种情况,当单片机 CPU 正在响应某个中断时,一个更高优先级的中断请求产生了,这时 CPU 将暂停响应当前低优先级的中断,转而去响应高优先级的中断源,响应完成后继续处理低优先级中断,之后再回到主程序继续运行,这个过程称之为中断嵌套。
我们这里举一个生活中的例子来解释中断嵌套的过程。当你正在家中打扫卫生的时候,家里座机响了,这时你便会先放下手中的活,然后拿起电话接电话,在打电话的时候有人按门铃了,这是你暂时先放下电话去开门,开完门之后你接着拿起电话继续讲,当挂断电话后,你紧接着刚才继续打扫卫生了。例子中打扫卫生相当于单片机 CPU 执行的主程序,电话相当于低优先级的中断,门铃相当于高优先级的中断。在打电话的时候先去开门相当于中断嵌套。
STC89C52 单片机提供了8个中断请求源,分别为:
外部中断0(INT0);
定时器0中断;
外部中断1(INT1);
定时器1中断;
串口(UART)中断;
定时器2中断;
外部中断2(INT2);
外部中断3(INT3)。
8个中断请求源可以设置为4级中断优先级,每一个中断源都可以通过软件设置为四级优先级的任一级。高优先级的中断可以打断低优先级的中断,反之则不可。同一优先级的中断同时来临时,则根据中断查询的顺序进行中断响应。
表 11-1 中断查询顺序表
如上表所示,在相同优先级内 ,外部中断0的查询次序最高,外部中断3的查询次序最低。举例说明:
第一种情况:
假设在程序中将 INT0 (外部中断0)优先级设置为优先级3, INT1(外部中断1)优先级设置为优先级2,那么,此时 INT0 的优先级高于 INT1。
当两个中断同时到达时,单片机优先处理 INT0,处理完了 INT0,再去处理 INT1。
当程序正在处理 INT1 中断时, INT0 中断来了,这时程序跳出来先去执行 INT0 的中断,处理完了再回来,就是因为 INT0 的优先级更高,处处都得让着它。
第二种情况:
假设在程序中将 INT0 、 INT1 的中断优先级设置为一样,都为优先级3。当他们同时到来时,单片机将会先去处理 INT0 ,因为 INT0 的查询次序高于 INT1 ,如上表所示。
当单片机正在处理 INT1 的中断时, INT0 中断来了,此时,会继续处理 INT1 中断,等处理完了再去处理 INT0 中断,就是因为他两的优先级一样,不能相互打断。
我们可以将上述8种中断源分为3大类:
第一种外部中断(INT0、1、2、3);
第二种定时器中断(Timer0,1,2);
第三中串口中断(UART)。
每种类型中断的使用方式都是相同的,只不过设置的寄存器不同罢了。前面定时器讲解的就是第二种的定时器0中断。所有中断的控制寄存器如下表所示,包括7个八位的寄存器。如下表所示, IP、 IPH 寄存器在单片机复位后值均为0,结合表 11-1 可知,在不对这两个寄存器进行重新设置时,所有中断均为优先级0。
表 11-2 中断控制寄存器
在分析上述7个寄存器之前,我们先来看一下单片机中断系统结构图,如下图所示。
图 11-1 中断系统结构图
每一个中断都有一个单独中断允许开关,例如, INT0 开关为 EX0, Timer0 为 ET0。如果这个开关没有关闭的话,中断是进入不了单片机的。
之后有一个中断允许总开关 EA,这个开关如果断开的话所有的中断都进入不了单片机。
上图中的 IE0, IE1, IE2 等分别是 INT0,1,2的中断标志位,也就是说对应的中断来了他们会被置1。
根据上图举例说明:
首先,当 INT0 中断来临时,他的中断标志位 IE0=1。随后,如果中断允许开关 EX0 和中断总开关同时都闭合的情况下, INT0 中断才会进入单片机内部,这时单片机根据它的优先级高低开始处理了。
在C语言编程中,中断又是怎么来实现的呢?首先在主程序初始化中设置好中断的工作方式,然后允许中断,接着程序执行主程序,当中断来临时,程序跳转到对应的中断子函数中执行相应的操作,执行完之后继续回到主程序。在C语言中,8个中断源对应这8个中断子程序函数,如下图所示,将中断要实现各功能编辑到相应的函数中即可。
图 11-2 单片机中断函数
如图 11-2 所示,前面函数的名字可以根据需要进行更改,关键字 interrupt x决定了这个函数属于哪个中断,前面讲到的定时器0中断,那么它对应为” interrupt 1”。 interrupt 0对应 INT0, interrupt 3对应定时器1中断。当中断来了之后,我们具体要干什么工作,将具体的代码写到上述对应的函数中即可。
STC89C52 系列单片机对中断源可开放或屏蔽,是由内部的特殊功能寄存器 IE (中断允许寄存器)进行控制的, IE 寄存器格式如下:
中断允许寄存器 IE 各位功能定义如下表所示:
表 11-3 寄存器 IE 位定义
控制位 | 功能 | 描述 |
---|---|---|
EA | 中断允许控制位 | EA=1,单片机 CPU 开放中断。 EA=0, CPU 屏蔽所有中断请求。 |
ES | 串行口1中断允许位 | ES=1,允许串行口1中断。 ES=0,禁止串行口1中断。 |
E T2 | 定时器/计数器 T2 的溢出中断允许位 | E T2 =1,允许 T2 中断。E T2 =0,禁止 T2 中断。 |
E T1 | 定时器/计数器 T1 的溢出中断允许位 | E T1 =1,允许 T1 中断。E T1 =0,禁止 T1 中断。 |
E T0 | 定时器/计数器 T0 的溢出中断允许位 | E T0 =1,允许 T0 中断。E T0 =0,禁止 T0 中断。 |
EX1 | 外部中断1中断允许位 | EX1=1,允许外部中断1中断。 EX1=0,禁止外部中断1中断。 |
EX0 | 外部中断0中断允许位 | EX0=1,允许外部中断0中断。 EX0=0,禁止外部中断0中断。 |
单片机 STC89C52 复位后会将寄存器 IE 清零,由户对 IE 中相应的位清 “0” 或置 “1” 来实现中断请求的允许或屏蔽。
总结一下:
** EA 为中断总开关, EA =1允许中断, EA =0禁止任何中断进入单片机;**
其他均为各个中断的开关,1表示允许中断,0表示禁止中断;
ET0-ET2 分别代表定时器 0-2, ES 代表串口中断, EX0-EX1 代表 INT0-1。
传统 51 单片机具有两级中断优先级,可实现中断嵌套。通过中断优先级寄存器 IP 可实现优先级的控制。 IP 寄存器格式如下:
中断优先级控制寄存器 IP 各位功能定义如下表所示:
表 11-4 寄存器 IP 位定义
控制位 | 功能 |
---|---|
PT2 | 定时器2优先级控制位 |
PT0=0,定时器2中断为低优先级 | |
PT0=1,定时器2中断为高优先级 | |
PT1 | 定时器1优先级控制位 |
PT0=0,定时器1中断为低优先级 | |
PT0=1,定时器1中断为高优先级 | |
PT0 | 定时器0优先级控制位 |
PT0=0,定时器0中断为低优先级 | |
PT0=1,定时器0中断为高优先级 | |
PS | 串口中断优先级控制位 |
PS=0,串口中断为低优先级 | |
PS=1,串口中断为高优先级 | |
PX1 | 外部中断1优先级控制位 |
PX1=0,外部中断1为低优先级 | |
PX1=1,外部中断1为高优先级 | |
PX0 | 外部中断0优先级控制位 |
PX0=0,外部中断0为低优先级 | |
PX0=1,外部中断0为高优先级 |
单片机复位后,优先级控制寄存器 IP 将清零,即所有中断请求均为低优先级。
总结一下:
IP 寄存器的各个位是用来设中断具体优先级的。
TCON 寄存器在第八章定时器中断时讲解过,其中寄存器的高5位为与定时器/计数器相关的功能位,这里不再赘述。这里介绍与外部中断相关的控制位:
特殊功能寄存器 TCON 低4位功能介绍:
表 11-5 TCON 外部中断位功能定义
控制位 | 功能 | 描述 |
---|---|---|
IE1 | 外部中断1请求源(INT1/P3.3) | IE1=1,外部中断1向 CPU 请求中断,当 CPU 响应该中断是由硬件清 “0” |
IE0 | 外部中断0请求源(INT1/P3.2) | IE0=1,外部中断0向 CPU 请求中断,当 CPU 响应该中断是由硬件清 “0” |
IT1 | 外部中断1中断源类型选择 | IT1=0, INT1/P3.3引脚上的低电平信号可触发中断, IT1=1,外部中断1为下降沿触发方式。 |
IT0 | 外部中断0中断源类型选择 | IT0=0, INT0/P3.2引脚上的低电平信号可触发中断, IT0=1,外部中断0为下降沿触发方式。 |
总结一下:
** IE0 - IE1 分别为外部中断 INT0-INT1 的中断标志位,当对应中断来临时, IE0 或 IE1 等于1;**
IT0-IT1 为外部中断 INT0-INT1 的中断触发方式,0表示低电平,1表示下降沿触发方式。
中断触发方式:
中断 INT0 -INT1 的输入引脚分别对应单片机的 P3.2, P3.3引脚。以 INT0 为例子进行讲解。
低电平触发方式,当 P3.2引脚的电平为0时,将产生 INT0 中断。
下降沿触发方式,当 P3.2引脚的电平从高跳变到底,即从1跳变到0时,将产生 INT0 中断。单片机电路会自动捕获这个跳变的过程。
当单片机 P3.2引脚,从高电平跳变到低电平时,流水灯流动一下。建立工程,并编写 int0.c代码如下:
/*******************************************************************
* 数码管显示测试
* ******************************************************************
* 【主芯片】:STC89SC52/STC12C5A60S2
* 【主频率】: 11.0592MHz
*
* 【版 本】: V1.0
* 【作 者】: stephenhugh
* 【网 站】:https://rymcu.taobao.com/
* 【邮 箱】:
*
* 【版 权】All Rights Reserved
* 【声 明】此程序仅用于学习与参考,引用请注明版权和作者信息!
* 【功 能】INT0 外部中断,下降沿触发实验
*******************************************************************/
#include <reg52.h>
#define uint unsigned int
uint Move = 0;
void main()
{
IT0 = 1;// 设置 INT0 为下降沿触发方式
EX0 = 1;// 允许 INT0 中断
EA = 1;// 开全局中断
while(1);
}
//INT0 中断函数
void int0_r() interrupt 0
{
P1 = ~(0x01<<Move);// 进入一次中断,流动一次
if(Move>=8) Move = 0;
else Move++;
}
图 11 -3 外部中断0实验代码
实验操作方法:
如下图左上角,已经把 P3.2通过焊盘引出来了,可以使用杜邦线一端连接 GND,另一端触碰 P3.2的焊盘模拟下降沿。每触碰一下,流水灯将向前流动一位。
图 11-4 外部中断0位置
实际操作及流水灯效果如下:
图 11 -5 外部中断0试验
本章详细介绍了单片机中断系统的工作原理以及部分中断寄存器功能的定义。介绍了外部中断0功能C语言程序的编写。