STM32 之 EXTI

发布者:MagicGarden最新更新时间:2016-10-06 来源: eefocus关键字:STM32  EXTI 手机看文章 扫描二维码
随时随地手机看文章
按键的硬件结构有一点一定要注意,要在GPIO段上拉电阻,否则GPIO设置成浮空输入后,会造成端口电平不稳定,中断效果不理想。

另外EXTI的映射关系可以看下图,是和管脚号对应的,比较好记

  STM32 之 EXTI - wanghengzhi@126 - 代码豆子

  STM32 之 EXTI - wanghengzhi@126 - 代码豆子

(1)Main

C语言: Codee#14817
/*++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
+ 实验平台 : ST 官方三合一套件 
+ 硬件     : STM32F103C8T6
+ 开发平台 : IAR For ARM 5.40
+ 仿真器   : J-Link
+ 日期     : 2010-11-4
+ 频率     :HSE = 8MHz ,主频 = 72MHz
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/

#include "includes.h"

/*******************************************************************************
                             == Main 函数 == 
*******************************************************************************/
int main(void)

RCC_Configuration();    //配置系统时钟 
NVIC_Configuration();   //配置 NVIC 和 Vector Table 
SysTick_Config();       //配置SysTick的精确延时

GPIO_Configuration(); 
EXTI_Configuration();

LED1_HIGH ; LED2_HIGH ; LED3_HIGH ; LED4_HIGH ; // 初始化让灯全灭

while (1)
{
   
      if( KEY_UP == 0 )
      { LED1_LOW ;}
      if( KEY_DOWN == 0 )
      { LED2_LOW ;}
      if( KEY_LEFT == 0 )
      { LED3_LOW ;}
      if( KEY_RIGHT == 0 )
      { LED4_LOW ;}

}
}

(2)Unique_Device_ID.c

C语言: Codee#14816
#include "includes.h"

/*******************************************************************************
                             == 全局变量 == 
*******************************************************************************/
vu32 TimingDelay;                  // 精确延时在SysTick中断里用的计数变量

/*******************************************************************************
* Function Name : RCC_Configuration 配置时钟
* Description    : Configures the different system clocks.
* Input          : None
* Output         : None
* Return         : None
*******************************************************************************/
void RCC_Configuration(void)
{
ErrorStatus HSEStartUpStatus;

//将外设 RCC寄存器重设为缺省值
RCC_DeInit();

//设置外部高速晶振(HSE)
RCC_HSEConfig(RCC_HSE_ON);

//等待 HSE 起振 
HSEStartUpStatus = RCC_WaitForHSEStartUp();

if(HSEStartUpStatus == SUCCESS)
{
    //预取指缓存使能
    FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable);

     //设置代码延时值
    //FLASH_Latency_2 2 延时周期
    FLASH_SetLatency(FLASH_Latency_2);

    //设置 AHB 时钟(HCLK)
    //RCC_SYSCLK_Div1 AHB 时钟 = 系统时钟 
    RCC_HCLKConfig(RCC_SYSCLK_Div1);

     //设置高速 AHB 时钟(PCLK2)
    //RCC_HCLK_Div2 APB1 时钟 = HCLK / 2 
    RCC_PCLK2Config(RCC_HCLK_Div2);

    //设置低速 AHB 时钟(PCLK1)
    //RCC_HCLK_Div2 APB1 时钟 = HCLK / 2 
    RCC_PCLK1Config(RCC_HCLK_Div2);

    // PLLCLK = 8MHz * 9 = 72 MHz 
    //设置 PLL 时钟源及倍频系数
    RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9);

    //使能或者失能 PLL
    RCC_PLLCmd(ENABLE);

    //等待指定的 RCC 标志位设置成功 等待PLL初始化成功
    while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET)
    {
    }


    //设置系统时钟(SYSCLK) 设置PLL为系统时钟源
    RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);

    //等待PLL成功用作于系统时钟的时钟源
    // 0x00:HSI 作为系统时钟 
    // 0x04:HSE作为系统时钟 
    // 0x08:PLL作为系统时钟 
    while(RCC_GetSYSCLKSource() != 0x08)
    {
    }
}

//RCC_APB2PeriphClockCmd(RCC_APB2Periph_ALL, ENABLE);


//使能或者失能 APB2 外设时钟
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_AFIO, ENABLE);
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB, ENABLE);
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC, ENABLE);
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOD, ENABLE);

}

