2017-05-22 15:08:04 +02:00
|
|
|
/**
|
|
|
|
******************************************************************************
|
|
|
|
* @addtogroup PIOS PIOS Core hardware abstraction layer
|
|
|
|
* @{
|
|
|
|
*
|
2017-05-26 01:06:31 +02:00
|
|
|
* @file vectors_stm32f30x.c
|
|
|
|
* @author The LibrePilot Project, http://www.librepilot.org Copyright (C) 2017.
|
|
|
|
* Tau Labs, http://taulabs.org, Copyright (C) 2012-2013
|
|
|
|
* The OpenPilot Team, http://www.openpilot.org Copyright (C) 2012.
|
|
|
|
* @brief C based vectors for F3
|
2017-05-22 15:08:04 +02:00
|
|
|
* @see The GNU Public License (GPL) Version 3
|
|
|
|
*
|
|
|
|
*****************************************************************************/
|
|
|
|
/*
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation; either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful, but
|
|
|
|
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
|
|
|
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
|
|
* for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License along
|
|
|
|
* with this program; if not, write to the Free Software Foundation, Inc.,
|
|
|
|
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
|
|
*/
|
|
|
|
|
|
|
|
/** interrupt handler */
|
|
|
|
typedef void (vector)(void);
|
|
|
|
|
|
|
|
/** default interrupt handler */
|
|
|
|
static void default_io_handler(void)
|
|
|
|
{
|
2017-05-22 16:53:12 +02:00
|
|
|
asm volatile ("BKPT #01");
|
2017-05-22 15:08:04 +02:00
|
|
|
for (;;) {
|
|
|
|
;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/** prototypes an interrupt handler */
|
|
|
|
#define HANDLER(_name) extern vector _name __attribute__((weak, alias("default_io_handler")))
|
|
|
|
|
|
|
|
HANDLER(Reserved_IRQHandler); // Reserved
|
|
|
|
HANDLER(WWDG_IRQHandler); // Window WatchDog
|
|
|
|
HANDLER(PVD_IRQHandler); // PVD through EXTI Line detection
|
|
|
|
HANDLER(TAMP_STAMP_IRQHandler); // Tamper and TimeStamps through the EXTI line
|
|
|
|
HANDLER(RTC_WKUP_IRQHandler); // RTC Wakeup through the EXTI line
|
|
|
|
HANDLER(FLASH_IRQHandler); // FLASH
|
|
|
|
HANDLER(RCC_IRQHandler); // RCC
|
|
|
|
HANDLER(EXTI0_IRQHandler); // EXTI Line0
|
|
|
|
HANDLER(EXTI1_IRQHandler); // EXTI Line1
|
|
|
|
HANDLER(EXTI2_TS_IRQHandler); // EXTI Line2 and Touch Sense Interrupt
|
|
|
|
HANDLER(EXTI3_IRQHandler); // EXTI Line3
|
|
|
|
HANDLER(EXTI4_IRQHandler); // EXTI Line4
|
|
|
|
HANDLER(DMA1_Channel1_IRQHandler); // DMA1 Channel 1
|
|
|
|
HANDLER(DMA1_Channel2_IRQHandler); // DMA1 Channel 2
|
|
|
|
HANDLER(DMA1_Channel3_IRQHandler); // DMA1 Channel 3
|
|
|
|
HANDLER(DMA1_Channel4_IRQHandler); // DMA1 Channel 4
|
|
|
|
HANDLER(DMA1_Channel5_IRQHandler); // DMA1 Channel 5
|
|
|
|
HANDLER(DMA1_Channel6_IRQHandler); // DMA1 Channel 6
|
|
|
|
HANDLER(DMA1_Channel7_IRQHandler); // DMA1 Channel 7
|
|
|
|
HANDLER(ADC1_2_IRQHandler); // ADC1 and ADC2
|
|
|
|
HANDLER(USB_HP_CAN1_TX_IRQHandler); // USB Device High Priority or CAN1 TX
|
|
|
|
HANDLER(USB_LP_CAN1_RX0_IRQHandler); // USB Device Low Priority or CAN1 RX0
|
|
|
|
HANDLER(CAN1_RX1_IRQHandler); // CAN1 RX1
|
|
|
|
HANDLER(CAN1_SCE_IRQHandler); // CAN1 SCE
|
|
|
|
HANDLER(EXTI9_5_IRQHandler); // External Line[9:5]s
|
|
|
|
HANDLER(TIM1_BRK_TIM15_IRQHandler); // TIM1 Break and TIM15
|
|
|
|
HANDLER(TIM1_UP_TIM16_IRQHandler); // TIM1 Update and TIM16
|
|
|
|
HANDLER(TIM1_TRG_COM_TIM17_IRQHandler); // TIM1 Trigger and Commutation and TIM17
|
|
|
|
HANDLER(TIM1_CC_IRQHandler); // TIM1 Capture Compare
|
|
|
|
HANDLER(TIM2_IRQHandler); // TIM2
|
|
|
|
HANDLER(TIM3_IRQHandler); // TIM3
|
|
|
|
HANDLER(TIM4_IRQHandler); // TIM4
|
|
|
|
HANDLER(I2C1_EV_EXTI23_IRQHandler); // I2C1 Event and EXTI23
|
|
|
|
HANDLER(I2C1_ER_IRQHandler); // I2C1 Error
|
|
|
|
HANDLER(I2C2_EV_EXTI24_IRQHandler); // I2C2 Event and EXTI24
|
|
|
|
HANDLER(I2C2_ER_IRQHandler); // I2C2 Error
|
|
|
|
HANDLER(SPI1_IRQHandler); // SPI1
|
|
|
|
HANDLER(SPI2_IRQHandler); // SPI2
|
|
|
|
HANDLER(USART1_EXTI25_IRQHandler); // USART1 and EXTI25
|
|
|
|
HANDLER(USART2_EXTI26_IRQHandler); // USART2 and EXTI26
|
|
|
|
HANDLER(USART3_EXTI28_IRQHandler); // USART3 and EXTI28
|
|
|
|
HANDLER(EXTI15_10_IRQHandler); // External Line[15:10]s
|
|
|
|
HANDLER(RTC_Alarm_IRQHandler); // RTC Alarm (A and B) through EXTI Line
|
|
|
|
HANDLER(USB_WKUP_IRQHandler); // USB FS Wakeup through EXTI line
|
|
|
|
HANDLER(TIM8_BRK_IRQHandler); // TIM8 Break
|
|
|
|
HANDLER(TIM8_UP_IRQHandler); // TIM8 Update
|
|
|
|
HANDLER(TIM8_TRG_COM_IRQHandler); // TIM8 Trigger and Commutation
|
|
|
|
HANDLER(TIM8_CC_IRQHandler); // TIM8 Capture Compare
|
|
|
|
HANDLER(ADC3_IRQHandler); // ADC3
|
|
|
|
HANDLER(SPI3_IRQHandler); // SPI3
|
|
|
|
HANDLER(UART4_EXTI34_IRQHandler); // UART4 and EXTI34
|
|
|
|
HANDLER(UART5_EXTI35_IRQHandler); // UART5 and EXTI35
|
|
|
|
HANDLER(TIM6_DAC_IRQHandler); // TIM6 and DAC1&2 underrun errors
|
|
|
|
HANDLER(TIM7_IRQHandler); // TIM7
|
|
|
|
HANDLER(DMA2_Channel1_IRQHandler); // DMA2 Channel 1
|
|
|
|
HANDLER(DMA2_Channel2_IRQHandler); // DMA2 Channel 2
|
|
|
|
HANDLER(DMA2_Channel3_IRQHandler); // DMA2 Channel 3
|
|
|
|
HANDLER(DMA2_Channel4_IRQHandler); // DMA2 Channel 4
|
|
|
|
HANDLER(DMA2_Channel5_IRQHandler); // DMA2 Channel 5
|
|
|
|
HANDLER(ADC4_IRQHandler); // ADC4
|
|
|
|
HANDLER(COMP1_2_3_IRQHandler); // COMP1, COMP2 and COMP3
|
|
|
|
HANDLER(COMP4_5_6_IRQHandler); // COMP4, COMP5 and COMP6
|
|
|
|
HANDLER(COMP7_IRQHandler); // COMP7
|
|
|
|
HANDLER(USB_HP_IRQHandler); // USB High Priority remap
|
|
|
|
HANDLER(USB_LP_IRQHandler); // USB Low Priority remap
|
|
|
|
HANDLER(USB_WKUP_RMP_IRQHandler); // USB Wakup remap
|
|
|
|
HANDLER(FPU_IRQHandler); // FPU
|
|
|
|
|
2017-04-20 10:51:14 +02:00
|
|
|
#if defined(STM32F303xD) || defined(STM32F303xE)
|
2017-05-22 15:08:04 +02:00
|
|
|
HANDLER(FMC_IRQHandler);
|
|
|
|
HANDLER(I2C3_EV_IRQHandler);
|
|
|
|
HANDLER(I2C3_ER_IRQHandler);
|
|
|
|
HANDLER(TIM20_BRK_IRQHandler);
|
|
|
|
HANDLER(TIM20_UP_IRQHandler);
|
|
|
|
HANDLER(TIM20_TRG_COM_IRQHandler);
|
|
|
|
HANDLER(TIM20_CC_IRQHandler);
|
|
|
|
HANDLER(SPI4_IRQHandler);
|
2017-04-20 10:51:14 +02:00
|
|
|
#endif /* defined(STM32F303xD) || defined(STM32F303xE) */
|
2017-05-22 15:08:04 +02:00
|
|
|
|
|
|
|
/** stm32f30x interrupt vector table */
|
|
|
|
vector *io_vectors[] __attribute__((section(".io_vectors"))) = {
|
|
|
|
WWDG_IRQHandler, // Window WatchDog
|
|
|
|
PVD_IRQHandler, // PVD through EXTI Line detection
|
|
|
|
TAMP_STAMP_IRQHandler, // Tamper and TimeStamps through the EXTI line
|
|
|
|
RTC_WKUP_IRQHandler, // RTC Wakeup through the EXTI line
|
|
|
|
FLASH_IRQHandler, // FLASH
|
|
|
|
RCC_IRQHandler, // RCC
|
|
|
|
EXTI0_IRQHandler, // EXTI Line0
|
|
|
|
EXTI1_IRQHandler, // EXTI Line1
|
|
|
|
EXTI2_TS_IRQHandler, // EXTI Line2 and Touch Sense Interrupt
|
|
|
|
EXTI3_IRQHandler, // EXTI Line3
|
|
|
|
EXTI4_IRQHandler, // EXTI Line4
|
|
|
|
DMA1_Channel1_IRQHandler, // DMA1 Channel 1
|
|
|
|
DMA1_Channel2_IRQHandler, // DMA1 Channel 2
|
|
|
|
DMA1_Channel3_IRQHandler, // DMA1 Channel 3
|
|
|
|
DMA1_Channel4_IRQHandler, // DMA1 Channel 4
|
|
|
|
DMA1_Channel5_IRQHandler, // DMA1 Channel 5
|
|
|
|
DMA1_Channel6_IRQHandler, // DMA1 Channel 6
|
|
|
|
DMA1_Channel7_IRQHandler, // DMA1 Channel 7
|
|
|
|
ADC1_2_IRQHandler, // ADC1 and ADC2
|
|
|
|
USB_HP_CAN1_TX_IRQHandler, // USB Device High Priority or CAN1 TX
|
|
|
|
USB_LP_CAN1_RX0_IRQHandler, // USB Device Low Priority or CAN1 RX0
|
|
|
|
CAN1_RX1_IRQHandler, // CAN1 RX1
|
|
|
|
CAN1_SCE_IRQHandler, // CAN1 SCE
|
|
|
|
EXTI9_5_IRQHandler, // External Line[9:5]s
|
|
|
|
TIM1_BRK_TIM15_IRQHandler, // TIM1 Break and TIM15
|
|
|
|
TIM1_UP_TIM16_IRQHandler, // TIM1 Update and TIM16
|
|
|
|
TIM1_TRG_COM_TIM17_IRQHandler, // TIM1 Trigger and Commutation and TIM17
|
|
|
|
TIM1_CC_IRQHandler, // TIM1 Capture Compare
|
|
|
|
TIM2_IRQHandler, // TIM2
|
|
|
|
TIM3_IRQHandler, // TIM3
|
|
|
|
TIM4_IRQHandler, // TIM4
|
|
|
|
I2C1_EV_EXTI23_IRQHandler, // I2C1 Event and EXTI23
|
|
|
|
I2C1_ER_IRQHandler, // I2C1 Error
|
|
|
|
I2C2_EV_EXTI24_IRQHandler, // I2C2 Event and EXTI24
|
|
|
|
I2C2_ER_IRQHandler, // I2C2 Error
|
|
|
|
SPI1_IRQHandler, // SPI1
|
|
|
|
SPI2_IRQHandler, // SPI2
|
|
|
|
USART1_EXTI25_IRQHandler, // USART1 and EXTI25
|
|
|
|
USART2_EXTI26_IRQHandler, // USART2 and EXTI26
|
|
|
|
USART3_EXTI28_IRQHandler, // USART3 and EXTI28
|
|
|
|
EXTI15_10_IRQHandler, // External Line[15:10]s
|
|
|
|
RTC_Alarm_IRQHandler, // RTC Alarm (A and B) through EXTI Line
|
|
|
|
USB_WKUP_IRQHandler, // USB FS Wakeup through EXTI line
|
|
|
|
TIM8_BRK_IRQHandler, // TIM8 Break
|
|
|
|
TIM8_UP_IRQHandler, // TIM8 Update
|
|
|
|
TIM8_TRG_COM_IRQHandler, // TIM8 Trigger and Commutation
|
|
|
|
TIM8_CC_IRQHandler, // TIM8 Capture Compare
|
|
|
|
ADC3_IRQHandler, // ADC3
|
2017-04-20 10:51:14 +02:00
|
|
|
#if defined(STM32F303xD) || defined(STM32F303xE)
|
2017-05-22 16:53:12 +02:00
|
|
|
FMC_IRQHandler, // FMC_IRQHandler (Available in STM32F303xD/E only)
|
2017-04-20 10:51:14 +02:00
|
|
|
#else
|
2017-05-22 15:08:04 +02:00
|
|
|
Reserved_IRQHandler, // reserved
|
2017-04-20 10:51:14 +02:00
|
|
|
#endif
|
2017-05-22 15:08:04 +02:00
|
|
|
Reserved_IRQHandler, // reserved
|
|
|
|
Reserved_IRQHandler, // reserved
|
|
|
|
SPI3_IRQHandler, // SPI3
|
|
|
|
UART4_EXTI34_IRQHandler, // UART4 and EXTI34
|
|
|
|
UART5_EXTI35_IRQHandler, // UART5 and EXTI35
|
|
|
|
TIM6_DAC_IRQHandler, // TIM6 and DAC1&2 underrun errors
|
|
|
|
TIM7_IRQHandler, // TIM7
|
|
|
|
DMA2_Channel1_IRQHandler, // DMA2 Channel 1
|
|
|
|
DMA2_Channel2_IRQHandler, // DMA2 Channel 2
|
|
|
|
DMA2_Channel3_IRQHandler, // DMA2 Channel 3
|
|
|
|
DMA2_Channel4_IRQHandler, // DMA2 Channel 4
|
|
|
|
DMA2_Channel5_IRQHandler, // DMA2 Channel 5
|
|
|
|
ADC4_IRQHandler, // ADC4
|
|
|
|
Reserved_IRQHandler, // reserved
|
|
|
|
Reserved_IRQHandler, // reserved
|
|
|
|
COMP1_2_3_IRQHandler, // COMP1, COMP2 and COMP3
|
|
|
|
COMP4_5_6_IRQHandler, // COMP4, COMP5 and COMP6
|
|
|
|
COMP7_IRQHandler, // COMP7
|
|
|
|
Reserved_IRQHandler, // reserved
|
|
|
|
Reserved_IRQHandler, // reserved
|
|
|
|
Reserved_IRQHandler, // reserved
|
|
|
|
Reserved_IRQHandler, // reserved
|
|
|
|
Reserved_IRQHandler, // reserved
|
2017-04-20 10:51:14 +02:00
|
|
|
#if defined(STM32F303xD) || defined(STM32F303xE)
|
|
|
|
I2C3_EV_IRQHandler, /*!< I2C3 event interrupt */
|
|
|
|
I2C3_ER_IRQHandler, /*!< I2C3 error interrupt */
|
|
|
|
#else
|
2017-05-22 15:08:04 +02:00
|
|
|
Reserved_IRQHandler, // reserved
|
|
|
|
Reserved_IRQHandler, // reserved
|
2017-04-20 10:51:14 +02:00
|
|
|
#endif
|
2017-05-22 15:08:04 +02:00
|
|
|
USB_HP_IRQHandler, // USB High Priority remap
|
|
|
|
USB_LP_IRQHandler, // USB Low Priority remap
|
|
|
|
USB_WKUP_RMP_IRQHandler, // USB Wakup remap
|
2017-04-20 10:51:14 +02:00
|
|
|
#if defined(STM32F303xD) || defined(STM32F303xE)
|
|
|
|
TIM20_BRK_IRQHandler, /*!< TIM20 Break Interrupt */
|
|
|
|
TIM20_UP_IRQHandler, /*!< TIM20 Update Interrupt */
|
|
|
|
TIM20_TRG_COM_IRQHandler, /*!< TIM20 Trigger and Commutation Interrupt */
|
|
|
|
TIM20_CC_IRQHandler, /*!< TIM20 Capture Compare Interrupt */
|
|
|
|
#else
|
2017-05-22 15:08:04 +02:00
|
|
|
Reserved_IRQHandler, // reserved
|
|
|
|
Reserved_IRQHandler, // reserved
|
|
|
|
Reserved_IRQHandler, // reserved
|
|
|
|
Reserved_IRQHandler, // reserved
|
2017-04-20 10:51:14 +02:00
|
|
|
#endif
|
2017-05-22 15:08:04 +02:00
|
|
|
FPU_IRQHandler, // FPU
|
2017-04-20 10:51:14 +02:00
|
|
|
#if defined(STM32F303xD) || defined(STM32F303xE)
|
2017-05-22 15:08:04 +02:00
|
|
|
Reserved_IRQHandler,
|
|
|
|
Reserved_IRQHandler,
|
2017-04-20 10:51:14 +02:00
|
|
|
SPI4_IRQHandler /*!< SPI4 global Interrupt */
|
|
|
|
#endif
|
2017-05-22 15:08:04 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @}
|
|
|
|
*/
|