STM32基础入门——外部中断

目录

一.外部中断介绍

二.外部中断概述

1. STM32的外部中断线

2.外部中断线与IO引脚对应关系

3. 中断向量与服务函数

4.EXTI功能框图 

         三.外部中断配置(CUBEMX)

1.思维导图

2.工程配置

3.代码详解


一.外部中断介绍

首先我们要理解什么是中断。

想象一个场景:你在家里看书学习,这时候突然来电话了。你的做法是停止学习去接电话,电话打完再放下电话继续学习。这一个过程就体现了中断的思想。我们抽象一下,把自己想象成一个单片机系统,看书就是正在执行的主任务,如果没有外界干扰,这个系统会一直执行当前的主任务。而当外部有改变(电话响了)的时候,系统会第一时间响应,从主任务跳转到这个紧急任务中,这个突发的事件就是(外部)中断,而系统处理的紧急任务则是中断处理函数。当紧急任务(接电话)完毕之后,系统又会回到最初的主任务中。

EXTI(External interrupt/event controller)—外部中断/事件控制器,管理了控制器的 19个中断/事件线。每个中断/事件线都对应有一个边沿检测器,可以实现输入信号的上升沿检测和下降沿的检测。EXTI 可以实现对每个中断/事件线进行单独配置,可以单独配置为中断或者事件,以及触发事件的属性。
 

二.外部中断概述

1. STM32的外部中断线

STM32的每个IO都可以作为外部中断输入。
STM32的中断控制器支持19个外部中断/事件请求:
线0~15:对应外部IO口的输入中断。

线16:连接到PVD输出。

线17:连接到RTC闹钟事件。

线18:连接到USB唤醒事件。

每个外部中断线可以独立的配置触发方式(上升沿,下降沿或者双边沿触发),触发/屏蔽,专用的状态位。

2.外部中断线与IO引脚对应关系

 这时候想必读者可能要问了,STM32供IO使用的中断线只有16个,但是STM32F10x系列的IO口多达上百个,STM32F103ZET6(112),STM32F103RCT6(51),那么中断线怎么跟IO口对应上呢?下图就是STM32的外部中断线和IO口的对应关系:

对于每个中断线,我们可以设置相应的触发方式(上升沿触发,下降沿触发,边沿触发)以及使能。

3. 中断向量与服务函数

 

4.EXTI功能框图 

      1.输入线,EXTI 控制器有 19 个中断/事件输入线,这些输入线可以通过寄存器设置为任意一个 GPIO,也可以是一些外设的事件。输入线一般是存在电平变化的信号。
        2.一个边沿检测电路,它会根据上升沿触发选择寄存(EXTI_RTSR)和下降沿触发选择寄存器(EXTI_FTSR)对应位的设置来控制信号触发。边沿检测电路以输入线作为信号输入端,如果检测到有边沿跳变就输出有效信号 1 给编号 3 电路,否则输出无效信号0。而 EXTI_RTSR 和 EXTI_FTSR 两个寄存器可以控制器需要检测哪些类型的电平跳变过程,可以是只有上升沿触发、只有下降沿触发或者上升沿和下降沿都触发。
        3.或门电路,它一个输入来自编号 2 电路,另外一个输入来自软件中断事件寄存器(EXTI_SWIER)。EXTI_SWIER允许我们通过程序控制就可以启动中断/事件线,这在某些地方非常有用。我们知道或门的作用就是有 1 就为 1,所以这两个输入随便一个有有效信号 1就可以输出 1 给编号 4和编号 6电路。
        4.与门电路,它一个输入是编号 3 电路,另外一个输入来自中断屏蔽寄存器(EXTI_IMR)。与门电路要求输入都为 1 才输出 1,导致的结果是如果 EXTI_IMR 设置为 0 时,那不管编号 3 电路的输出信号是 1 还是 0,最终编号 4 电路输出的信号都为 0;
如果EXTI_IMR设置为1时,最终编号4电路输出的信号才由编号3电路的输出信号决定,这样我们可以简单的控制 EXTI_IMR 来实现是否产生中断的目的。编号 4 电路输出的信号会被保存到挂起寄存器(EXTI_PR)内,如果确定编号 4 电路输出为 1 就会把 EXTI_PR 对应位置 1。
        5.将 EXTI_PR 寄存器内容输出到 NVIC 内,从而实现系统中断事件控制。
