STM32F4X之中断二

一、外部中断

外部中断:外部中断的中断是相对于外部中断控制器(EXTI)来说,如下图所示:

EXTI掌管着23根中断线,具体分布图下:

16根连接GPIO口,如下图:

所有的0口连接到中断线0,所有的1口连接到中断线1,以此类推。
具体的哪个IO口连接到相应的中断线,通过寄存器:SYSCFG_EXTICRx决定(x = 1~4)。
其余7根呢??
另外七根 EXTI 线连接方式如下:
● EXTI 线 16 连接到 PVD 输出
● EXTI 线 17 连接到 RTC 闹钟事件
● EXTI 线 18 连接到 USB OTG FS 唤醒事件
● EXTI 线 19 连接到以太网唤醒事件
● EXTI 线 20 连接到 USB OTG HS(在 FS 中配置)唤醒事件
● EXTI 线 21 连接到 RTC 入侵和时间戳事件
● EXTI 线 22 连接到 RTC 唤醒事件 
上面7根来自片内外设
外部中断框图分析
下图为外部中断控制器框架结构,上面讲的外部中断线上的每个中断源都会经过这样的一个结构。

框图分成了两个部分,红色代表产生的是中断,绿色代表产生的是事件。
补充:
中断:当一定的条件满足后(比如串口接收到数据)一定会进入中断服务函数。
事件:当一定的条件满足后(比如串口接收到数据)自动触发硬件工作。例如:将某一个寄存器的某一个位置位1或将某一个位清成0,接收数据标志位置1等。
相同点:中断与事件的产生条件一致。
不同点:中断过程需要CPU参与,事件不需要CPU参与。
(1)中断(重点掌握)
编号①代表外部中断线(外部中断的信号来源),外部中断线一共有23根,其中16根来源为GPIO口,另外7根来源为片上外设。需要从这23根中选择其中一个作为输入线。
编号②是边沿检测电路,这个边沿检测电路的信号来源来自外部中断线,通过对上升沿触发选择寄存器和下降沿触发选择寄存器的配置来决定这个边沿检测电路检测哪种边沿信号(上升沿、下降沿、双边沿)。当编号①输入了对应的边沿信号时,边沿电测电路就会输出有效信号‘1’,否则输出‘0’。
编号③是一个或门电路,这个或门电路有两个信号源,一个来自边沿检测电路的输出端,一个来自软件中断事件寄存器。当边沿检测电路输出有效信号‘1’或者软件中断事件寄存器对应位为1时,或门电路就输出有效信号‘1’。其实,这里可以直接通过设置软件中断事件寄存器来产生中断信号而不需要检测到对应边沿,这个就是所谓的软件中断。
编号④是一个与门电路,这个与门电路有两个信号源,一个来自或门电路的输出端,一个来自中断屏蔽寄存器。当或门电路输出有效信号‘1’同时中断屏蔽寄存器也输出有效信号‘1’时,这个与门电路才输出有效信号‘1’。其实就是可以通过对中断屏蔽寄存器的配置来决定是否响应该中断。(模块级中断使能)
编号⑤:当与门电路输出了有效信号‘1’到挂起请求寄存器时,挂起请求寄存器就会告诉NVIC当前产生了外部中断信号,请求NVIC响应。
注意:产生中断线路目的是把输入信号输入到NVIC,进一步会运行中断服务函数.

产生外部中断原理框图

外部中断配置流程:
SYSCFGEN时钟打开
选择对应的外部中断线SYSCFG_EXTICRx
配置边沿触发器
使能中断屏蔽寄存器(模块级中断使能)
配置NVIC控制器(核心级中断使能)
编写中断服务函数
事件
绿色部分是产生了事件
编号①②③与前面的分析一样。
编号⑥与编号④的原理一样,就是可以通过对事件屏蔽寄存器的配置决定是否可以产生事件。
编号⑦是脉冲发生器,当编号⑥电路输出有效信号‘1’时,可以触发脉冲发生器产生一个脉冲信号触发其他模块工作,不需要CPU参与。

注意:
当脉冲发生器输入端是一个有效信号1时就会产生一个脉冲;如果输入端是无效信号就不会输出脉冲。
脉冲信号,事件的最终的结果,这个脉冲信号可以给其他外设电路使用,比如定时器TIM、模拟数字转换器ADC等等。
相关寄存器

中断屏蔽寄存器

位 22:0 MRx:x 线上的中断屏蔽 (Interrupt mask on line x)

0:屏蔽来自 x 线的中断请求

1:开放来自 x 线的中断请求

事件屏蔽寄存器

位 22:0 MRx:x 线上的事件屏蔽 (Event mask on line x)

0:屏蔽来自 x 线的事件请求

1:开放来自 x 线的事件请求

上升沿触发选择寄存器

位 22:0 TRx:线 x 的上升沿触发事件配置位 (Rising trigger event configuration bit of line x)

0:禁止输入线上升沿触发(事件和中断)

1:允许输入线上升沿触发(事件和中断)

下降沿触发选择寄存器

位 22:0 TRx:线 x 的下降沿触发事件配置位 (Falling trigger event configuration bit of line x)

0:禁止输入线下降沿触发(事件和中断)

1:允许输入线下降沿触发(事件和中断)

软件中断事件寄存器

位 22:0 SWIERx:线 x 上的软件中断 (Software Interrupt on line x) (关闭软件中断通过写0操作)

当该位为“0”时,写“1”将设置 EXTI_PR 中相应的挂起位。

如果在 EXTI_IMR 和 EXTI_EMR 中允许产生该中断,则产生中断请求。

通过清除 EXTI_PR 的对应位(写入“1”),可以清除该位为“0”。

挂起寄存器

位 22:0 PRx:挂起位 (Pending bit) (产生中断的标志位,清中断标志位)

0:没有发生触发请求

1:发生了选择的触发请求

当在外部中断线上发生了选择的边沿事件,该位被置“1”。

在此位中写入“1”可以清除它, 也可以通过改变边沿检测的极性清除。

外部中断线中断源选择相关寄存器

SYSCFG 外部中断配置寄存器 1 (SYSCFG_EXTICR1)

位 15:0 EXTIx[3:0]:EXTI x 配置(x = 0 到 3)(EXTI x configuration (x = 0 to 3))

这些位通过软件写入,以选择 EXTIx 外部中断的源输入。

0000:PA[x] 引脚

0001:PB[x] 引脚

0010:PC[x] 引脚

0011:PD[x] 引脚

0100:PE[x] 引脚

0101:PF[C] 引脚

0110:PG[x] 引脚

0111:PH[x] 引脚

1000:PI[x] 引脚

注意高16位是保留位

例:需要将PB7作为外部中断的信号源。

SYSCFG_EXTICR2EXTI7位写入0001

SYSCFG 外部中断配置寄存器 2 (SYSCFG_EXTICR2)

SYSCFG 外部中断配置寄存器 3 (SYSCFG_EXTICR3)

SYSCFG 外部中断配置寄存器 4 (SYSCFG_EXTICR4)

RCC APB2 外设时钟使能寄存器 (RCC_APB2ENR)

位 14 SYSCFGEN:系统配置控制器时钟使能 (System configuration controller clock enable)

由软件置 1 和清零。

0:禁止系统配置控制器时钟

1:使能系统配置控制器时钟

软件设计

配置流程:

  • 按键能正常工作(PA0配置成浮空输入)
  • 输入线选择(把PA0映射到EXTI0中)
  • 设置边沿检测电路(上升沿检测)

④屏蔽软件中断,屏蔽事件

⑤模块级中断使能(配置中断屏蔽寄存器)

⑥配置NVIC(设置优先级、系统级中断使能)

⑦编写中断服务函数(清标志)

  1. 按键初始化
    • 开启GPIO的时钟
    • 配置GPIO的模式(普通输入)
    • 配置GPIO的无上下拉
  2. 初始化外部中断
    • 开启syscfg的时钟
    • 配置syscfg-exticr1寄存器对应的外部中断线。
    • 配置上升沿检测,关闭下降沿检测
    • 关闭软件中断事件
    • 关闭事件屏蔽
    • 开启中断屏蔽
    • 开启NVIC控制器
    • 清除一次标志位
  3. 编写中断服务函数
    • 判断是哪一个中断
    • 清中断标志
    • 功能代码

