Arm STM32F0:EXTI4工作时,EXTI1/EXTI2上的中断未触发*迷茫*

Arm STM32F0:EXTI4工作时,EXTI1/EXTI2上的中断未触发*迷茫*,arm,interrupt,stm32,stm32f0,Arm,Interrupt,Stm32,Stm32f0,你能帮我一下,告诉我我做错了什么吗?EXTI1和EXTI2不会启动,而EXTI4却工作得完美无缺。这不是硬件问题。如果我切换引脚,新的EXTI4按钮将继续启动,而我切换的按钮不再启动 我已经彻底检查了所有的段,我不明白为什么EXTI0_1_IRQHandler不启动,而EXTI4_15_IRQHandler启动。请参阅下面我用于库的两个文件。我在OpenSTM32 IDE中使用SPL。“main.c”只调用 ENCODER_STM32_configureInterface(); 所以真的没有别

你能帮我一下,告诉我我做错了什么吗?EXTI1和EXTI2不会启动,而EXTI4却工作得完美无缺。这不是硬件问题。如果我切换引脚,新的EXTI4按钮将继续启动,而我切换的按钮不再启动

我已经彻底检查了所有的段,我不明白为什么EXTI0_1_IRQHandler不启动,而EXTI4_15_IRQHandler启动。请参阅下面我用于库的两个文件。我在OpenSTM32 IDE中使用SPL。“main.c”只调用

ENCODER_STM32_configureInterface();
所以真的没有别的事情发生了

// ENCODER_STM32 library: This library shall enable interfacing an encoder on an STM32F0 chip.

// GPIO Definitions
#define    ENCODER_GPIO_PORT       GPIOA
#define    ENCODER_GPIO_CLK_PIN    GPIO_Pin_1
#define    ENCODER_GPIO_DT_PIN     GPIO_Pin_2
#define    ENCODER_GPIO_SW_PIN     GPIO_Pin_4
#define    ENCODER_GPIO_PERIPH     RCC_AHBPeriph_GPIOA

// EXTI Definitions
#define    ENCODER_EXTI_PORTSRC    EXTI_PortSourceGPIOA
#define    ENCODER_EXTI_CLK_PINSRC EXTI_PinSource1
#define    ENCODER_EXTI_CLK_LINE   EXTI_Line1
#define    ENCODER_EXTI_DT_PINSRC  EXTI_PinSource2
#define    ENCODER_EXTI_DT_LINE    EXTI_Line2
#define    ENCODER_EXTI_SW_PINSRC  EXTI_PinSource4
#define    ENCODER_EXTI_SW_LINE    EXTI_Line4
#define    ENCODER_EXTI_PERIPH     RCC_APB2Periph_SYSCFG
#define    ENCODER_EXTI_MODE       EXTI_Mode_Interrupt
#define    ENCODER_EXTI_TRIGGER    EXTI_Trigger_Falling

// NVIC Definitions
#define    ENCODER_NVIC_CLK_CHA    EXTI0_1_IRQn
#define    ENCODER_NVIC_DT_CHA     EXTI2_3_IRQn
#define    ENCODER_NVIC_SW_CHA     EXTI4_15_IRQn
#define    ENCODER_NVIC_PRIORITY   0x03

// Variable Definitions

// Parameter Definitions

// Function Definitions

// Function Declarations
void ENCODER_STM32_configureInterface(void);
而且

#include "stm32f0xx.h"
#include "usart_stm32_console.h"
#include "encoder_stm32.h"

