
前言 STM32单片机的一个强大之处在于用于庞大的中断体系,掌握STM32对中断优先级的定义是学好STM32中断的前提。本次我们讲解STM32关于中断优先级NVIC的定义。我们以基本原理、寄存器介绍和库函数配置这一 顺序来讲解。 一、基础知识 1.NVIC基础知识 CM3内核支持256个中断,其中包含了16个内核中断和240个外部中断,并且具有256级的可编程中断设置。 STM32并没有使用CM3内核的全部东西,而是只用了它的一部分。有84个中断,包括16个内核中断和68个可屏蔽中断,具有16级可编程的中断优先级。 在STM32F103系列上面又只有60个可屏蔽中断(在107系列才有68个) 2.抢占优先级&响应优先级 抢占优先级也就是先占优先级,概念等同于51单片机中的中断。假设有两中断先后触发,已经在执行的中断抢占优先级如果没有后触发的中断抢占优先级更高,就会先处理抢占优先级高的中断。也就是说又有较高的抢占优先级的中断可以打断抢占优先级较低的中断。这是实现中断嵌套的基础。 响应优先级,也就是次占优先级,只在同一抢占优先级的中断同时触发时起作用,抢占优先级相同,则优先执行响应优先级较高的中断。响应优先级不会造成中断嵌套。 如果中断的两个优先级都一致,则优先执行位于中断向量表中位置较高的中断。 3.中断向量表 ![]() ![]() ![]() ![]() (图片来自STM32中文参考手册) 4.中断优先级分组 看到中断向量表后,想必大家都会心生疑问:STM32有几十个中断,怎么管理呢? 这就要讲解中断管理方法了,首先对STM32的中断进行分组,组0~4。同时,对每个中断设置一个抢占优先级和一个响应优先级值。 分组配置是在寄存器SCB->AIRCR中配置: ![]() 二、配置中断相关寄存器 以下是位于CM3内核中的与NVIC分组相关的寄存器:
中断优先级控制的寄存器组:IP[240] 全称是:Interrupt Priority Registers。240个8位寄存器,每个中断使用一个寄存器来确定优先级。STM32F10x系列一共60个可屏蔽中断,使用IP[59]~IP[0]。每个IP寄存器的高4位用来设置抢占和响应优先级(根据分组),低4位没有用到。 中断失能寄存器组:ICER[8] 作用:用来失能中断。32位寄存器,每个位控制一个中断的失能。STM32F10x只有60个可屏蔽中断,所以只使用了其中的ICER[0]和ICER[1]。ICER[0]的bit0~bit31分别对应中断0~31。ICER[1]的bit0~27对应中断32~59;配置方法跟ISER一样。 中断挂起控制寄存器组:ISPR[8] 作用:用来挂起中断 中断解挂控制寄存器组:ICPR[8] 作用:用来解挂中断 中断激活标志位寄存器组:IABR[8] 作用:只读,通过它可以知道当前在执行的中断是哪一个。如果对应位为1,说明该中断正在执行 三、库函数配置 1.中断参数初始化函数
2.中断优先级设置步骤 ①系统运行后先设置中断优先级分组,调用函数: void NVIC_PriorityGroupConfig(uint32_t NVIC_PriorityGroup); 整个系统执行过程中,只设置一次中断分组。 ②针对每个中断,设置对应的抢占优先级和响应优先级: void NVIC_Init(NVIC_InitTypeDef* NVIC_InitStruct); ③ 如果需要挂起/解挂,查看中断当前激活状态,分别调用相关函数即可。 总结 要想学习STM32中断,要先掌握STM32对优先级的分组。本讲以原理、相关寄存器介绍和库函数配置的顺序对STM32的NVIC中断优先级进行讲解,希望读者反复研究,为以后的学习打好基础。 |
【下载有礼】STM32 Finder华为应用商店正式上线!移动选型工具助力开发效率升级
【2025·STM32峰会】GUI解决方案实训分享5-调通板载的NRF24L01 SPI接口并使用模块进行无线通信(发送和接收)
【2025·STM32峰会】GUI解决方案实训分享2-编译运行TouchGFX咖啡机例程(含桌面仿真)
实战经验 | Keil工程使用NEAI库的异常问题
STM32 ISP IQTune:真正零门槛的免费ISP调整软件
【经验分享】STM32 新建基于STM32F40x 固件库的MDK5 工程
意法半导体MCU双供应链策略,打消中国客户后顾之忧
2024意法半导体工业峰会:赋能智能电源和智能工业,构筑可持续未来
ST推出灵活、面向未来的智能电表通信解决方案,助力能源转型
意法半导体 x Qu-Bit Electronix:推动新一轮的数字声音合成革命