STM32外部中断与各通道对应关系

发布者:as233632621最新更新时间:2018-09-11 来源: eefocus关键字:STM32  外部中断  通道 手机看文章 扫描二维码
随时随地手机看文章

EXTI0_IRQn的值,其实就是EXTI0中断向量在中断向量表中的位置(STM32技术参考手册中断向量表position栏中的数值)

一:外部中断使用配置过程:

(1)配置时钟信号
(2)引脚属性
(3)NVIC配置

(4)外部中断配置

二:配置步骤

步骤如下: 
1.系统初始化,如系统时钟初始化,使之进入72MHZ主频;程序启动时已调用SystemInit()函数将主频改为72MHZ。
2.GPIO配置,务必注意打开GPIO时钟时,一定打开AFIO时钟。 在使用引脚的重映射功能和外部中断时需要使用AFIO时钟。
3.EXTI配置,在这里配置需要选择哪个引脚作为中断引脚。 

//定义一个EXTI初始化结构体
EXTI_InitTypeDef EXTI_InitStructure; 
//设置中断线:EXTIL_Line1为中断线1
EXTI_InitStructure.EXTI_Line = EXTI_Line1; 
//模式
EXTI_InitStructure.EXTI_Mode = EXTI_Mode_Interrupt; 


模式:这里有两个模式:(1)中断模式,(2)事件,具体区别如下:
“事件:是表示检测有一某件触发事件发生了。中断:有某个事件发生并产生中断,并跳转到对应的中断处理程序中。事件可以触发中断,也可以不触发中断有可能被更优先的中断屏蔽,事件不会事件本质上就是一个触发信号,是用来触发特定的外设模块或核心本身(唤醒).事件只是一个触发信号(脉冲),而中断则是一个固定的电平信号”


//设置中断触发方式(3种)

 EXTI_InitStructure.EXTI_Trigger = EXTI_Trigger_Falling;


 EXTI_Trigger_Falling:设置输入线路下降沿为中断请求
 EXTI_Trigger_Rising:设置输入线路上升沿为中断请求
  EXTI_Trigger_Rising_Falling:设置输入线路上升沿和下降沿为中断请求

 //定义选择中断线的新状态
 EXTI_InitStructure.EXTI_LineCmd=ENABLE;

 //根据EXTI_InitStructure中指定的参数初始化外设EXTI寄存器
 EXTI_Init(&EXTI_InitStructure);


 4.NVIC配置,这也是比单片机多出来的部分,我们必须把NVIC中对应的通道使能,并且设置优先级别。



 5.编写中断函数

 void EXTI2_IRQHandler(void)


三:STM32外部中断与各通道对应关系




例子 1:

exit.c文件
 
#include "exti.h"
#include "delay.h"
extern int isr_flag ;
 
void EXTIX_Init(void)
{
 
	EXTI_InitTypeDef EXTI_InitStructure;
	NVIC_InitTypeDef NVIC_InitStructure;
        GPIO_InitTypeDef GPIO_InitStructure;
 
 	//时钟配置
 	RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOE | RCC_APB2Periph_AFIO,ENABLE);
 
 	//IO配置
	GPIO_InitStructure.GPIO_Pin  = GPIO_Pin_0;
	GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPU; 
 	GPIO_Init(GPIOE, &GPIO_InitStructure);
	GPIO_SetBits(GPIOE,GPIO_Pin_0);	
 
	//EXTI
  	GPIO_EXTILineConfig(GPIO_PortSourceGPIOE,GPIO_PinSource0);
  	EXTI_InitStructure.EXTI_Line=EXTI_Line0;	
  	EXTI_InitStructure.EXTI_Mode = EXTI_Mode_Interrupt;	
  	EXTI_InitStructure.EXTI_Trigger = EXTI_Trigger_Falling;
  	EXTI_InitStructure.EXTI_LineCmd = ENABLE;
  	EXTI_Init(&EXTI_InitStructure);	 	
 
  	//NVIC
        NVIC_InitStructure.NVIC_IRQChannel = EXTI0_IRQn;			       
  	NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0x02;	
  	NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0x02;					
  	NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;								
  	NVIC_Init(&NVIC_InitStructure);
}
 
 
void EXTI0_IRQHandler(void)
{
	delay_ms(1);   
	if(EXTI_GetITStatus(EXTI_Line0)!=RESET)
	{
           isr_flag = 1;
	   EXTI_ClearITPendingBit(EXTI_Line0);  
	}	
}