/*******************************************************************************
* Function Name : NVIC_Configuration 配置中断优先级
* Description    : Configures NVIC and Vector Table base location.
* Input          : None
* Output         : None
* Return         : None
*******************************************************************************/
void NVIC_Configuration(void)
{
NVIC_InitTypeDef NVIC_InitStructure_EXTI_LINE7; 
    
#ifdef VECT_TAB_RAM
/* Set the Vector Table base location at 0x20000000 */
NVIC_SetVectorTable(NVIC_VectTab_RAM, 0x0);
#else /* VECT_TAB_FLASH */
/* Set the Vector Table base location at 0x08000000 */
NVIC_SetVectorTable(NVIC_VectTab_FLASH, 0x0);
#endif

//===== NVIC_EXTI_PB7 =================================================== 
    /* Configure the NVIC Preemption Priority Bits */ 
NVIC_PriorityGroupConfig(NVIC_PriorityGroup_0);

    /* Enable the EXTI PB7 Interrupt */
NVIC_InitStructure_EXTI_LINE7.NVIC_IRQChannel = EXTI9_5_IRQChannel;   // 配置使能指定的IRQ(Interrupt ReQuest中断请求)通道
NVIC_InitStructure_EXTI_LINE7.NVIC_IRQChannelPreemptionPriority = 0; // 配置IRQ的 组 优先级
NVIC_InitStructure_EXTI_LINE7.NVIC_IRQChannelSubPriority = 0;         // 配置IRQ的 从 优先级
NVIC_InitStructure_EXTI_LINE7.NVIC_IRQChannelCmd = ENABLE;            // 配置IRQ 使能
NVIC_Init(&NVIC_InitStructure_EXTI_LINE7);                            // 初始化 UART1_IRQ

}

/*******************************************************************************
* Function Name : GPIO_Configuration 配置管教
* Description    : Configures the different GPIO ports.
* Input          : None
* Output         : None
* Return         : None
*******************************************************************************/
void GPIO_Configuration(void)
{
GPIO_InitTypeDef GPIO_InitStructure_LED_PORTB;
GPIO_InitTypeDef GPIO_InitStructure_KEY_PORTA;
GPIO_InitTypeDef GPIO_InitStructure_KEY_PORTB;
GPIO_InitTypeDef GPIO_InitStructure_KEY_PORTC;

//==== LED =======================================================
GPIO_InitStructure_LED_PORTB.GPIO_Pin = GPIO_Pin_12 | GPIO_Pin_13 | GPIO_Pin_14 | GPIO_Pin_15 ;
GPIO_InitStructure_LED_PORTB.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_InitStructure_LED_PORTB.GPIO_Mode = GPIO_Mode_Out_PP;   //推挽输出
GPIO_Init(GPIOB, &GPIO_InitStructure_LED_PORTB); 

//==== KEY =======================================================
GPIO_InitStructure_KEY_PORTA.GPIO_Pin = GPIO_Pin_0 ;
GPIO_InitStructure_KEY_PORTA.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_InitStructure_KEY_PORTA.GPIO_Mode = GPIO_Mode_IPU ;     //上拉输入
GPIO_Init(GPIOA, &GPIO_InitStructure_KEY_PORTA); 

GPIO_InitStructure_KEY_PORTB.GPIO_Pin = GPIO_Pin_7 ;
GPIO_InitStructure_KEY_PORTB.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_InitStructure_KEY_PORTB.GPIO_Mode = GPIO_Mode_IN_FLOATING;      //浮空输入 ,外部中断按键
GPIO_Init(GPIOB, &GPIO_InitStructure_KEY_PORTB); 

GPIO_InitStructure_KEY_PORTC.GPIO_Pin = GPIO_Pin_13 | GPIO_Pin_14 | GPIO_Pin_15 ;
GPIO_InitStructure_KEY_PORTC.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_InitStructure_KEY_PORTC.GPIO_Mode = GPIO_Mode_IPU;      //上拉输入
GPIO_Init(GPIOC, &GPIO_InitStructure_KEY_PORTC); 

}

/*******************************************************************************
* Function Name : EXTI_Configuration 配置外部中断管教
* Description    : Configures the EXTI 
* Input          : None
* Output         : None
* Return         : None
*******************************************************************************/
void EXTI_Configuration(void)
{
EXTI_InitTypeDef EXTI_InitStructure_EXTI_LINE7;

/* Connect EXTI Line7 to PB7 */
GPIO_EXTILineConfig(GPIO_PortSourceGPIOB, GPIO_PinSource7);                   // 配置 管脚PB7用作外部中断线路

/* Configure EXTI Line7 to generate an interrupt on falling edge */ 
EXTI_InitStructure_EXTI_LINE7.EXTI_Line = EXTI_Line7;                         //配置 使能或失能的外部线路
EXTI_InitStructure_EXTI_LINE7.EXTI_Mode = EXTI_Mode_Interrupt;                //配置 EXTI线路为中断请求 (或者是事件请求)
EXTI_InitStructure_EXTI_LINE7.EXTI_Trigger = EXTI_Trigger_Falling;            //配置 使能线路的触发边沿 -- 下降沿触发中断
EXTI_InitStructure_EXTI_LINE7.EXTI_LineCmd = ENABLE;                          //配置 状态为使能
EXTI_Init(&EXTI_InitStructure_EXTI_LINE7);                                    // 初始化外部中断线路7

/* Generate software interrupt: simulate a falling edge applied on EXTI line 7 */
EXTI_GenerateSWInterrupt(EXTI_Line7);                                         //线路7产生一个软件中断
}

