STM32F407ZGT6学习之外部中断

工程代码:https://pan.baidu.com/s/1Qlfg1_br0tN6yy0fcDwCjg,密码:fhh2

(一)、概述

    STM32外部中断通过检测外部的触发事件(上升沿触发、下降沿触发或边沿触发),触发中断事件实现低延迟的中断处理。

 1、外部中断框架图

由下图可以看出,外部中断的边沿检测器连接输入信号,当“软件中断寄存器”和“中断屏蔽寄存器”打开的时候,当有事件触发时,事件会被送到NVIC中断控制器中触发中断事件。

               STM32F407ZGT6学习之外部中断

2、外部中断特性

2.1、中断优先级

    中断包含 16 个可编程优先级(使用了 4 位中断优先级),数字越小的优先级等级越高。通过NVIC_PriorityGroupConfig这个函数,把16个可编程优先级分配给抢占优先级和响应优先级

抢占优先级:可以打断其他抢占优先级低的中断,先运行完自身的中断。

响应优先级:在上一个中断运行结束后,如果另外两种中断的抢占优先级相同,则响应优先级高的中断被运行。

2.2 NVIC中断

    NVIC中断是内核中断,当外部中断事件被送入内核中时,需要设置内核的NVIC的相应参数,才能进入中断服务函数。

可以参考:https://blog.****.net/wuyuzun/article/details/72783152

2.3、中断的触发事件

    外部中断/事件控制器包含多达 23 个用于产生事件/中断请求的边沿检测器,其中0~15号外部中断连接这每组GPIO的一个引脚,不同组GPIO的同一号引脚连接同一号外部中断(如:GPIOA_Pin2、GPIOB_Pin2都连接在外部中断2)。

3、外部中断寄存器

STM32F407ZGT6学习之外部中断

①EXTI_IMR寄存器使能对应的23个的外部中断

②EXTI_EMR寄存器使能对应的23个事件请求

③EXTI_RTSR触发源的选择,使能之后,当输入源有上升沿信号时,将触发对应的事件

④EXTI_FTSR触发源的选择,使能之后,当输入源有下升沿信号时,将触发对应的事件

⑤SWIER寄存器使能软件中断事件,使能时将会触发对应位置的事件