0 [1 U. c2 T# S
pbuldntfby364011395310.png
1 c1 g& l! T) h) s" |
5 H% K, r1 I4 X# L
1,环境搭建:& C) l& O Z4 d* \& Z/ @* A
硬件平台:STM32H750XBH6开发环境:STM32CubeMX V6.8.1+KEIL V5.28.0.0STM32H750固件版本:package V1.11.0仿真下载驱动:ST-Link
3 b" L3 C) _0 E! _, v, Z9 K! _4 s2 g2,中断的定义
" g$ y5 _ p5 b9 f8 q中断(Interrupt)微控制器中的一种机制,允许在正常程序执行期间暂停当前正在执行的任务,以处理特定事件或条件。这些事件或条件可以是来自外部的信号、设备状态的改变、定时器触发、错误条件等。中断使系统能够及时响应重要事件,而无需不断轮询或等待事件的发生。3,中断的分类
3 U# G& w6 J) H6 N7 O9 B8 x中断可以根据多个因素进行分类,主要根据其来源、优先级、触发方式和处理方式。以下是一些常见的中断分类:
1 O$ I/ g% T$ b* U+ C8 g根据来源分类:A.外部中断(External Interrupts):这些中断来自于外部硬件或设备,如按键、传感器、通信接口等的触发信号。B.内部中断(Internal Interrupts):这些中断源于处理器或微控制器内部的事件,如定时器计数溢出、除零错误等。 b% [/ }7 t, E) b$ T$ s! n
根据触发方式分类:A.硬件中断(Hardware Interrupts):硬件中断是由硬件触发的中断,如外部设备产生的信号。B.软件中断(Software Interrupts):软件中断是由程序中的指令产生的,通常用于执行特定功能或服务调用。
; F2 G$ S3 N. G& f根据优先级分类:A.可屏蔽中断(Maskable Interrupts):这些中断可以通过设置中断屏蔽位来禁用或启用。通常,系统可以控制是否屏蔽可屏蔽中断。B.不可屏蔽中断(Non-Maskable Interrupts,NMI):这些中断无法被屏蔽,通常用于处理紧急或重要事件,如硬件故障。( P& }; X. ^+ f b
根据处理方式分类:A.同步中断(Synchronous Interrupts):这些中断在程序执行期间同步触发,例如除零错误。B.异步中断(Asynchronous Interrupts):这些中断可以随时发生,不受程序控制,例如外部硬件触发的中断。
8 I% \2 S7 |$ |8 g$ m! |根据应用领域分类:A.实时中断(Real-Time Interrupts):这些中断需要在严格的时间要求内进行处理,通常用于实时系统,如航空航天、汽车控制等。B.一般用途中断(General-Purpose Interrupts):这些中断用于一般计算和控制任务,时间要求没有那么严格。/ i4 y, k$ a% i! p- C3 O- a
根据中断向量表分类:A.单一中断向量表(Single Interrupt Vector Table):整个系统使用一个中断向量表,每个中断在表中有唯一的入口点。B.多中断向量表(Multiple Interrupt Vector Tables):不同的模块或设备可能使用独立的中断向量表,每个表包含特定设备的中断处理程序。# J6 y6 P& |3 Y' M% S* r) g7 l% S
[/ol] p& }$ W2 o% |% u+ a& q2 j5 S
1j0wzf0gf4q64011395410.png
' [- a w3 s W4 p% q) @' r! k3 }
4,内部中断与外部中断: s2 p7 X) o+ V1 J! L/ r5 g
内部中断和外部中断是根据中断的来源和触发方式来进行分类的两种常见中断类型。它们在嵌入式系统和微控制器中具有不同的特点:! |, a0 q/ e$ W
1. 内部中断4 [* F t5 M& A( w1 h
来源:内部中断是由处理器或微控制器内部的事件引发的。这些事件通常与处理器或微控制器的运行状态和特性有关,例如定时器溢出、除零错误、指令执行完成等。触发方式:内部中断是同步的,它们在程序执行期间由内部事件引发,通常是特定指令的执行或计时器/计数器的状态变化。屏蔽:通常,内部中断可以通过设置中断屏蔽位来禁用或启用。处理器通常提供了特定的寄存器或标志位来管理内部中断的屏蔽。例子:除零错误、非法指令、定时器中断等都可以归类为内部中断。
+ u$ J( c* \6 E2. 外部中断:( G; \+ {# N9 s0 q. g- y# g
来源:外部中断是由外部硬件或设备触发的事件引发的,如按键、传感器、通信接口等。触发方式:外部中断是异步的,它们可以随时发生,不受程序控制。通常,当外部事件满足特定条件时,外部中断会被触发。屏蔽:外部中断通常可以通过设置中断屏蔽位来禁用或启用。在外部中断情况下,系统可以根据需要控制是否屏蔽外部中断。例子:按键按下、传感器触发、串行通信接口数据接收等都可以归类为外部中断。
# p. c( |- {! h; u0 s) n5,中断优先级! v: v( t j/ `4 d! N
中断优先级分组:STM32微控制器使用中断优先级分组来划分中断优先级。中断优先级分组的设置决定了可用的优先级位数和子组位数。通常,分组位数越多,允许更精细的优先级控制。/ c8 y" S. D$ K% [- U( z
优先级位数:在STM32中,通常有4位或3位用于中断优先级设置,具体取决于微控制器型号。较多的优先级位数允许更精细的控制。
) W0 B2 {* j3 n5 K8 J8 Z子组位数:某些STM32系列支持子组位数,这允许在同一主组中进一步细分优先级。4 Y7 V N% U9 o+ C9 q
中断优先级值:中断优先级值是一个数字,通常在0到(2^N - 1)之间,其中N是可用的位数。较小的值表示更高的优先级。在中断优先级寄存器中,优先级值的最高位通常是最重要的位。
$ ~6 p% O" D) F' K: e% W中断优先级设置:为了设置中断优先级,您需要编程配置中断控制器的相关寄存器。具体的设置方法和寄存器名称可能因STM32微控制器型号而异,因此您需要查看特定型号的参考手册和数据表。中断优先级分组示例:以下是一个示例,展示了如何设置中断优先级:Group 0, Subgroup 0: 0x00 - 0x03Group 0, Subgroup 1: 0x04 - 0x07Group 1, Subgroup 0: 0x08 - 0x0B...Group 7, Subgroup 1: 0x38 - 0x3BGroup 0: 0x00 - 0x0FGroup 1: 0x10 - 0x1FGroup 2: 0x20 - 0x2F...Group 15: 0xF0 - 0xFF4位分组,0位子组:3位分组,1位子组:[/ol]4,中断嵌套5 s1 x0 t; H: ?; x# G
在STM32微控制器中,中断嵌套(Interrupt Nesting)是一种机制,允许处理多个中断请求,并在一个中断服务程序中嵌套地处理其他中断。这种机制非常有用,因为它使您能够处理多个中断,而不需要等待一个中断服务程序完成后才能处理下一个中断。这提高了系统的响应性,特别是在具有多个优先级的中断时。
6 d; o7 N: T% s. W; r: \0 t以下是有关STM32中断嵌套的一些关键概念:中断嵌套优先级:STM32支持设置每个中断请求的中断优先级。通过设置不同的中断优先级,您可以控制中断的相对优先级。当多个中断同时发生时,高优先级的中断将优先得到处理。这确保了对紧急事件的快速响应。中断嵌套的允许:STM32允许中断嵌套,但它需要在中断控制寄存器中进行相应的配置。中断服务程序(ISR)中的中断嵌套:如果在中断服务程序中发生了中断,系统会检查新中断的优先级。如果新中断的优先级更高,系统会暂停当前中断服务程序的执行,并立即开始新中断的服务程序。一旦新中断服务程序完成,系统会返回到原始中断服务程序的执行点,继续执行。中断服务程序的嵌套深度:STM32支持多级中断嵌套,这意味着可以在中断服务程序中触发其他中断,而这些新中断也可以再触发其他中断,依此类推。这允许系统以一种高度灵活的方式处理多个中断。
! j( b; X8 g* ]5,代码与中断对于内核来说提供的优先级有多少位在芯片厂商设计的时候并不会用到全部,ST只用到了四位,并且默认配置使用16个主优先级,并没有用到子优先级,我们可以看到可配置优先级为0-15 数字越大优先级越低- i* k0 x2 h! e; L5 c, N
4j3f0dfa5ps64011395511.png
5 R5 N2 O* W J1 s: S
: H! K7 W3 U! l* {& s
c4cdp0p1xdk64011395611.png
" K5 v/ a) r* J- |) @
. c! w. v( O5 b: l& V( v9 _& h# C
以下是如何配置和使用 STM32 中断的简单步骤:9 I! H2 D7 b) J K( N7 J
A.配置中断源:首先,你需要配置引起中断源。例如,如果你使用外部引脚作为中断源,你需要配置该引脚为外部中断模式。B.设置优先级:使用 NVIC 函数来设置中断优先级。C.启用中断:再次使用 NVIC 函数启用特定的中断。D.编写ISR:为特定的中断源编写一个处理函数。例如,如果你为 EXTI0编写一个ISR,你可能会有一个如下的函数:void EXTI0_IRQHandler(void) { // 处理中断的代码 // 清除中断标志 EXTI_ClearITPendingBit(EXTI_Line0); }注意:确保你的主程序中已经启用了全局中断。通常,这是通过 __enable_irq(); 函数实现的。一旦中断发生,程序将自动跳转到相应的 ISR。确保你的 ISR 是简短和高效的,以避免长时间的中断延迟。
6 M" @7 c$ A+ D7 M2 K==========1 A) D, T7 s* c
往期回顾:; b) g- i) A6 }! Q2 }" g# I" ?
【蓝桥杯单片机】第二章 软件安装) `! |2 d% X( M
【蓝桥杯单片机】第一章 大赛概述1 x5 |9 i1 q, [. Q7 j/ K6 F" {
【蓝桥杯嵌入式】第九章 PWM! W1 y$ [& B7 Z4 R }
【蓝桥杯嵌入式】第八章 串口接收
) q# M) T! L; {; v6 n( ~+ o==========
6 |( E8 \% m: ?
q4m130uru1164011395711.png
+ j: D" L6 \! D8 E" R
& d) x7 p! e! I1 E) Z$ T
6 G# V/ n( j2 X+ {" j
r0sa0zgzkrx64011395811.png
|