例子2:

#include "exti.h"
#include "led.h"
#include "key.h"
#include "delay.h"
#include "usart.h"
#include "beep.h" 
//外部中断0服务程序
void EXTIX_Init(void)
{
 
    EXTI_InitTypeDef EXTI_InitStructure;
    NVIC_InitTypeDef NVIC_InitStructure;
    GPIO_InitTypeDef GPIO_InitStructure;
 
    //初始化KEY0-->GPIOA.13,KEY1-->GPIOA.15  上拉输入
    RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_GPIOE | RCC_APB2Periph_AFIO,ENABLE);//使能PORTA,PORTE时钟
 
//IO初始化
    GPIO_InitStructure.GPIO_Pin  = GPIO_Pin_2|GPIO_Pin_3|GPIO_Pin_4;    //PE2~4
    GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPU;                       //设置成上拉输入
    GPIO_Init(GPIOE, &GPIO_InitStructure);                              //初始化GPIOE2,3,4
    //初始化 WK_UP-->GPIOA.0   下拉输入
    GPIO_InitStructure.GPIO_Pin  = GPIO_Pin_0;
    GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPD;                       //PA0设置成输入,默认下拉   
    GPIO_Init(GPIOA, &GPIO_InitStructure);//初始化GPIOA.0
 
 
//EXTI
       //GPIOE.2 中断线以及中断初始化配置   下降沿触发
  	GPIO_EXTILineConfig(GPIO_PortSourceGPIOE,GPIO_PinSource2);
  	EXTI_InitStructure.EXTI_Line=EXTI_Line2;	               //KEY2
  	EXTI_InitStructure.EXTI_Mode = EXTI_Mode_Interrupt;	
  	EXTI_InitStructure.EXTI_Trigger = EXTI_Trigger_Falling;
  	EXTI_InitStructure.EXTI_LineCmd = ENABLE;
  	EXTI_Init(&EXTI_InitStructure);	 	                    //根据EXTI_InitStruct中指定的参数初始化外设EXTI寄存器
 
       //GPIOE.3	  中断线以及中断初始化配置 下降沿触发 //KEY1
  	GPIO_EXTILineConfig(GPIO_PortSourceGPIOE,GPIO_PinSource3);
  	EXTI_InitStructure.EXTI_Line=EXTI_Line3;
  	EXTI_Init(&EXTI_InitStructure);	  	                     //根据EXTI_InitStruct中指定的参数初始化外设EXTI寄存器
 
       //GPIOE.4	  中断线以及中断初始化配置  下降沿触发	    //KEY0
  	GPIO_EXTILineConfig(GPIO_PortSourceGPIOE,GPIO_PinSource4);
  	EXTI_InitStructure.EXTI_Line=EXTI_Line4;
  	EXTI_Init(&EXTI_InitStructure);	  	                     //根据EXTI_InitStruct中指定的参数初始化外设EXTI寄存器
 
 
       //GPIOA.0	  中断线以及中断初始化配置 上升沿触发 PA0  WK_UP
 	GPIO_EXTILineConfig(GPIO_PortSourceGPIOA,GPIO_PinSource0); 
 	EXTI_InitStructure.EXTI_Line=EXTI_Line0;
  	EXTI_InitStructure.EXTI_Trigger = EXTI_Trigger_Rising;
  	EXTI_Init(&EXTI_InitStructure);		                   //根据EXTI_InitStruct中指定的参数初始化外设EXTI寄存器
 
//NVIC
  	NVIC_InitStructure.NVIC_IRQChannel = EXTI0_IRQn;		//使能按键WK_UP所在的外部中断通道
  	NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0x02;	//抢占优先级2, 
  	NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0x03;		//子优先级3
  	NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;			//使能外部中断通道
  	NVIC_Init(&NVIC_InitStructure); 
 
        NVIC_InitStructure.NVIC_IRQChannel = EXTI2_IRQn;		//使能按键KEY2所在的外部中断通道
  	NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0x02;	//抢占优先级2, 
  	NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0x02;		//子优先级2
  	NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;			//使能外部中断通道
  	NVIC_Init(&NVIC_InitStructure);
 
 
  	NVIC_InitStructure.NVIC_IRQChannel = EXTI3_IRQn;		//使能按键KEY1所在的外部中断通道
  	NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0x02;	//抢占优先级2 
  	NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0x01;		//子优先级1 
  	NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;		        //使能外部中断通道
  	NVIC_Init(&NVIC_InitStructure);  	                        //根据NVIC_InitStruct中指定的参数初始化外设NVIC寄存器
 
	  NVIC_InitStructure.NVIC_IRQChannel = EXTI4_IRQn;		//使能按键KEY0所在的外部中断通道
  	NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0x02;	//抢占优先级2 
  	NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0x00;		//子优先级0 
  	NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;			//使能外部中断通道
  	NVIC_Init(&NVIC_InitStructure);  	                        //根据NVIC_InitStruct中指定的参数初始化外设NVIC寄存器
 
}
 