void ENCODER_STM32_configureInterface(void) {

    // Enabling Clocks
    RCC_AHBPeriphClockCmd(ENCODER_GPIO_PERIPH, ENABLE);
    RCC_APB2PeriphClockCmd(ENCODER_EXTI_PERIPH, ENABLE);

    // Configuring GPIO
    GPIO_InitTypeDef GPIO_InitStructure;
    GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
    GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
    GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP;
    GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN;
    GPIO_InitStructure.GPIO_Pin = ENCODER_GPIO_CLK_PIN | ENCODER_GPIO_DT_PIN | ENCODER_GPIO_SW_PIN;
    GPIO_Init(ENCODER_GPIO_PORT, &GPIO_InitStructure);

    // Configuring EXTI
    EXTI_InitTypeDef EXTI_InitStructure;
    EXTI_InitStructure.EXTI_Line = ENCODER_EXTI_CLK_LINE | ENCODER_EXTI_DT_LINE | ENCODER_EXTI_SW_LINE;
    EXTI_InitStructure.EXTI_Mode = ENCODER_EXTI_MODE;
    EXTI_InitStructure.EXTI_Trigger = ENCODER_EXTI_TRIGGER;
    EXTI_InitStructure.EXTI_LineCmd = ENABLE;
    SYSCFG_EXTILineConfig(ENCODER_EXTI_PORTSRC, ENCODER_EXTI_CLK_PINSRC);
    SYSCFG_EXTILineConfig(ENCODER_EXTI_PORTSRC, ENCODER_EXTI_DT_PINSRC);
    SYSCFG_EXTILineConfig(ENCODER_EXTI_PORTSRC, ENCODER_EXTI_SW_PINSRC);
    EXTI_Init(&EXTI_InitStructure);

    // Configuring NVIC
    NVIC_InitTypeDef NVIC_InitStructure;
    NVIC_InitStructure.NVIC_IRQChannel = ENCODER_NVIC_CLK_CHA | ENCODER_NVIC_DT_CHA | ENCODER_NVIC_SW_CHA;
    NVIC_InitStructure.NVIC_IRQChannelPriority = ENCODER_NVIC_PRIORITY;
    NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
    NVIC_Init(&NVIC_InitStructure);

}


void EXTI0_1_IRQHandler(void) {

    USART_STM32_sendToUSART("IRQ0_1 triggered");

    if(EXTI_GetITStatus(ENCODER_EXTI_CLK_LINE) != RESET) {
        USART_STM32_sendToUSART("CLK triggered");
        EXTI_ClearITPendingBit(ENCODER_EXTI_CLK_LINE);
    }

}


void EXTI2_3_IRQHandler(void) {

    USART_STM32_sendToUSART("IRQ2_3 triggered");

    if(EXTI_GetITStatus(ENCODER_EXTI_DT_LINE) != RESET) {
        USART_STM32_sendToUSART("DT triggered");
        EXTI_ClearITPendingBit(ENCODER_EXTI_DT_LINE);
    }

}


void EXTI4_15_IRQHandler(void) {

    USART_STM32_sendToUSART("IRQ4_15 triggered");

    if(EXTI_GetITStatus(ENCODER_EXTI_SW_LINE) != RESET) {
        USART_STM32_sendToUSART("SW triggered");
        EXTI_ClearITPendingBit(ENCODER_EXTI_SW_LINE);
    }

}
NVIC_Init()
一次只能使用一个中断
,因为
NVIC_InitStructure.NVIC_IRQChannel
不是位掩码,而是一个简单的标识符

查看标题中IRQ通道的定义:

  EXTI0_1_IRQn                = 5,      /*!< EXTI Line 0 and 1 Interrupts                            */
  EXTI2_3_IRQn                = 6,      /*!< EXTI Line 2 and 3 Interrupts                            */
  EXTI4_15_IRQn               = 7,      /*!< EXTI Line 4 to 15 Interrupts                            */
NVIC_Init()
一次只能使用一个中断
,因为
NVIC_InitStructure.NVIC_IRQChannel
不是位掩码,而是一个简单的标识符

查看标题中IRQ通道的定义:

  EXTI0_1_IRQn                = 5,      /*!< EXTI Line 0 and 1 Interrupts                            */
  EXTI2_3_IRQn                = 6,      /*!< EXTI Line 2 and 3 Interrupts                            */
  EXTI4_15_IRQn               = 7,      /*!< EXTI Line 4 to 15 Interrupts                            */

我已经通过CubeMX尝试了HAL,它正在工作,因此,如果激活了过多的组件,就不会出现问题。如上所述,SPL配置中的代码有问题,导致其无法工作。我就是看不出来。谁在乎已经死了5年的SPL。无论如何,在我个人看来,使用诸如HAL或SPL之类的“伟大”库编写如此简单的例程简直是荒谬可笑。我已经通过CubeMX尝试过HAL,并且它是有效的,因此在激活过多组件的情况下,它不可能是一个问题。如上所述,SPL配置中的代码有问题,导致其无法工作。我就是看不出来。谁在乎已经死了5年的SPL。无论如何,在我个人看来,使用HAL或SPL等“伟大”库编写如此简单的例程简直是荒谬可笑。谢谢!这真的帮助我理解了。很抱歉问了这么一个新手问题。我第一次使用STM平台。谢谢!这真的帮助我理解了。很抱歉问了这么一个新手问题。我第一次使用STM平台。