/*******************************************************************************
* Function Name : SysTick_Config   SysTick设置
* Description    : Configures SysTick
* Input          : None
* Output         : None
* Return         : None
*******************************************************************************/
void SysTick_Config(void)
{
    /* Disable SysTick Counter */
    SysTick_CounterCmd(SysTick_Counter_Disable);

    /* Disable the SysTick Interrupt */
    SysTick_ITConfig(DISABLE);

    /* Configure HCLK clock as SysTick clock source */
    SysTick_CLKSourceConfig(SysTick_CLKSource_HCLK_Div8);

    /* SysTick interrupt each 1000 Hz with HCLK equal to 72MHz */
    SysTick_SetReload(9000);

    /* Enable the SysTick Interrupt */
    SysTick_ITConfig(ENABLE);

}

/*******************************************************************************
* Function Name : 精确延时函数
*******************************************************************************/
void Delay_Ms(u32 nTime)
{
/* Enable the SysTick Counter */
SysTick_CounterCmd(SysTick_Counter_Enable);

TimingDelay = nTime;

while(TimingDelay != 0);

/* Disable SysTick Counter */
SysTick_CounterCmd(SysTick_Counter_Disable);
/* Clear SysTick Counter */
SysTick_CounterCmd(SysTick_Counter_Clear);
}

(4)stm32f10x_it.c

C语言: Codee#14818
/* Includes ------------------------------------------------------------------*/
#include "includes.h"
//#include "stm32f10x_it.h"


// ... ...


/*******************************************************************************
* Function Name : EXTI9_5_IRQHandler
* Description    : This function handles External lines 9 to 5 interrupt request.
* Input          : None
* Output         : None
* Return         : None
*******************************************************************************/
// LINE : 407
void EXTI9_5_IRQHandler(void)
{           
       if(EXTI_GetITStatus(EXTI_Line7) == SET)                  // 读取中断状态
       {
               
              LED1_HIGH ; LED2_HIGH ; LED3_HIGH ; LED4_HIGH ;   // 灯全灭
              
              EXTI_ClearITPendingBit(EXTI_Line7);               // 清除标志位
       }
    
}

// ... ...

关键字:STM32  EXTI 引用地址:STM32 之 EXTI

上一篇:SDIO_FATFS_MDK 调试记录
下一篇:STM32 之 ISP下载

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

