微控制器(单片机)的中断系统及应用

news/2025/1/3 4:40:14/

文章目录

    • 1. 什么是中断
      • 1.1 中断的概念
      • 1.2 中断源
        • 1.2.1 中断源的种类
    • 2. 中断寄存器
      • 2.1 TCON寄存器
      • 2.2 SCON寄存器
      • 2.3 IE寄存器
      • 2.4 IP寄存器
    • 3. 中断处理流程
      • 3.1 定时器中断实操
      • 3.2 外部中断实操
      • 3.3 思考题:
    • 4. 最重要的事

1. 什么是中断

1.1 中断的概念

中断是指中央处理器CPU正在处理某件事情的时候,外部发生了某一事件(如定时器计时已到),请求CPU迅速去处理,CPU暂停当前的工作,转去处理所发生的事件,处理完以后,再回到原来被中断的地方,继续原来的工作。实现这种功能的部件称为中断系统。它由4个与中断有关的特殊功能寄存器(TCON、SCON)中断允许控制寄存器IE中断顺序查询逻辑等组成。

1.2 中断源

我们将发起中断申请的设备,称为中断源。

1.2.1 中断源的种类

根据中断源的不同,可分为2个外部中断源,3个内部中断源:

  • /INT0:外部中断0,中断请求信号由P3.2端口线引入,低电平或下跳沿引起。
  • /INT1:外部中断1,中断请求信号由P3.3端口线引入,低电平或下跳沿引起。
  • T0:定时/计数器0溢出中断,对外部脉冲计数由P3.4输入,由T0计满回零引起。
  • T1:定时/计数器1溢出中断,对外部脉冲计数由P3.5输入,由T1计满回零引起。
  • 串行中断:包括串行接收中断RI和串行发送中断TI。

2. 中断寄存器

单片机中主要包含四类特殊的寄存器对中断进行控制:

  • TCON:定时/计数器控制寄存器
  • SCON:串行口控制寄存器
  • IE:中断允许寄存器
  • IP:中断优先级寄存器

2.1 TCON寄存器

每个中断源对应一个中断标志位,当某个中断源有中断请求时,相应的中断标志位置1,各中断源的中断标志位在TCON和SCON中,具体如下表所示:
在这里插入图片描述
说明:

  • 标志位IE0=1时,表示外部中断/INT0提出了中断请求,如果IE0=0,则没有中断请求;
  • 标志位IE1=1时,表示外部中断/INT1提出了中断请求;
  • 标志位TF0=1时,表示定时器/计数器T0提出了中断请求;
  • 标志位TF1=1时,表示定时器/计数器T1提出了中断请求。
  • IT0:外部中断0触发方式控制位。
    • 当IT0=0时,为电平触发方式(低电平有效);
    • 当IT0=1时,为边沿触发方式(下降沿有效)。
  • IT1(TCON.2):外部中断1触发方式控制位,其作用和IT0类似。
  • TR0(TCON.4):定时/计数器T0运行控制位。
    当TR0=1,启动定时/计数器T0;反之,停止定时/计数器T0。
  • TR1(TCON.6):定时/计数器T1运行控制位,其作用和TR0相同。

2.2 SCON寄存器

在这里插入图片描述
这里补充一下串口通信的四种模式,方便后面理解各个标志位的作用:
在这里插入图片描述
说明:

  • TI:串行口发送中断标志位,当CPU将一个发送数据写入串行口发送缓冲器时,就启动了发送过程。每发送完一个串行帧,由硬件置位TI,即TI=1。 CPU响应中断时,不能自动清除TI,TI必须由软件清除。
  • RI:串行口接收中断标志位。当允许串行口接收数据时,每接收完一个串行帧,由硬件置位RI,即RI=1,RI也必须由软件清除。
  • SM0、SM1:串口工作方式选择位,用于控制串口通信模式。
  • SM2:多机通信控制位,主要用于方式2和方式3。
  • REN:允许串行接收位。由软件置REN=1,则启动串行口接收数据;若置REN=0,则禁止接收。
  • TB8:在方式2或方式3中,是发送数据的第九位,可以用软件规定其作用,例如:作为数据的奇偶校验位,或在多机通信中,作为地址帧/数据帧的标志位。在方式0和方式1中,该位未用。
  • RB8:在方式2或方式3中,是接收到数据的第九位,作为奇偶校验位或地址帧/数据帧的标志位。在方式1时,若SM2=0,则RB8是接收到的停止位。