//外部中断0服务程序 
void EXTI0_IRQHandler(void)
{
	delay_ms(10);//消抖
	if(KEY3==1)	 	 //WK_UP按键
	{				 
		BEEP=!BEEP;	
	}
	EXTI_ClearITPendingBit(EXTI_Line0); //清除LINE0上的中断标志位  
}
 
//外部中断2服务程序
void EXTI2_IRQHandler(void)
{
	delay_ms(10);     //消抖
	if(KEY2==0)	  //按键KEY2
	{
		LED0=!LED0;
	}		 
	EXTI_ClearITPendingBit(EXTI_Line2);  //清除LINE2上的中断标志位  
}
//外部中断3服务程序
void EXTI3_IRQHandler(void)
{
	delay_ms(10);    //消抖
	if(KEY1==0)	 //按键KEY1
	{				 
		LED1=!LED1;
	}		 
	EXTI_ClearITPendingBit(EXTI_Line3);  //清除LINE3上的中断标志位  
}
 
void EXTI4_IRQHandler(void)
{
	delay_ms(10);     //消抖
	if(KEY0==0)	 //按键KEY0
	{
		LED0=!LED0;
		LED1=!LED1; 
	}		 
	EXTI_ClearITPendingBit(EXTI_Line4);  //清除LINE4上的中断标志位  
}


关键字:STM32  外部中断  通道 引用地址:STM32外部中断与各通道对应关系

上一篇:STM32延时函数的四种方法
下一篇:STM32中EXTI和NVIC的关系

推荐阅读最新更新时间:2024-03-16 16:13