STM32-自学笔记(16.窗口看门狗,程序用到的库函数介绍)
1.RCC_APB1PeriphClockCmd 函数原型:void RCC_APB1PeriphClockCmd (u32 RCC_APB1Periph,FunctionalState NewState) 功能:使能或者失能APB1外设时钟 参数: RCC_APB1Periph:APB1的外设时钟 NewState:指定外设时钟的新状态,这个参数可以取ENABLE或者DISABLE 返回值:无 参数RCC_APB1Periph RCC_APB1Periph_TIM2 TIM2时钟 RCC_APB1Periph_I2C1 I2C1时钟 RCC_APB1Periph_TIM3 T
[单片机]
STM32复习笔记(十四)DAC数/模转换
一、STM32 DAC局限性: 只有大容量的STM32F10x才具有DAC功能, 所以正点原子所有STM32开发板均具有DAC功能。 STM32的DAC模块(数字/模拟转换模块)是12位数字输入,电压输出型的DAC。DAC可以配置为8位或12位模式,也可以与DMA控制器配合使用。DAC工作在12位模式时,数据可以设置成左对齐或右对齐。DAC模块有2个输出通道,每个通道都有单独的转换器。在双DAC模式下,2个通道可以独立地进行转换,也可以同时进行转换并同步地更新2个通道的输出。DAC可以通过引脚输入参考电压VREF+以获得更精确的转换结果。 二、STM32的DAC模块主要特点有: ① 2个DAC转换器:每个转换器对应1个输出通道
[单片机]
<font color='red'>STM32</font>复习笔记(十四)DAC数/模转换
STM32—4线SPI驱动SSD1306 OLED
一.OLED简介 OLED,即有机发光二极管(Organic Light-Emitting Diode),又称为有机电激光显示(OrganicElectroluminesence Display, OELD)。 OLED 由于同时具备自发光,不需背光源、对比度高、厚度薄、视角广、反应速度快、可用于挠曲性面板、使用温度范围广、构造及制程较简单等优异之特性,被认为是下一代的平面显示器新兴应用技术。 模块特点: 没有背光,需要通过写入指令来开启显示 尺寸小:0.96寸,分辨率高:128*64 提供多种通信接口:6800、8080、3线/4线SPI、IIC 供电3.3V 需要改变模块的通信接口时,只需要改变模块背后的电阻位置即可,如示
[单片机]
<font color='red'>STM32</font>—4线SPI驱动SSD1306 OLED
assert_param函数的意义
在STM32的固件库和提供的例程中,到处都可以见到assert_param()的使用。如果打开任何一个例程中的stm32f10x_conf.h文件,就可以看到实际上assert_param是一个宏定义; 在固件库中,它的作用就是检测传递给函数的参数是否是有效的参数。 所谓有效的参数是指满足规定范围的参数,比如某个参数的取值范围只能是小于3的正整数,如果给出的参数大于3,则这个assert_param()可以在运行的程序调用到这个函数时报告错误,使程序员可以及时发现错误,而不必等到程序运行结果的错误而大费周折。 这是一种常见的软件技术,可以在调试阶段帮助程序员快速地排除那些明显的错误。 它确实在程序的运行上牺牲了效率(但
[单片机]
STM32常见问题:低温下部分产品RTC不工作的问题探析
前言 客户反馈在批量生产阶段,发现部分产品的MCU的RTC在低温(0℃)下工作不正常,但是在常温下又是正常的,且其他正常的MCU的RTC在常温与低温下都是正常的。 问题跟进 通过与客户邮件沟通,了解到客户使用的MCU型号是STM32F030C6T6TR。在产品的主从结构中主要用作电源管理和时钟管理。通过客户的描述,似乎相同型号不同片子都存在较大的差异。 由于时间紧急,在了解到初步信息后拜访客户,针对客户认为有问题的MCU芯片做针对性试验。通过STM32CubMx生成测试工程,分别使用LSI(40K),LSE(32.768K),RTC工作时每秒通过LED1(PB5)取反一次(通过LED1灯是否闪烁来指示RTC是否工作正常),
[单片机]
<font color='red'>STM32</font>常见问题:低温下部分产品RTC不工作的问题探析
STM32----FLASH掉电保存动态平衡方案
stm32是支持对自身Flash(code区)进行读写的。所以,在某些需要掉电保存的场合,我们可以利用这一特性节省一个外部的Flash或者EEPROM,对数据进行保存。 但是,如果需要经常性的保存数据,就会对固定地址的Flash进行频繁的擦写,大大损耗Flash的寿命。在这种时候,就需要用到动态平衡的方法进行处理了。原理: 一、Flash擦写寿命 根据网上查阅的资料,单个NOR Flash地址的寿命,是受擦写次数的影响的。再具体一点,单个地址上的每个位,分别独立。比如0x08011000这个地址,共有8个bit,假设我一直令这个地址的数据循环为0x01与0x00。那么bit0位就会一直被擦写。循环几万次后bit
[单片机]
STM32实战三 C++ IO.cpp
这一章开始编写代码,主要是两个方面,一是C++,二是进行简单的IO封装。其它教程一般是用C语言,从按键或LED灯开始,比较直观,容易上手,但与实际应用有一定的区别,这里要做的是实用控制程序,开始就比较正规,C++是发展趋势,所以就从这里开始。 说是C++,实际是C和C++的混合程序,系统提供的都是C,新写的代码是C++,先从简单的IO开始,添加两个文件IO.cpp和IO.h代码如下: IO.h #ifndef __IO__ #define __IO__ extern C { // 按C语言编译,Keil5中的包含文件已经加入了C++兼容,不用再加这一段 #pragma diag_remark 368 //消除 wa
[单片机]
使用STM32点亮一颗LED实验
本次实验系统环境 Matlab版本: 2021b 系统环境 :Win10专业版 模型与原理图 simulink模型如图5.1所示,实验现象PB8以0.5S周期反转,PB9以1S周期翻转闪烁,本次实验电路原理如图5.2所示,实验所使用的下载器为STLINK 2V1版本,下载器自带一个串口,完整实验电路板如图5.3所示 图5.1 两颗LED闪烁simulink模型 图5.2 LED闪烁电路图 图5.3 实验开发板 基础模型介绍与分析 “Digital Write”模型用于控制I/O口作为普通输出用,双击模型可更改引脚编号,如图5.4所示其引脚对应STM32的PB8端口,例如想使用PA5引脚时,可通过将其改为“PA_
[单片机]
使用<font color='red'>STM32</font>点亮一颗LED实验
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

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

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

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