接下来我们来看看绿色虚线指示的电路流程。它是一个产生事件的线路,最终输出一个脉冲信号。
产生事件线路是在编号3电路之后与中断线路有所不同,之前电路都是共用的。
        6.与门电路,它一个输入来自编号 3 电路,另外一个输入来自事件屏蔽寄存器(EXTI_EMR)。如果 EXTI_EMR设置为 0时,那不管编号 3电路的输出信号是 1还是 0,最终编号 6 电路输出的信号都为 0;如果 EXTI_EMR 设置为 1 时,最终编号 6 电路输出的信号才由编号 3 电路的输出信号决定,这样我们可以简单的控制 EXTI_EMR 来实现是否产生
事件的目的。
        7.脉冲发生器电路,当它的输入端,即编号 6 电路的输出端,是一个有效信号 1 时就会产生一个脉冲;如果输入端是无效信号就不会输出脉冲。
        8.脉冲信号,就是产生事件的线路最终的产物,这个脉冲信号可以给其他外设电路使用,比如定时器 TIM、模拟数字转换器 ADC等等,这样的脉冲信号一般用来触发 TIM 或者 ADC开始转换。


三.外部中断配置(CUBEMX)

1.思维导图

 2.工程配置

1.首先选择中断模式

 2.

 

3.使能中断,配置优先级
ps:
编号越小,表明它的优先级别越高
抢占,是指打断其他中断的属性,即因为具有这个属性会出现嵌套中断(在执行中断服务函数A 的过程中被中断B 打断,执行完中断服务函数B 再继续执行中断服务函数A)
响应属性则应用在抢占属性相同的情况下,当两个中断向量的抢占优先级相同时,如果两个中断同时到达, 则先处理响应优先级高的中断

选择配置后新建工程

3.代码详解

在stm.f1xx_it.c中找到

 

_weak说明是个虚函数,我们来编写这个函数,我们复制这个函数名到main.c里

oid HAL_GPIO_EXTI_Callback(uint16_t GPIO_Pin)
{
	if(GPIO_Pin == GPIO_PIN_4) //判断是这样引脚产生中断
	{
		HAL_GPIO_TogglePin(GPIOE,GPIO_PIN_5); //翻转电平
	}		
}

编译烧录复位,这样按键就会控制LED灯的亮灭。

  • 1
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
STM32L476RGT6芯片上,使用mbed进行断处理相对比较简单。 首先,在mbed定义一个Ticker对象,这个对象可以定时调用一个函数,我们可以在这个函数实现断处理的逻辑。例如: ``` #include "mbed.h" Ticker ticker; void interrupt_handler() { // 处理断逻辑 } int main() { ticker.attach(&interrupt_handler, 1.0); // 每秒调用一次 interrupt_handler 函数 while(1) { // 主循环代码 } } ``` 在上面的代码,我们定义了一个Ticker对象,调用了它的attach函数来注册一个断处理函数interrupt_handler。这个函数会每秒被调用一次。 接下来,我们需要在interrupt_handler函数实现具体的断处理逻辑。在该函数,我们可以使用printf_STM32L476R函数输出调试信息。例如: ``` #include "mbed.h" #include "mbed_trace.h" Ticker ticker; void interrupt_handler() { printf_STM32L476R("Interrupt occurred\n"); } int main() { mbed_trace_init(); // 初始化mbed trace ticker.attach(&interrupt_handler, 1.0); // 每秒调用一次 interrupt_handler 函数 while(1) { // 主循环代码 } } ``` 在上面的代码,我们调用了mbed_trace_init函数来初始化mbed trace,在interrupt_handler函数使用printf_STM32L476R函数输出调试信息。注意,printf_STM32L476R函数的使用与标准库的printf函数类似,但它会将输出信息重定向到调试串口。 当然,除了Ticker对象,mbed还提供了其他的对象用于处理不同类型的断。例如,InterruptIn对象可以用于处理外部中断,Serial对象可以用于处理串口断等等。具体使用方法可以参考mbed官方文档。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值