示波器基础系列之十一 —— 如何用示波器测量4个以上通道
问题: 您好!我是XX研究院研究员XX。很感谢您的来信,我是检测方面的初学者,您的附件让我受益匪浅。我有个比较弱的问题想请教您:我们现场测量有超过8个量以上,现有的示波器似乎不能一台同时接入这么多量,那么我计划分别接不同的示波器,比如接4个,怎么样可以保证之间没有干扰或延迟呢?各个示波器之间是否需要共地连接呢? 非常期待您的指导,祝您身体健康,工作顺利! 回答: 首先需要确认您是需要同时测量8个以上参数还是要测量8种输入信号。如果是前者,只是要测量8个以上的参数,解决方案很简单:购买力科第四代示波器,可以同时测量12个参数。我上周发出邮件后得到几个别答复,下面这个回答比较专业和全面。
[测试测量]
CAN_总线_STM32(2)
过滤器的理解 STM32 参考手册中提到:bxCAN 控制器为应用程序提供了 28个位宽可变的、可配置的过滤器组(0~28))(103只有14个)每个过滤器组的位宽都可以独立配置。可以配置成 16 位或者 32 位。过滤器组还可配置为屏蔽位模式(标识符掩码)或标识符列表模式。 每个过滤器组x由2个32位寄存器,CAN_FxR1和 CAN_FxR2组成 先看一个过滤器组:如图 这里的 ID 并不是发送数据帧里面的ID,此ID非彼ID,硬件上属于不同的 register,这里的 ID 就是你需要去设置来达到你想要过滤接收某个数据 ID 的一串标识符,然后过滤器会根据你所设置的标识符 ID 来决定是不
[单片机]
CAN_总线_<font color='red'>STM32</font>(2)
STM32外部中断具体解释
一、基本概念 ARM Coetex-M3内核共支持256个中断,当中16个内部中断,240个外部中断和可编程的256级中断优先级的设置。STM32眼下支持的中断共84个(16个内部+68个外部),还有16级可编程的中断优先级的设置,仅使用中断优先级设置8bit中的高4位。 STM32可支持68个中断通道,已经固定分配给对应的外部设备,每一个中断通道都具备自己的中断优先级控制字节PRI_n(8位,可是STM32中仅仅使用4位,高4位有效),每4个通道的8位中断优先级控制字构成一个32位的优先级寄存器。68个通道的优先级控制字至少构成17个32位的优先级寄存器。 4bit的中断优先级能够分成2组,从高位看,前面定义的是抢占式优
[单片机]
STM32开发笔记4: STM32F407 UART的使用方法
STM32F4内嵌4个通用异步/同步收发器(USART1、USART2、USART3、USART6)和两个通用异步收发器(UART4和UART5)。本文讲解此6个串行口,在异步模式下的使用方法,如不加说明,以USART1为例。 可以按照下述步骤,对通用异步串行口进行设置。 1、打开config.h文件,对如下图所示的宏进行设置,0x0c表示将当前串行口UART1的波特率设为115200bps,无效验。 2、打开main.c文件,可以在其中断服务函数中,完成接收逻辑的代码编写,如下图所示。此代码表明,当串行口收到1个字节的数据后,将触发串行口中断,在中断服务程序中,将接收到的1字节数据取出,送u8_Ua
[单片机]
<font color='red'>STM32</font>开发笔记4: STM32F407 UART的使用方法
STM32中NVIC_SystemReset()函数的作用?什么时候用?
STM32软件复位有两种方式 (1)方式一:NVIC_SystemReset()函数用来复位STM32. 注意1:从SYSRESETREQ 被置为有效,到复位发生器执行复位命令,往往会有一个延时。在此延时期间,处理器仍然可以响应中断请求。但我们的本意往往是要让此次执行到此为止,不要再做任何其它事情了。所以,最好在发出复位请求前,先把FAULTMASK置位。需要加上这句:__set_FAULTMASK(1);意思是关闭所有中断的意思,目的是在执行NVIC_SystemReset()复位函数过程中不被中断所打断。两个函数执行后系统复位重新执行代码,包括之前所配置好的外设寄存器也都回到复位状态。如下: __set_FAULTMASK
[单片机]
STM32 SDIO详解
1、SDIO简介 SDIO,全称:Secure Digital Input and Output,即安全数字输入输出接口。它是在SD卡接口的基础上发展而来,它可以兼容之前的SD卡,并可以连接SDIO接口设备,比如:蓝牙、WIFI、照相机等。 SDIO和SD卡规范间的一个重要区别是增加了低速标准。低速卡的目标应用是以最小的硬件开支支持低速I/O能力。低速卡支持类似调制解调器、条码扫描仪和GPS接收器等应用。 STM32的SDIO控制器支持多媒体卡(MMC卡)、SD存储卡、SDI/O卡和CE-ATA设备。 SDIO框图 复位后SDIO_D0用于数据传输。初始化后主机可以改变数据总线的宽度(通过ACMD6命令设置) 如果一个多媒体卡
[单片机]
<font color='red'>STM32</font> SDIO详解
USE_STDPERIPH_DRIVER, STM32F10X_HD说明
如果在STM32工程编译时没有添加USE_STDPERIPH_DRIVER, STM32F10X_HD时会出现如下错误: ..\library\cortex_m3\stm32f10x.h(96): error: #35: #error directive: Please select first the target STM32F10x device used in your application (in stm32f10x.h file) 这时候我们需要在 Target Options 中的 C/C++ 选项卡中添加USE_STDPERIPH_DRIVER、STM32F10X_HD。这样才能使编顺利通过。 那么这个错
[单片机]
USE_STDPERIPH_DRIVER, STM32F10X_HD说明
基于STM32的远程温控系统设计
温度控制是工业控制的主要对象之一,常用的温控数学模型是一阶惯性加上纯滞后环节,但其随着加热对象和环境条件的不同,会存在着较大的差异。因为温控对象这种较为普遍的含有纯滞后环节的特点,容易引起系统超调和持续的振荡,温度控制对象的参数会发生幅度较大的变化。因此无法采用传统的控制方法(如常规的PID控制)对温度进行有效的控制,而智能控制不需要对象的精确数学模型就可以对系统实施控制 。温度控制多采用由单片机系统来实现温度控制,其缺点是远程控制系统复杂,可靠性差,特别是当控制点较多、距离较远时,采取总线方式的通讯出错概率较高,影响到温度的控制精度 。   目前,多家厂商(如日本导电、岛通)均推出精度可达0.1级的基于PID算法的智能型温控仪
[工业控制]
基于<font color='red'>STM32</font>的远程温控系统设计
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved