/**************************************************************************** * arch/arm/include/stm32f0/irq.h * * Copyright (C) 2017 Gregory Nutt. All rights reserved. * Author: Gregory Nutt * Alan Carvalho de Assis * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in * the documentation and/or other materials provided with the * distribution. * 3. Neither the name NuttX nor the names of its contributors may be * used to endorse or promote products derived from this software * without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE * POSSIBILITY OF SUCH DAMAGE. * ****************************************************************************/ /* This file should never be included directed but, rather, only indirectly * through nuttx/irq.h */ #ifndef __ARCH_ARM_INCLUDE_STM32F0_IRQ_H #define __ARCH_ARM_INCLUDE_STM32F0_IRQ_H /**************************************************************************** * Included Files ****************************************************************************/ #ifndef __ASSEMBLY__ # include #endif #include /**************************************************************************** * Pre-processor Definitions ****************************************************************************/ /* IRQ numbers. The IRQ number corresponds vector number and hence map * directly to bits in the NVIC. This does, however, waste several words of * memory in the IRQ to handle mapping tables. */ /* Common Processor Exceptions (vectors 0-15) */ #define STM32F0_IRQ_RESERVED (0) /* Reserved vector (only used with CONFIG_DEBUG_FEATURES) */ /* Vector 0: Reset stack pointer value */ /* Vector 1: Reset (not handler as an IRQ) */ #define STM32F0_IRQ_NMI (2) /* Vector 2: Non-Maskable Interrupt (NMI) */ #define STM32F0_IRQ_HARDFAULT (3) /* Vector 3: Hard fault */ /* Vectors 4-10: Reserved */ #define STM32F0_IRQ_SVCALL (11) /* Vector 11: SVC call */ /* Vector 12-13: Reserved */ #define STM32F0_IRQ_PENDSV (14) /* Vector 14: Pendable system service request */ #define STM32F0_IRQ_SYSTICK (15) /* Vector 15: System tick */ /* External interrupts (vectors >= 16) */ #define STM32F0_IRQ_EXTINT (16) /* Vector number of the first external interrupt */ #define STM32F0_IRQ_WWDG (16) /* Vector 16: WWDG */ #define STM32F0_IRQ_PVD_VDDIO2 (17) /* Vector 17: PVD_VDDIO2 */ #define STM32F0_IRQ_RTC (18) /* Vector 18: RTC */ #define STM32F0_IRQ_FLASH (19) /* Vector 19: FLASH */ #define STM32F0_IRQ_RCC_CRS (20) /* Vector 20: RCC and CRS */ #define STM32F0_IRQ_EXTI0_1 (21) /* Vector 21: EXTI0_1 */ #define STM32F0_IRQ_EXTI2_3 (22) /* Vector 22: EXTI2_3 */ #define STM32F0_IRQ_EXTI4_15 (23) /* Vector 23: EXTI4_15 */ #define STM32F0_IRQ_TSC (24) /* Vector 24: TSC */ #define STM32F0_IRQ_DMA_CH1 (25) /* Vector 25: DMA_CH1 */ #define STM32F0_IRQ_DMA_CH23 (26) /* Vector 26: DMA_CH2_3 and DMA2_CH1_2 */ #define STM32F0_IRQ_DMA_CH4567 (27) /* Vector 27: DMA_CH4_5_6_7 and DMA2_CH3_4_5 */ #define STM32F0_IRQ_ADC_COMP (28) /* Vector 28: ADC_COMP */ #define STM32F0_IRQ_TIM1_BRK (29) /* Vector 29: TIM1_BRK_UP_TRG_COM */ #define STM32F0_IRQ_TIM1_CC (30) /* Vector 30: TIM1_CC */ #define STM32F0_IRQ_TIM2 (31) /* Vector 31: TIM2 */ #define STM32F0_IRQ_TIM3 (32) /* Vector 32: TIM3 */ #define STM32F0_IRQ_TIM6_DAC (33) /* Vector 33: TIM6 and DAC */ #define STM32F0_IRQ_TIM7 (34) /* Vector 34: TIM7 */ #define STM32F0_IRQ_TIM14 (35) /* Vector 35: TIM14 */ #define STM32F0_IRQ_TIM15 (36) /* Vector 36: TIM15 */ #define STM32F0_IRQ_TIM16 (37) /* Vector 37: TIM16 */ #define STM32F0_IRQ_TIM17 (38) /* Vector 38: TIM17 */ #define STM32F0_IRQ_I2C1 (39) /* Vector 39: I2C1 */ #define STM32F0_IRQ_I2C2 (40) /* Vector 40: I2C2 */ #define STM32F0_IRQ_SPI1 (41) /* Vector 41: SPI1 */ #define STM32F0_IRQ_SPI2 (42) /* Vector 42: SPI2 */ #define STM32F0_IRQ_USART1 (43) /* Vector 43: USART1 */ #define STM32F0_IRQ_USART2 (44) /* Vector 44: USART2 */ #define STM32F0_IRQ_USART345678 (45) /* Vector 45: USART3_4_5_6_7_8 */ #define STM32F0_IRQ_CEC_CAN (46) /* Vector 46: HDMI CEC and CAN */ #define STM32F0_IRQ_USB (47) /* Vector 47: USB */ #define NR_IRQS (48) /* 32 interrupts plus 16 exceptions */ /**************************************************************************** * Public Types ****************************************************************************/ #ifndef __ASSEMBLY__ typedef void (*vic_vector_t)(uint32_t *regs); /**************************************************************************** * Inline functions ****************************************************************************/ /**************************************************************************** * Public Data ****************************************************************************/ /**************************************************************************** * Public Function Prototypes ****************************************************************************/ #ifdef __cplusplus extern "C" { #endif #ifdef __cplusplus } #endif #endif /* __ASSEMBLY__ */ #endif /* __ARCH_ARM_INCLUDE_STM32F0_IRQ_H */