2.3 IE寄存器

中断系统中所有中断以及某个中断源的开放和屏蔽是由中断允许寄存器IE控制的,IE可进行位寻址。中断允许寄存器IE对中断的开放和关闭实现两级控制。(PS:两级控制是指有一个总的开关中断控制位EA。当EA=0时,所有的中断请求被屏蔽,CPU对任何中断请求都不接受;当EA=1时,CPU开放中断,但5个中断源的中断请求是否允许,还要由IE中的低5位所对应的5个中断请求允许控制位的状态来决定。)
在这里插入图片描述
说明:

  • EA:CPU中断允许(总允许)位。EA0=0,所有中断关闭,EA=1,CPU打开中断。
  • ES:串行口中断允许位。ES=1,允许串口中断,否则关闭串口中断。
  • ET1:定时/计数器T1中断允许位。ET1=1,允许T1中断,否则关闭T1中断。
  • EX1:外部中断1允许位。EX1=1,允许外部中断1中断,否则关闭外部中断1。
  • ET0:定时/计数器T0中断允许位。其功能与ET1相同。
  • EX0:外部中断0允许位。其功能与EX1相同。

2.4 IP寄存器

单片机有两个中断优先级,即可实现二级中断服务嵌套。两级优先级遵循下述规则:仅高优先级可中断嵌套低优先级。简而言之:高优先级的中断可打断低优先级的中断。
在这里插入图片描述
说明:

  • PX0:外部中断0优先级设定位;
  • PT0:定时/计数器T0优先级设定位;
  • PX1:外部中断1优先级设定位;
  • PT1:定时/计数器T1优先级设定位;
  • PS:串行口优先级设定位;
    注意: 对于同一优先级的中断,一旦中断得到响应,就不会被其他中断打断。对于各中断的优先权值,则根据中断的系统的自然优先级形成,自然优先级如下图所示:
    在这里插入图片描述

3. 中断处理流程

在这里插入图片描述

3.1 定时器中断实操

要求:使P1.0管脚上输出周期为2ms的方波脉冲。设单片机晶振频率‎Fosc=6MHz。
思路:利用定时器T0作1ms定时,达到定时值后引起中断,在中断服务程序中,使P1.0的状态取一次反,并再次定时1ms。
PS:当定时器/计数器工作在方式1时,且确定定时为T后,其初值的计算公式为:

X = 65536 - T x Fosc /12

编程实现为:

#include <reg52.h>sbit Pulse=P1^1;//初始化定时器
void InitTimer0( ){EA = 0;				//禁止所有中断TMOD =  0x01;		// T0为定时器状态,工作方式1TL0 =  (65536 - 10000) / 256 ;			// T0的低位定时初值TH0 = (65536 - 10000) %256 ;		// T0的高位定时初值ET0 = 1;			//允许定时器/计数器0的溢出中断EA = 1;				//开CPU中断TR0 = 1;			//启动定时器0
}
//定时器0中断服务程序
void IRQTimer0 () interrupt 1{EA=0;TL0 = (65536 - 10000) / 256;			// T0的低位定时初值TH0 =  (65536 - 10000) %256;		// T0的高位定时初值Pulse=~Pulse;EA=1;
}
//主程序
void main() {InitTimer0( )Pulse=1;while(1);
}

3.2 外部中断实操

要求:绘制电路图,并通过按键实现LED灯的闪烁。
思路:将按键信号作为单片机外部中断触发信号。每产生一个外部中断就将与LED灯相连的P1.0口电平取反,从而实现LED灯闪烁
PS:由于手动按键存在机械抖动,且按键会持续一段时间(约50~100ms),为避免一次按键产生多次外部中断,需要在每次中断后进行一定延时处理,确保本次按键已经释放

实现:电路图设计为:
在这里插入图片描述
编程为:

#include<reg51.h>
sbit LED=P1^0;
// 主函数
void main(void){P3=0xff;     //端口初始化,为外部中断信号输入作准备。EA=1;	    //开总中断IT0=0;	    //设置外部中断0为电平触发方式EX0=1;	    //外部中断0允许LED=0;	//LED初始状态为点亮	while(1);     //等待中断	
}
//外部中断0服务程序
void EIRQ0(void) interrupt 0{unsigned int iDelay=0;EX0=0;	     //关外部中断1 LED=~ LED;   //来一个外部中断信号LED状态改变一次For(iDelay=0; iDelay<65535; iDelay++); //延时等待按键释放EX0=1;	     //开外部中断1
}