二、软件中断

软件中断简介

软件中断:完全不需要硬件的参与,通过代码(软件)就可以产生中断的方式。

软件中断框图

软件中断--相关寄存器

中断屏蔽寄存器 (EXTI_IMR)

软件中断事件寄存器 (EXTI_SWIER)

软件设计:

  1. 初始化外部中断
    • 开启中断屏蔽(模块级中断使能)
    • 开启NVIC控制器(核心级中断使能)
    • 初始化先关闭软件中断功能(在需要的是开启,标志位就会置一)
  2. 编写中断服务函数
    • 清中断标志
    • 具体代码
#include "exti.h"
//PE3->EXTI3
void EXTI_Init(void)
{/*1IO配置*/RCC->AHB1ENR |= 1<< 4;GPIOE->MODER &=~(0X3<< 6);//输入模式GPIOE->PUPDR &=~(0X3<< 6);//没有上下拉/*2选择外部中断线的输入*/RCC->APB2ENR |=1 << 14;//打开系统配置控制器的时钟(APB2)SYSCFG->EXTICR[0]|=4<< 12;//选择外部中断线3的中断来源是PE3/*3选择触发边沿*/EXTI->FTSR |=1<< 3;//外部中断线3设置为下降沿触发中断/*4允许中断产生*/EXTI->IMR |=1<< 3;//开放来自 x 线的中断请求/*5配置EXTI3 的NVIC*/NVIC_SetPriority(EXTI3_IRQn, NVIC_EncodePriority (7-2, 0, 2));NVIC_EnableIRQ (EXTI3_IRQn);//核心级中断使能}#include "stdio.h"
/*编写中断服务函数*/
void EXTI3_IRQHandler (void)
{//请标志是写入一清除标志EXTI->PR |=1<< 3;//清除一次标志/*功能代码*/printf("w外部中断线3的中断来了\r\n");
}void EXTI8_Init(void)
{/*4允许中断产生*/EXTI->IMR |=1<< 8;//开放来自 x 线的中断请求/*5配置EXTI8 的NVIC*/NVIC_SetPriority(EXTI9_5_IRQn, NVIC_EncodePriority (7-2, 3, 2));NVIC_EnableIRQ (EXTI9_5_IRQn);//核心级中断使能}/*编写中断服务函数*/
void EXTI9_5_IRQHandler (void)
{//请标志是写入一清除标志EXTI->PR |=1<< 8;//清除一次标志/*功能代码*/printf("外部中断线8的中断来了\r\n");
}
#ifndef EXTI_H
#define EXTI_H
#include "stm32f4xx.h"
#include "io_bit.h"
void EXTI_Init(void);
void EXTI8_Init(void);
#endif
/************************************
*  @brief :主函数
*  @param :none
*  @return:none
*  @note  程序入口
*************************************/
int main(void)
{NVIC_SetPriorityGrouping (7-2);//抢占2响应4-2u8 key = 0;//硬件初始化配置KEY_Init();EXTI_Init();EXTI8_Init();while(1)//让CPU卡主,单片机的程序架构{if(KeyScan()){EXTI->SWIER|=1<< 8;//软件产生一个中断}}	
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/145436.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Qt控件之QToolBox】介绍及使用

概述 QToolBox类提供了一个列式的带有选项卡的小部件条目。工具箱是一个小部件&#xff0c;以一个列式的选项卡显示在上方&#xff0c;并在当前选项卡下方显示当前的小部件条目。每个选项卡在选项卡列中有一个索引位置。选项卡的小部件条目是一个QWidget。 每个小部件条目都有…

内网穿透的应用-如何通过TortoiseSVN+内网穿透,实现公网提交文件到内网SVN服务器?

文章目录 前言1. TortoiseSVN 客户端下载安装2. 创建检出文件夹3. 创建与提交文件4. 公网访问测试 前言 TortoiseSVN是一个开源的版本控制系统&#xff0c;它与Apache Subversion&#xff08;SVN&#xff09;集成在一起&#xff0c;提供了一个用户友好的界面&#xff0c;方便用…

智慧公厕设备选型攻略,打造智能化便利生活体验

智慧公厕设备的选型对于打造智能化便利生活体验起着至关重要的作用。在不断提升城市品质的背景下&#xff0c;智慧公厕已成为城市建设中的一项重要内容。在选购智慧公厕设备时&#xff0c;我们需要考虑到不同版本的功能要求&#xff0c;确保公厕设备的质量和性能。本文以智慧公…

【广州华锐互动】关于物理力学的3D实验实操平台

在科学的广阔领域中&#xff0c;物理力学是一个至关重要的分支&#xff0c;它探索了物体在力作用下的运动规律。然而&#xff0c;传统的物理实验往往需要复杂的设备和大量的操作&#xff0c;这对于学生来说是一项巨大的挑战。为了解决这个问题&#xff0c;广州华锐互动开发了物…

基于斑马优化的BP神经网络(分类应用) - 附代码

基于斑马优化的BP神经网络&#xff08;分类应用&#xff09; - 附代码 文章目录 基于斑马优化的BP神经网络&#xff08;分类应用&#xff09; - 附代码1.鸢尾花iris数据介绍2.数据集整理3.斑马优化BP神经网络3.1 BP神经网络参数设置3.2 斑马算法应用 4.测试结果&#xff1a;5.M…

c语言进制的转换二进制转换10进制

c语言进制的转换之二进制转换10进制 c语言的进制的转换 c语言进制的转换之二进制转换10进制一、二进制转换10进制的方法二、10进制程序打印 一、二进制转换10进制的方法 二进制&#xff1a; 二进制逢二进一&#xff0c;所有的数组是0、1组成 十进制转二进制&#xff1a; 除二反…

【计算机网络】UDP的报文结构和注意事项

UDP&#xff08;User Datagram Protocol&#xff0c;用户数据报协议&#xff09;是一种无连接的协议&#xff0c;它在传输层中提供了简单、不可靠的数据传输服务。与TCP&#xff08;Transmission Control Protocol,传输控制协议&#xff09;不同&#xff0c;UDP不需要建立连接&…

什么是跨浏览器测试,为什么跨浏览器测试很重要?

一、什么是跨浏览器测试&#xff1f; 在跨浏览器测试中&#xff0c;对网站或移动应用程序进行测试以确保其“与浏览器无关”&#xff0c;即跨各种浏览器、设备、操作系统及其组合工作。因为每个浏览器解析文档对象模型(DOM)的方式都大不相同&#xff0c;所以输出对于被测Web应…

Jmeter性能 —— 事务控制器

统计性能测试结果一定会关注TPS&#xff0c;TPS表示&#xff1a;每秒处理事务数&#xff0c;JMeter默认每个事务对应一个请求。我们可以用逻辑控制器中的事务控制器将多个请求统计为一个事务。 1、添加事务控制器 2、事务控制器参数说明 Generate parent sample&#xff1a;如…

CUDA学习笔记(十四) Constant Memory

转载至https://www.cnblogs.com/1024incn/tag/CUDA/ CONSTANT MEMORY constant Memory对于device来说只读但是对于host是可读可写。constant Memory和global Memory一样都位于DRAM&#xff0c;并且有一个独立的on-chip cache&#xff0c;比直接从constant Memory读取要快得多…

stm32外部时钟为12MHZ,修改代码适配

代码默认是8MHZ的&#xff0c;修改2个地方&#xff1a; 第一个地方是这个文件的这里&#xff1a; 第二个地方是找到这个函数&#xff1a; 修改第二个地方的这里&#xff1a;

Linux下Jenkins自动化部署SpringBoot应用

Linux下Jenkins自动化部署SpringBoot应用 1、 Jenkins介绍 官方网址&#xff1a;https://www.jenkins.io/ 2、安装Jenkins 2.1 centos下命令行安装 访问官方&#xff0c;点击文档&#xff1a; 点击 Installing Jenkins&#xff1a; 点击 Linux&#xff1a; 选择 Red Hat/…