3.3 思考题:

现要求编制程序,并设计相关外部电路,使P1.1管脚上连接LED,并在外部中断INT0连接按键。设单片机晶振频率‎Fosc=12MHz。
1.利用定时器T0使得达到定时值后引起中断,在中断服务程序中,使LED灯状态发生反转,并持续500ms。
2.若单片机被外部中断INT0中断,则在中断服务程序中使得LED等的状态进行500ms每次的闪烁(亮500ms,灭500ms)反复5次,期间可被定时器中断,5次以后重新回到INT0中断前状态。

想要获取或查看思考题的答案,请关注公众号:Newtol,后台回复暗号:中断

4. 最重要的事

有关转载、错误指正、问题咨询等事宜请扫码关注个人公众号进行联系,更有大量视频学习资源分享

http://www.ppmy.cn/news/123466.html

相关文章

操作系统中的中断控制

本文为随笔&#xff0c;更多细节可关注微信公众号&#xff1a;emOsprey uCOS II MAX_SYSCALL_INTERRUPT_PRIORITY EQU 3 ; 屏蔽低于优先级 2 的中断&#xff0c;即抢占优先级设置为 0~2 将被屏蔽&#xff0c;3不屏蔽 OS_CPU_SR_SaveMRS R0, BASEPRI ; 读取 PRI…

【中断篇】中断控制器及中断检测时序

&#x1f31f;&#x1f31f;&#x1f31f;博主主页&#xff1a;MuggleZero &#x1f31f;&#x1f31f;&#x1f31f; 《ARMv8架构初学者笔记》专栏地址&#xff1a;《ARMv8架构初学者笔记》 GIC-500控制器支持GICv3架构&#xff0c;具有以下中断类型&#xff1a; SGI&#xff…

ARM通用中断控制器GIC之中断处理简介

在阅读本章之前&#xff0c;可以参考笔者之前关于GIC的一些描述&#xff1a; ARM通用中断控制器GIC(generic Interrupt Controller)简介 ARM架构Generic Interrupt Controller(GIC)之Distributor和CPU interface功能介绍 ARM架构Generic Interrupt Controller(GIC)详解之术语…

Linux中断子系统【1】- 中断控制器GIC驱动分析

系列文章目录 Linux中断子系统【1】- 中断控制器GIC驱动分析 Linux中断子系统【2】- Linux内核软中断softirq和小任务tasklet分析 Linux中断子系统【3】- Linux内核request_irq源码分析 Linux中断子系统【4】- Linux中断子系统之中断映射(初始化中断控制器) Linux中断子系统【…

操作系统中的中断

中断是指CPU对系统发生的某个事件做出的一种反应&#xff0c;CPU暂停正在执行的程序&#xff0c;保存现场后自动去执行相应的处理程序&#xff0c;处理完该事件后再返回中断处继续执行原来的程序。。中断一般三类&#xff0c;一种是由CPU外部引起的&#xff0c;称为外中断。如I…

系统中断介绍

1、介绍&#xff1a; 中断&#xff1a;是指计算机程序运行过程中&#xff0c;系统外部、系统内部或者现行程序本身若出现紧急事件&#xff0c;处理机立即中止现行程序的运行&#xff0c;自动转入相应的处理程序(中断服务程序)&#xff0c;待处理完后&#xff0c;再返回原来的程…

soc(九) 中断控制器

中断控制器在SOC中的位置 中断控制器需要做什么事情 从某个 简单中断处理器 的角度考虑 整个过程 既然处理中断的最核心模块是 中断控制器 , 那么 我们就应该了解 中断控制器的典型工作流程 . 在了解工作过程中自然了解到 中断控制器留给 CPU 的接口.从而达到怎么控制中断控制…

中断与中断控制器8259A

中断与中断控制器8259A 中断概述8086/8088中断矢量设置方法一方法二 可屏蔽中断的响应过程中断控制器8259A8259A工作原理8259A工作方式1.设置优先级的方式&#xff08;1&#xff09;全嵌套方式&#xff08;2&#xff09;特殊全嵌套方式&#xff08;3&#xff09;优先级自动循环…