From dd61b09cb8f29c89dba992e5c77c91d935b9a84a Mon Sep 17 00:00:00 2001 From: Jerzy Kasenberg Date: Mon, 10 Jun 2024 13:14:58 +0200 Subject: [PATCH] hw/mcu/stm32f7: Use common startup code STM32F7 now uses common startup code for Cortex-M7 and autogenerated linker script. Flash cache initialization moved to hal_system_init.c to make system_stm32f7xx.c more like original ST file so future updates will be easier. Unused ld scripts remove NVIC_NUM_VECTOR corrected (probably value was from other MCU) Signed-off-by: Jerzy Kasenberg --- hw/mcu/stm/stm32f7xx/include/mcu/cmsis_nvic.h | 12 +- .../stm/stm32f7xx/include/mcu/mcu_vectors.h | 50 ++++ .../include/mcu/vectors/stm32f722xx_vectors.h | 139 +++++++++++ .../include/mcu/vectors/stm32f723xx_vectors.h | 139 +++++++++++ .../include/mcu/vectors/stm32f730xx_vectors.h | 139 +++++++++++ .../include/mcu/vectors/stm32f732xx_vectors.h | 139 +++++++++++ .../include/mcu/vectors/stm32f733xx_vectors.h | 139 +++++++++++ .../include/mcu/vectors/stm32f745xx_vectors.h | 133 +++++++++++ .../include/mcu/vectors/stm32f746xx_vectors.h | 133 +++++++++++ .../include/mcu/vectors/stm32f750xx_vectors.h | 133 +++++++++++ .../include/mcu/vectors/stm32f756xx_vectors.h | 133 +++++++++++ .../include/mcu/vectors/stm32f765xx_vectors.h | 145 ++++++++++++ .../include/mcu/vectors/stm32f767xx_vectors.h | 145 ++++++++++++ .../include/mcu/vectors/stm32f769xx_vectors.h | 145 ++++++++++++ .../include/mcu/vectors/stm32f777xx_vectors.h | 145 ++++++++++++ .../include/mcu/vectors/stm32f779xx_vectors.h | 145 ++++++++++++ hw/mcu/stm/stm32f7xx/src/clock_stm32f7xx.c | 8 - hw/mcu/stm/stm32f7xx/src/hal_system_init.c | 50 ++++ hw/mcu/stm/stm32f7xx/src/system_stm32f7xx.c | 9 - hw/mcu/stm/stm32f7xx/stm32f746.ld | 217 ------------------ hw/mcu/stm/stm32f7xx/stm32f767.ld | 217 ------------------ 21 files changed, 2056 insertions(+), 459 deletions(-) create mode 100644 hw/mcu/stm/stm32f7xx/include/mcu/mcu_vectors.h create mode 100644 hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f722xx_vectors.h create mode 100644 hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f723xx_vectors.h create mode 100644 hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f730xx_vectors.h create mode 100644 hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f732xx_vectors.h create mode 100644 hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f733xx_vectors.h create mode 100644 hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f745xx_vectors.h create mode 100644 hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f746xx_vectors.h create mode 100644 hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f750xx_vectors.h create mode 100644 hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f756xx_vectors.h create mode 100644 hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f765xx_vectors.h create mode 100644 hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f767xx_vectors.h create mode 100644 hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f769xx_vectors.h create mode 100644 hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f777xx_vectors.h create mode 100644 hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f779xx_vectors.h create mode 100644 hw/mcu/stm/stm32f7xx/src/hal_system_init.c delete mode 100644 hw/mcu/stm/stm32f7xx/stm32f746.ld delete mode 100644 hw/mcu/stm/stm32f7xx/stm32f767.ld diff --git a/hw/mcu/stm/stm32f7xx/include/mcu/cmsis_nvic.h b/hw/mcu/stm/stm32f7xx/include/mcu/cmsis_nvic.h index a9dea74a78..040d9cf16b 100644 --- a/hw/mcu/stm/stm32f7xx/include/mcu/cmsis_nvic.h +++ b/hw/mcu/stm/stm32f7xx/include/mcu/cmsis_nvic.h @@ -9,16 +9,12 @@ #include -#if defined(STM32F746xx) - #define MCU_NUM_PERIPH_VECTORS 98 -#elif defined(STM32F767xx) - #define MCU_NUM_PERIPH_VECTORS 110 -#else - #error "Number of peripheral vectors not defined for this MCU." -#endif +extern uint32_t __isr_vector_start[]; +extern uint32_t __isr_vector_end[]; +/* Extract number of vectors from .interrupt section size */ +#define NVIC_NUM_VECTORS (__isr_vector_end - __isr_vector_start) #define NVIC_USER_IRQ_OFFSET 16 -#define NVIC_NUM_VECTORS (16 + MCU_NUM_PERIPH_VECTORS) #include "stm32f7xx.h" diff --git a/hw/mcu/stm/stm32f7xx/include/mcu/mcu_vectors.h b/hw/mcu/stm/stm32f7xx/include/mcu/mcu_vectors.h new file mode 100644 index 0000000000..0002f237a0 --- /dev/null +++ b/hw/mcu/stm/stm32f7xx/include/mcu/mcu_vectors.h @@ -0,0 +1,50 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance + * with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +#if defined(STM32F722xx) +#include "vectors/stm32f722xx_vectors.h" +#elif defined(STM32F723xx) +#include "vectors/stm32f723xx_vectors.h" +#elif defined(STM32F732xx) +#include "vectors/stm32f732xx_vectors.h" +#elif defined(STM32F733xx) +#include "vectors/stm32f733xx_vectors.h" +#elif defined(STM32F756xx) +#include "vectors/stm32f756xx_vectors.h" +#elif defined(STM32F746xx) +#include "vectors/stm32f746xx_vectors.h" +#elif defined(STM32F745xx) +#include "vectors/stm32f745xx_vectors.h" +#elif defined(STM32F765xx) +#include "vectors/stm32f765xx_vectors.h" +#elif defined(STM32F767xx) +#include "vectors/stm32f767xx_vectors.h" +#elif defined(STM32F769xx) +#include "vectors/stm32f769xx_vectors.h" +#elif defined(STM32F777xx) +#include "vectors/stm32f777xx_vectors.h" +#elif defined(STM32F779xx) +#include "vectors/stm32f779xx_vectors.h" +#elif defined(STM32F730xx) +#include "vectors/stm32f730xx_vectors.h" +#elif defined(STM32F750xx) +#include "vectors/stm32f750xx_vectors.h" +#else +#error "Please select first the target STM32F7xx device used in your application" +#endif diff --git a/hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f722xx_vectors.h b/hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f722xx_vectors.h new file mode 100644 index 0000000000..542f431ce1 --- /dev/null +++ b/hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f722xx_vectors.h @@ -0,0 +1,139 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance + * with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +INT_VECTOR_STACK_TOP(__StackTop) +INT_VECTOR_RESET_HANDLER(Reset_Handler) +INT_VECTOR_NMI_HANDLER(NMI_Handler) +INT_VECTOR_HARDFAULT_HANDLER(HardFault_Handler) +INT_VECTOR_MEMMANAGE_HANDLER(MemManage_Handler) +INT_VECTOR_BUSFAULT_HANDLER(BusFault_Handler) +INT_VECTOR_USAGEFAULT_HANDLER(UsageFault_Handler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_SVC_HANDLER(SVC_Handler) +INT_VECTOR_DEBUGMON_HANDLER(DebugMon_Handler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_PENDSV_HANDLER(PendSV_Handler) +INT_VECTOR_SYSTICK_HANDLER(SysTick_Handler) +INT_VECTOR(WWDG_IRQHandler) +INT_VECTOR(PVD_IRQHandler) +INT_VECTOR(TAMP_STAMP_IRQHandler) +INT_VECTOR(RTC_WKUP_IRQHandler) +INT_VECTOR(FLASH_IRQHandler) +INT_VECTOR(RCC_IRQHandler) +INT_VECTOR(EXTI0_IRQHandler) +INT_VECTOR(EXTI1_IRQHandler) +INT_VECTOR(EXTI2_IRQHandler) +INT_VECTOR(EXTI3_IRQHandler) +INT_VECTOR(EXTI4_IRQHandler) +INT_VECTOR(DMA1_Stream0_IRQHandler) +INT_VECTOR(DMA1_Stream1_IRQHandler) +INT_VECTOR(DMA1_Stream2_IRQHandler) +INT_VECTOR(DMA1_Stream3_IRQHandler) +INT_VECTOR(DMA1_Stream4_IRQHandler) +INT_VECTOR(DMA1_Stream5_IRQHandler) +INT_VECTOR(DMA1_Stream6_IRQHandler) +INT_VECTOR(ADC_IRQHandler) +INT_VECTOR(CAN1_TX_IRQHandler) +INT_VECTOR(CAN1_RX0_IRQHandler) +INT_VECTOR(CAN1_RX1_IRQHandler) +INT_VECTOR(CAN1_SCE_IRQHandler) +INT_VECTOR(EXTI9_5_IRQHandler) +INT_VECTOR(TIM1_BRK_TIM9_IRQHandler) +INT_VECTOR(TIM1_UP_TIM10_IRQHandler) +INT_VECTOR(TIM1_TRG_COM_TIM11_IRQHandler) +INT_VECTOR(TIM1_CC_IRQHandler) +INT_VECTOR(TIM2_IRQHandler) +INT_VECTOR(TIM3_IRQHandler) +INT_VECTOR(TIM4_IRQHandler) +INT_VECTOR(I2C1_EV_IRQHandler) +INT_VECTOR(I2C1_ER_IRQHandler) +INT_VECTOR(I2C2_EV_IRQHandler) +INT_VECTOR(I2C2_ER_IRQHandler) +INT_VECTOR(SPI1_IRQHandler) +INT_VECTOR(SPI2_IRQHandler) +INT_VECTOR(USART1_IRQHandler) +INT_VECTOR(USART2_IRQHandler) +INT_VECTOR(USART3_IRQHandler) +INT_VECTOR(EXTI15_10_IRQHandler) +INT_VECTOR(RTC_Alarm_IRQHandler) +INT_VECTOR(OTG_FS_WKUP_IRQHandler) +INT_VECTOR(TIM8_BRK_TIM12_IRQHandler) +INT_VECTOR(TIM8_UP_TIM13_IRQHandler) +INT_VECTOR(TIM8_TRG_COM_TIM14_IRQHandler) +INT_VECTOR(TIM8_CC_IRQHandler) +INT_VECTOR(DMA1_Stream7_IRQHandler) +INT_VECTOR(FMC_IRQHandler) +INT_VECTOR(SDMMC1_IRQHandler) +INT_VECTOR(TIM5_IRQHandler) +INT_VECTOR(SPI3_IRQHandler) +INT_VECTOR(UART4_IRQHandler) +INT_VECTOR(UART5_IRQHandler) +INT_VECTOR(TIM6_DAC_IRQHandler) +INT_VECTOR(TIM7_IRQHandler) +INT_VECTOR(DMA2_Stream0_IRQHandler) +INT_VECTOR(DMA2_Stream1_IRQHandler) +INT_VECTOR(DMA2_Stream2_IRQHandler) +INT_VECTOR(DMA2_Stream3_IRQHandler) +INT_VECTOR(DMA2_Stream4_IRQHandler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR(OTG_FS_IRQHandler) +INT_VECTOR(DMA2_Stream5_IRQHandler) +INT_VECTOR(DMA2_Stream6_IRQHandler) +INT_VECTOR(DMA2_Stream7_IRQHandler) +INT_VECTOR(USART6_IRQHandler) +INT_VECTOR(I2C3_EV_IRQHandler) +INT_VECTOR(I2C3_ER_IRQHandler) +INT_VECTOR(OTG_HS_EP1_OUT_IRQHandler) +INT_VECTOR(OTG_HS_EP1_IN_IRQHandler) +INT_VECTOR(OTG_HS_WKUP_IRQHandler) +INT_VECTOR(OTG_HS_IRQHandler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR(RNG_IRQHandler) +INT_VECTOR(FPU_IRQHandler) +INT_VECTOR(UART7_IRQHandler) +INT_VECTOR(UART8_IRQHandler) +INT_VECTOR(SPI4_IRQHandler) +INT_VECTOR(SPI5_IRQHandler) +INT_VECTOR_UNUSED(0) +INT_VECTOR(SAI1_IRQHandler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR(SAI2_IRQHandler) +INT_VECTOR(QUADSPI_IRQHandler) +INT_VECTOR(LPTIM1_IRQHandler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR(SDMMC2_IRQHandler) diff --git a/hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f723xx_vectors.h b/hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f723xx_vectors.h new file mode 100644 index 0000000000..542f431ce1 --- /dev/null +++ b/hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f723xx_vectors.h @@ -0,0 +1,139 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance + * with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +INT_VECTOR_STACK_TOP(__StackTop) +INT_VECTOR_RESET_HANDLER(Reset_Handler) +INT_VECTOR_NMI_HANDLER(NMI_Handler) +INT_VECTOR_HARDFAULT_HANDLER(HardFault_Handler) +INT_VECTOR_MEMMANAGE_HANDLER(MemManage_Handler) +INT_VECTOR_BUSFAULT_HANDLER(BusFault_Handler) +INT_VECTOR_USAGEFAULT_HANDLER(UsageFault_Handler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_SVC_HANDLER(SVC_Handler) +INT_VECTOR_DEBUGMON_HANDLER(DebugMon_Handler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_PENDSV_HANDLER(PendSV_Handler) +INT_VECTOR_SYSTICK_HANDLER(SysTick_Handler) +INT_VECTOR(WWDG_IRQHandler) +INT_VECTOR(PVD_IRQHandler) +INT_VECTOR(TAMP_STAMP_IRQHandler) +INT_VECTOR(RTC_WKUP_IRQHandler) +INT_VECTOR(FLASH_IRQHandler) +INT_VECTOR(RCC_IRQHandler) +INT_VECTOR(EXTI0_IRQHandler) +INT_VECTOR(EXTI1_IRQHandler) +INT_VECTOR(EXTI2_IRQHandler) +INT_VECTOR(EXTI3_IRQHandler) +INT_VECTOR(EXTI4_IRQHandler) +INT_VECTOR(DMA1_Stream0_IRQHandler) +INT_VECTOR(DMA1_Stream1_IRQHandler) +INT_VECTOR(DMA1_Stream2_IRQHandler) +INT_VECTOR(DMA1_Stream3_IRQHandler) +INT_VECTOR(DMA1_Stream4_IRQHandler) +INT_VECTOR(DMA1_Stream5_IRQHandler) +INT_VECTOR(DMA1_Stream6_IRQHandler) +INT_VECTOR(ADC_IRQHandler) +INT_VECTOR(CAN1_TX_IRQHandler) +INT_VECTOR(CAN1_RX0_IRQHandler) +INT_VECTOR(CAN1_RX1_IRQHandler) +INT_VECTOR(CAN1_SCE_IRQHandler) +INT_VECTOR(EXTI9_5_IRQHandler) +INT_VECTOR(TIM1_BRK_TIM9_IRQHandler) +INT_VECTOR(TIM1_UP_TIM10_IRQHandler) +INT_VECTOR(TIM1_TRG_COM_TIM11_IRQHandler) +INT_VECTOR(TIM1_CC_IRQHandler) +INT_VECTOR(TIM2_IRQHandler) +INT_VECTOR(TIM3_IRQHandler) +INT_VECTOR(TIM4_IRQHandler) +INT_VECTOR(I2C1_EV_IRQHandler) +INT_VECTOR(I2C1_ER_IRQHandler) +INT_VECTOR(I2C2_EV_IRQHandler) +INT_VECTOR(I2C2_ER_IRQHandler) +INT_VECTOR(SPI1_IRQHandler) +INT_VECTOR(SPI2_IRQHandler) +INT_VECTOR(USART1_IRQHandler) +INT_VECTOR(USART2_IRQHandler) +INT_VECTOR(USART3_IRQHandler) +INT_VECTOR(EXTI15_10_IRQHandler) +INT_VECTOR(RTC_Alarm_IRQHandler) +INT_VECTOR(OTG_FS_WKUP_IRQHandler) +INT_VECTOR(TIM8_BRK_TIM12_IRQHandler) +INT_VECTOR(TIM8_UP_TIM13_IRQHandler) +INT_VECTOR(TIM8_TRG_COM_TIM14_IRQHandler) +INT_VECTOR(TIM8_CC_IRQHandler) +INT_VECTOR(DMA1_Stream7_IRQHandler) +INT_VECTOR(FMC_IRQHandler) +INT_VECTOR(SDMMC1_IRQHandler) +INT_VECTOR(TIM5_IRQHandler) +INT_VECTOR(SPI3_IRQHandler) +INT_VECTOR(UART4_IRQHandler) +INT_VECTOR(UART5_IRQHandler) +INT_VECTOR(TIM6_DAC_IRQHandler) +INT_VECTOR(TIM7_IRQHandler) +INT_VECTOR(DMA2_Stream0_IRQHandler) +INT_VECTOR(DMA2_Stream1_IRQHandler) +INT_VECTOR(DMA2_Stream2_IRQHandler) +INT_VECTOR(DMA2_Stream3_IRQHandler) +INT_VECTOR(DMA2_Stream4_IRQHandler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR(OTG_FS_IRQHandler) +INT_VECTOR(DMA2_Stream5_IRQHandler) +INT_VECTOR(DMA2_Stream6_IRQHandler) +INT_VECTOR(DMA2_Stream7_IRQHandler) +INT_VECTOR(USART6_IRQHandler) +INT_VECTOR(I2C3_EV_IRQHandler) +INT_VECTOR(I2C3_ER_IRQHandler) +INT_VECTOR(OTG_HS_EP1_OUT_IRQHandler) +INT_VECTOR(OTG_HS_EP1_IN_IRQHandler) +INT_VECTOR(OTG_HS_WKUP_IRQHandler) +INT_VECTOR(OTG_HS_IRQHandler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR(RNG_IRQHandler) +INT_VECTOR(FPU_IRQHandler) +INT_VECTOR(UART7_IRQHandler) +INT_VECTOR(UART8_IRQHandler) +INT_VECTOR(SPI4_IRQHandler) +INT_VECTOR(SPI5_IRQHandler) +INT_VECTOR_UNUSED(0) +INT_VECTOR(SAI1_IRQHandler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR(SAI2_IRQHandler) +INT_VECTOR(QUADSPI_IRQHandler) +INT_VECTOR(LPTIM1_IRQHandler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR(SDMMC2_IRQHandler) diff --git a/hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f730xx_vectors.h b/hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f730xx_vectors.h new file mode 100644 index 0000000000..08cc326c40 --- /dev/null +++ b/hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f730xx_vectors.h @@ -0,0 +1,139 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance + * with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +INT_VECTOR_STACK_TOP(__StackTop) +INT_VECTOR_RESET_HANDLER(Reset_Handler) +INT_VECTOR_NMI_HANDLER(NMI_Handler) +INT_VECTOR_HARDFAULT_HANDLER(HardFault_Handler) +INT_VECTOR_MEMMANAGE_HANDLER(MemManage_Handler) +INT_VECTOR_BUSFAULT_HANDLER(BusFault_Handler) +INT_VECTOR_USAGEFAULT_HANDLER(UsageFault_Handler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_SVC_HANDLER(SVC_Handler) +INT_VECTOR_DEBUGMON_HANDLER(DebugMon_Handler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_PENDSV_HANDLER(PendSV_Handler) +INT_VECTOR_SYSTICK_HANDLER(SysTick_Handler) +INT_VECTOR(WWDG_IRQHandler) +INT_VECTOR(PVD_IRQHandler) +INT_VECTOR(TAMP_STAMP_IRQHandler) +INT_VECTOR(RTC_WKUP_IRQHandler) +INT_VECTOR(FLASH_IRQHandler) +INT_VECTOR(RCC_IRQHandler) +INT_VECTOR(EXTI0_IRQHandler) +INT_VECTOR(EXTI1_IRQHandler) +INT_VECTOR(EXTI2_IRQHandler) +INT_VECTOR(EXTI3_IRQHandler) +INT_VECTOR(EXTI4_IRQHandler) +INT_VECTOR(DMA1_Stream0_IRQHandler) +INT_VECTOR(DMA1_Stream1_IRQHandler) +INT_VECTOR(DMA1_Stream2_IRQHandler) +INT_VECTOR(DMA1_Stream3_IRQHandler) +INT_VECTOR(DMA1_Stream4_IRQHandler) +INT_VECTOR(DMA1_Stream5_IRQHandler) +INT_VECTOR(DMA1_Stream6_IRQHandler) +INT_VECTOR(ADC_IRQHandler) +INT_VECTOR(CAN1_TX_IRQHandler) +INT_VECTOR(CAN1_RX0_IRQHandler) +INT_VECTOR(CAN1_RX1_IRQHandler) +INT_VECTOR(CAN1_SCE_IRQHandler) +INT_VECTOR(EXTI9_5_IRQHandler) +INT_VECTOR(TIM1_BRK_TIM9_IRQHandler) +INT_VECTOR(TIM1_UP_TIM10_IRQHandler) +INT_VECTOR(TIM1_TRG_COM_TIM11_IRQHandler) +INT_VECTOR(TIM1_CC_IRQHandler) +INT_VECTOR(TIM2_IRQHandler) +INT_VECTOR(TIM3_IRQHandler) +INT_VECTOR(TIM4_IRQHandler) +INT_VECTOR(I2C1_EV_IRQHandler) +INT_VECTOR(I2C1_ER_IRQHandler) +INT_VECTOR(I2C2_EV_IRQHandler) +INT_VECTOR(I2C2_ER_IRQHandler) +INT_VECTOR(SPI1_IRQHandler) +INT_VECTOR(SPI2_IRQHandler) +INT_VECTOR(USART1_IRQHandler) +INT_VECTOR(USART2_IRQHandler) +INT_VECTOR(USART3_IRQHandler) +INT_VECTOR(EXTI15_10_IRQHandler) +INT_VECTOR(RTC_Alarm_IRQHandler) +INT_VECTOR(OTG_FS_WKUP_IRQHandler) +INT_VECTOR(TIM8_BRK_TIM12_IRQHandler) +INT_VECTOR(TIM8_UP_TIM13_IRQHandler) +INT_VECTOR(TIM8_TRG_COM_TIM14_IRQHandler) +INT_VECTOR(TIM8_CC_IRQHandler) +INT_VECTOR(DMA1_Stream7_IRQHandler) +INT_VECTOR(FMC_IRQHandler) +INT_VECTOR(SDMMC1_IRQHandler) +INT_VECTOR(TIM5_IRQHandler) +INT_VECTOR(SPI3_IRQHandler) +INT_VECTOR(UART4_IRQHandler) +INT_VECTOR(UART5_IRQHandler) +INT_VECTOR(TIM6_DAC_IRQHandler) +INT_VECTOR(TIM7_IRQHandler) +INT_VECTOR(DMA2_Stream0_IRQHandler) +INT_VECTOR(DMA2_Stream1_IRQHandler) +INT_VECTOR(DMA2_Stream2_IRQHandler) +INT_VECTOR(DMA2_Stream3_IRQHandler) +INT_VECTOR(DMA2_Stream4_IRQHandler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR(OTG_FS_IRQHandler) +INT_VECTOR(DMA2_Stream5_IRQHandler) +INT_VECTOR(DMA2_Stream6_IRQHandler) +INT_VECTOR(DMA2_Stream7_IRQHandler) +INT_VECTOR(USART6_IRQHandler) +INT_VECTOR(I2C3_EV_IRQHandler) +INT_VECTOR(I2C3_ER_IRQHandler) +INT_VECTOR(OTG_HS_EP1_OUT_IRQHandler) +INT_VECTOR(OTG_HS_EP1_IN_IRQHandler) +INT_VECTOR(OTG_HS_WKUP_IRQHandler) +INT_VECTOR(OTG_HS_IRQHandler) +INT_VECTOR_UNUSED(0) +INT_VECTOR(AES_IRQHandler) +INT_VECTOR(RNG_IRQHandler) +INT_VECTOR(FPU_IRQHandler) +INT_VECTOR(UART7_IRQHandler) +INT_VECTOR(UART8_IRQHandler) +INT_VECTOR(SPI4_IRQHandler) +INT_VECTOR(SPI5_IRQHandler) +INT_VECTOR_UNUSED(0) +INT_VECTOR(SAI1_IRQHandler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR(SAI2_IRQHandler) +INT_VECTOR(QUADSPI_IRQHandler) +INT_VECTOR(LPTIM1_IRQHandler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR(SDMMC2_IRQHandler) diff --git a/hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f732xx_vectors.h b/hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f732xx_vectors.h new file mode 100644 index 0000000000..08cc326c40 --- /dev/null +++ b/hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f732xx_vectors.h @@ -0,0 +1,139 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance + * with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +INT_VECTOR_STACK_TOP(__StackTop) +INT_VECTOR_RESET_HANDLER(Reset_Handler) +INT_VECTOR_NMI_HANDLER(NMI_Handler) +INT_VECTOR_HARDFAULT_HANDLER(HardFault_Handler) +INT_VECTOR_MEMMANAGE_HANDLER(MemManage_Handler) +INT_VECTOR_BUSFAULT_HANDLER(BusFault_Handler) +INT_VECTOR_USAGEFAULT_HANDLER(UsageFault_Handler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_SVC_HANDLER(SVC_Handler) +INT_VECTOR_DEBUGMON_HANDLER(DebugMon_Handler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_PENDSV_HANDLER(PendSV_Handler) +INT_VECTOR_SYSTICK_HANDLER(SysTick_Handler) +INT_VECTOR(WWDG_IRQHandler) +INT_VECTOR(PVD_IRQHandler) +INT_VECTOR(TAMP_STAMP_IRQHandler) +INT_VECTOR(RTC_WKUP_IRQHandler) +INT_VECTOR(FLASH_IRQHandler) +INT_VECTOR(RCC_IRQHandler) +INT_VECTOR(EXTI0_IRQHandler) +INT_VECTOR(EXTI1_IRQHandler) +INT_VECTOR(EXTI2_IRQHandler) +INT_VECTOR(EXTI3_IRQHandler) +INT_VECTOR(EXTI4_IRQHandler) +INT_VECTOR(DMA1_Stream0_IRQHandler) +INT_VECTOR(DMA1_Stream1_IRQHandler) +INT_VECTOR(DMA1_Stream2_IRQHandler) +INT_VECTOR(DMA1_Stream3_IRQHandler) +INT_VECTOR(DMA1_Stream4_IRQHandler) +INT_VECTOR(DMA1_Stream5_IRQHandler) +INT_VECTOR(DMA1_Stream6_IRQHandler) +INT_VECTOR(ADC_IRQHandler) +INT_VECTOR(CAN1_TX_IRQHandler) +INT_VECTOR(CAN1_RX0_IRQHandler) +INT_VECTOR(CAN1_RX1_IRQHandler) +INT_VECTOR(CAN1_SCE_IRQHandler) +INT_VECTOR(EXTI9_5_IRQHandler) +INT_VECTOR(TIM1_BRK_TIM9_IRQHandler) +INT_VECTOR(TIM1_UP_TIM10_IRQHandler) +INT_VECTOR(TIM1_TRG_COM_TIM11_IRQHandler) +INT_VECTOR(TIM1_CC_IRQHandler) +INT_VECTOR(TIM2_IRQHandler) +INT_VECTOR(TIM3_IRQHandler) +INT_VECTOR(TIM4_IRQHandler) +INT_VECTOR(I2C1_EV_IRQHandler) +INT_VECTOR(I2C1_ER_IRQHandler) +INT_VECTOR(I2C2_EV_IRQHandler) +INT_VECTOR(I2C2_ER_IRQHandler) +INT_VECTOR(SPI1_IRQHandler) +INT_VECTOR(SPI2_IRQHandler) +INT_VECTOR(USART1_IRQHandler) +INT_VECTOR(USART2_IRQHandler) +INT_VECTOR(USART3_IRQHandler) +INT_VECTOR(EXTI15_10_IRQHandler) +INT_VECTOR(RTC_Alarm_IRQHandler) +INT_VECTOR(OTG_FS_WKUP_IRQHandler) +INT_VECTOR(TIM8_BRK_TIM12_IRQHandler) +INT_VECTOR(TIM8_UP_TIM13_IRQHandler) +INT_VECTOR(TIM8_TRG_COM_TIM14_IRQHandler) +INT_VECTOR(TIM8_CC_IRQHandler) +INT_VECTOR(DMA1_Stream7_IRQHandler) +INT_VECTOR(FMC_IRQHandler) +INT_VECTOR(SDMMC1_IRQHandler) +INT_VECTOR(TIM5_IRQHandler) +INT_VECTOR(SPI3_IRQHandler) +INT_VECTOR(UART4_IRQHandler) +INT_VECTOR(UART5_IRQHandler) +INT_VECTOR(TIM6_DAC_IRQHandler) +INT_VECTOR(TIM7_IRQHandler) +INT_VECTOR(DMA2_Stream0_IRQHandler) +INT_VECTOR(DMA2_Stream1_IRQHandler) +INT_VECTOR(DMA2_Stream2_IRQHandler) +INT_VECTOR(DMA2_Stream3_IRQHandler) +INT_VECTOR(DMA2_Stream4_IRQHandler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR(OTG_FS_IRQHandler) +INT_VECTOR(DMA2_Stream5_IRQHandler) +INT_VECTOR(DMA2_Stream6_IRQHandler) +INT_VECTOR(DMA2_Stream7_IRQHandler) +INT_VECTOR(USART6_IRQHandler) +INT_VECTOR(I2C3_EV_IRQHandler) +INT_VECTOR(I2C3_ER_IRQHandler) +INT_VECTOR(OTG_HS_EP1_OUT_IRQHandler) +INT_VECTOR(OTG_HS_EP1_IN_IRQHandler) +INT_VECTOR(OTG_HS_WKUP_IRQHandler) +INT_VECTOR(OTG_HS_IRQHandler) +INT_VECTOR_UNUSED(0) +INT_VECTOR(AES_IRQHandler) +INT_VECTOR(RNG_IRQHandler) +INT_VECTOR(FPU_IRQHandler) +INT_VECTOR(UART7_IRQHandler) +INT_VECTOR(UART8_IRQHandler) +INT_VECTOR(SPI4_IRQHandler) +INT_VECTOR(SPI5_IRQHandler) +INT_VECTOR_UNUSED(0) +INT_VECTOR(SAI1_IRQHandler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR(SAI2_IRQHandler) +INT_VECTOR(QUADSPI_IRQHandler) +INT_VECTOR(LPTIM1_IRQHandler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR(SDMMC2_IRQHandler) diff --git a/hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f733xx_vectors.h b/hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f733xx_vectors.h new file mode 100644 index 0000000000..08cc326c40 --- /dev/null +++ b/hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f733xx_vectors.h @@ -0,0 +1,139 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance + * with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +INT_VECTOR_STACK_TOP(__StackTop) +INT_VECTOR_RESET_HANDLER(Reset_Handler) +INT_VECTOR_NMI_HANDLER(NMI_Handler) +INT_VECTOR_HARDFAULT_HANDLER(HardFault_Handler) +INT_VECTOR_MEMMANAGE_HANDLER(MemManage_Handler) +INT_VECTOR_BUSFAULT_HANDLER(BusFault_Handler) +INT_VECTOR_USAGEFAULT_HANDLER(UsageFault_Handler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_SVC_HANDLER(SVC_Handler) +INT_VECTOR_DEBUGMON_HANDLER(DebugMon_Handler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_PENDSV_HANDLER(PendSV_Handler) +INT_VECTOR_SYSTICK_HANDLER(SysTick_Handler) +INT_VECTOR(WWDG_IRQHandler) +INT_VECTOR(PVD_IRQHandler) +INT_VECTOR(TAMP_STAMP_IRQHandler) +INT_VECTOR(RTC_WKUP_IRQHandler) +INT_VECTOR(FLASH_IRQHandler) +INT_VECTOR(RCC_IRQHandler) +INT_VECTOR(EXTI0_IRQHandler) +INT_VECTOR(EXTI1_IRQHandler) +INT_VECTOR(EXTI2_IRQHandler) +INT_VECTOR(EXTI3_IRQHandler) +INT_VECTOR(EXTI4_IRQHandler) +INT_VECTOR(DMA1_Stream0_IRQHandler) +INT_VECTOR(DMA1_Stream1_IRQHandler) +INT_VECTOR(DMA1_Stream2_IRQHandler) +INT_VECTOR(DMA1_Stream3_IRQHandler) +INT_VECTOR(DMA1_Stream4_IRQHandler) +INT_VECTOR(DMA1_Stream5_IRQHandler) +INT_VECTOR(DMA1_Stream6_IRQHandler) +INT_VECTOR(ADC_IRQHandler) +INT_VECTOR(CAN1_TX_IRQHandler) +INT_VECTOR(CAN1_RX0_IRQHandler) +INT_VECTOR(CAN1_RX1_IRQHandler) +INT_VECTOR(CAN1_SCE_IRQHandler) +INT_VECTOR(EXTI9_5_IRQHandler) +INT_VECTOR(TIM1_BRK_TIM9_IRQHandler) +INT_VECTOR(TIM1_UP_TIM10_IRQHandler) +INT_VECTOR(TIM1_TRG_COM_TIM11_IRQHandler) +INT_VECTOR(TIM1_CC_IRQHandler) +INT_VECTOR(TIM2_IRQHandler) +INT_VECTOR(TIM3_IRQHandler) +INT_VECTOR(TIM4_IRQHandler) +INT_VECTOR(I2C1_EV_IRQHandler) +INT_VECTOR(I2C1_ER_IRQHandler) +INT_VECTOR(I2C2_EV_IRQHandler) +INT_VECTOR(I2C2_ER_IRQHandler) +INT_VECTOR(SPI1_IRQHandler) +INT_VECTOR(SPI2_IRQHandler) +INT_VECTOR(USART1_IRQHandler) +INT_VECTOR(USART2_IRQHandler) +INT_VECTOR(USART3_IRQHandler) +INT_VECTOR(EXTI15_10_IRQHandler) +INT_VECTOR(RTC_Alarm_IRQHandler) +INT_VECTOR(OTG_FS_WKUP_IRQHandler) +INT_VECTOR(TIM8_BRK_TIM12_IRQHandler) +INT_VECTOR(TIM8_UP_TIM13_IRQHandler) +INT_VECTOR(TIM8_TRG_COM_TIM14_IRQHandler) +INT_VECTOR(TIM8_CC_IRQHandler) +INT_VECTOR(DMA1_Stream7_IRQHandler) +INT_VECTOR(FMC_IRQHandler) +INT_VECTOR(SDMMC1_IRQHandler) +INT_VECTOR(TIM5_IRQHandler) +INT_VECTOR(SPI3_IRQHandler) +INT_VECTOR(UART4_IRQHandler) +INT_VECTOR(UART5_IRQHandler) +INT_VECTOR(TIM6_DAC_IRQHandler) +INT_VECTOR(TIM7_IRQHandler) +INT_VECTOR(DMA2_Stream0_IRQHandler) +INT_VECTOR(DMA2_Stream1_IRQHandler) +INT_VECTOR(DMA2_Stream2_IRQHandler) +INT_VECTOR(DMA2_Stream3_IRQHandler) +INT_VECTOR(DMA2_Stream4_IRQHandler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR(OTG_FS_IRQHandler) +INT_VECTOR(DMA2_Stream5_IRQHandler) +INT_VECTOR(DMA2_Stream6_IRQHandler) +INT_VECTOR(DMA2_Stream7_IRQHandler) +INT_VECTOR(USART6_IRQHandler) +INT_VECTOR(I2C3_EV_IRQHandler) +INT_VECTOR(I2C3_ER_IRQHandler) +INT_VECTOR(OTG_HS_EP1_OUT_IRQHandler) +INT_VECTOR(OTG_HS_EP1_IN_IRQHandler) +INT_VECTOR(OTG_HS_WKUP_IRQHandler) +INT_VECTOR(OTG_HS_IRQHandler) +INT_VECTOR_UNUSED(0) +INT_VECTOR(AES_IRQHandler) +INT_VECTOR(RNG_IRQHandler) +INT_VECTOR(FPU_IRQHandler) +INT_VECTOR(UART7_IRQHandler) +INT_VECTOR(UART8_IRQHandler) +INT_VECTOR(SPI4_IRQHandler) +INT_VECTOR(SPI5_IRQHandler) +INT_VECTOR_UNUSED(0) +INT_VECTOR(SAI1_IRQHandler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR(SAI2_IRQHandler) +INT_VECTOR(QUADSPI_IRQHandler) +INT_VECTOR(LPTIM1_IRQHandler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR(SDMMC2_IRQHandler) diff --git a/hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f745xx_vectors.h b/hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f745xx_vectors.h new file mode 100644 index 0000000000..1c78c33653 --- /dev/null +++ b/hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f745xx_vectors.h @@ -0,0 +1,133 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance + * with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +INT_VECTOR_STACK_TOP(__StackTop) +INT_VECTOR_RESET_HANDLER(Reset_Handler) +INT_VECTOR_NMI_HANDLER(NMI_Handler) +INT_VECTOR_HARDFAULT_HANDLER(HardFault_Handler) +INT_VECTOR_MEMMANAGE_HANDLER(MemManage_Handler) +INT_VECTOR_BUSFAULT_HANDLER(BusFault_Handler) +INT_VECTOR_USAGEFAULT_HANDLER(UsageFault_Handler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_SVC_HANDLER(SVC_Handler) +INT_VECTOR_DEBUGMON_HANDLER(DebugMon_Handler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_PENDSV_HANDLER(PendSV_Handler) +INT_VECTOR_SYSTICK_HANDLER(SysTick_Handler) +INT_VECTOR(WWDG_IRQHandler) +INT_VECTOR(PVD_IRQHandler) +INT_VECTOR(TAMP_STAMP_IRQHandler) +INT_VECTOR(RTC_WKUP_IRQHandler) +INT_VECTOR(FLASH_IRQHandler) +INT_VECTOR(RCC_IRQHandler) +INT_VECTOR(EXTI0_IRQHandler) +INT_VECTOR(EXTI1_IRQHandler) +INT_VECTOR(EXTI2_IRQHandler) +INT_VECTOR(EXTI3_IRQHandler) +INT_VECTOR(EXTI4_IRQHandler) +INT_VECTOR(DMA1_Stream0_IRQHandler) +INT_VECTOR(DMA1_Stream1_IRQHandler) +INT_VECTOR(DMA1_Stream2_IRQHandler) +INT_VECTOR(DMA1_Stream3_IRQHandler) +INT_VECTOR(DMA1_Stream4_IRQHandler) +INT_VECTOR(DMA1_Stream5_IRQHandler) +INT_VECTOR(DMA1_Stream6_IRQHandler) +INT_VECTOR(ADC_IRQHandler) +INT_VECTOR(CAN1_TX_IRQHandler) +INT_VECTOR(CAN1_RX0_IRQHandler) +INT_VECTOR(CAN1_RX1_IRQHandler) +INT_VECTOR(CAN1_SCE_IRQHandler) +INT_VECTOR(EXTI9_5_IRQHandler) +INT_VECTOR(TIM1_BRK_TIM9_IRQHandler) +INT_VECTOR(TIM1_UP_TIM10_IRQHandler) +INT_VECTOR(TIM1_TRG_COM_TIM11_IRQHandler) +INT_VECTOR(TIM1_CC_IRQHandler) +INT_VECTOR(TIM2_IRQHandler) +INT_VECTOR(TIM3_IRQHandler) +INT_VECTOR(TIM4_IRQHandler) +INT_VECTOR(I2C1_EV_IRQHandler) +INT_VECTOR(I2C1_ER_IRQHandler) +INT_VECTOR(I2C2_EV_IRQHandler) +INT_VECTOR(I2C2_ER_IRQHandler) +INT_VECTOR(SPI1_IRQHandler) +INT_VECTOR(SPI2_IRQHandler) +INT_VECTOR(USART1_IRQHandler) +INT_VECTOR(USART2_IRQHandler) +INT_VECTOR(USART3_IRQHandler) +INT_VECTOR(EXTI15_10_IRQHandler) +INT_VECTOR(RTC_Alarm_IRQHandler) +INT_VECTOR(OTG_FS_WKUP_IRQHandler) +INT_VECTOR(TIM8_BRK_TIM12_IRQHandler) +INT_VECTOR(TIM8_UP_TIM13_IRQHandler) +INT_VECTOR(TIM8_TRG_COM_TIM14_IRQHandler) +INT_VECTOR(TIM8_CC_IRQHandler) +INT_VECTOR(DMA1_Stream7_IRQHandler) +INT_VECTOR(FMC_IRQHandler) +INT_VECTOR(SDMMC1_IRQHandler) +INT_VECTOR(TIM5_IRQHandler) +INT_VECTOR(SPI3_IRQHandler) +INT_VECTOR(UART4_IRQHandler) +INT_VECTOR(UART5_IRQHandler) +INT_VECTOR(TIM6_DAC_IRQHandler) +INT_VECTOR(TIM7_IRQHandler) +INT_VECTOR(DMA2_Stream0_IRQHandler) +INT_VECTOR(DMA2_Stream1_IRQHandler) +INT_VECTOR(DMA2_Stream2_IRQHandler) +INT_VECTOR(DMA2_Stream3_IRQHandler) +INT_VECTOR(DMA2_Stream4_IRQHandler) +INT_VECTOR(ETH_IRQHandler) +INT_VECTOR(ETH_WKUP_IRQHandler) +INT_VECTOR(CAN2_TX_IRQHandler) +INT_VECTOR(CAN2_RX0_IRQHandler) +INT_VECTOR(CAN2_RX1_IRQHandler) +INT_VECTOR(CAN2_SCE_IRQHandler) +INT_VECTOR(OTG_FS_IRQHandler) +INT_VECTOR(DMA2_Stream5_IRQHandler) +INT_VECTOR(DMA2_Stream6_IRQHandler) +INT_VECTOR(DMA2_Stream7_IRQHandler) +INT_VECTOR(USART6_IRQHandler) +INT_VECTOR(I2C3_EV_IRQHandler) +INT_VECTOR(I2C3_ER_IRQHandler) +INT_VECTOR(OTG_HS_EP1_OUT_IRQHandler) +INT_VECTOR(OTG_HS_EP1_IN_IRQHandler) +INT_VECTOR(OTG_HS_WKUP_IRQHandler) +INT_VECTOR(OTG_HS_IRQHandler) +INT_VECTOR(DCMI_IRQHandler) +INT_VECTOR_UNUSED(0) +INT_VECTOR(RNG_IRQHandler) +INT_VECTOR(FPU_IRQHandler) +INT_VECTOR(UART7_IRQHandler) +INT_VECTOR(UART8_IRQHandler) +INT_VECTOR(SPI4_IRQHandler) +INT_VECTOR(SPI5_IRQHandler) +INT_VECTOR(SPI6_IRQHandler) +INT_VECTOR(SAI1_IRQHandler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR(DMA2D_IRQHandler) +INT_VECTOR(SAI2_IRQHandler) +INT_VECTOR(QUADSPI_IRQHandler) +INT_VECTOR(LPTIM1_IRQHandler) +INT_VECTOR(CEC_IRQHandler) +INT_VECTOR(I2C4_EV_IRQHandler) +INT_VECTOR(I2C4_ER_IRQHandler) +INT_VECTOR(SPDIF_RX_IRQHandler) diff --git a/hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f746xx_vectors.h b/hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f746xx_vectors.h new file mode 100644 index 0000000000..16abf62a5f --- /dev/null +++ b/hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f746xx_vectors.h @@ -0,0 +1,133 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance + * with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +INT_VECTOR_STACK_TOP(__StackTop) +INT_VECTOR_RESET_HANDLER(Reset_Handler) +INT_VECTOR_NMI_HANDLER(NMI_Handler) +INT_VECTOR_HARDFAULT_HANDLER(HardFault_Handler) +INT_VECTOR_MEMMANAGE_HANDLER(MemManage_Handler) +INT_VECTOR_BUSFAULT_HANDLER(BusFault_Handler) +INT_VECTOR_USAGEFAULT_HANDLER(UsageFault_Handler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_SVC_HANDLER(SVC_Handler) +INT_VECTOR_DEBUGMON_HANDLER(DebugMon_Handler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_PENDSV_HANDLER(PendSV_Handler) +INT_VECTOR_SYSTICK_HANDLER(SysTick_Handler) +INT_VECTOR(WWDG_IRQHandler) +INT_VECTOR(PVD_IRQHandler) +INT_VECTOR(TAMP_STAMP_IRQHandler) +INT_VECTOR(RTC_WKUP_IRQHandler) +INT_VECTOR(FLASH_IRQHandler) +INT_VECTOR(RCC_IRQHandler) +INT_VECTOR(EXTI0_IRQHandler) +INT_VECTOR(EXTI1_IRQHandler) +INT_VECTOR(EXTI2_IRQHandler) +INT_VECTOR(EXTI3_IRQHandler) +INT_VECTOR(EXTI4_IRQHandler) +INT_VECTOR(DMA1_Stream0_IRQHandler) +INT_VECTOR(DMA1_Stream1_IRQHandler) +INT_VECTOR(DMA1_Stream2_IRQHandler) +INT_VECTOR(DMA1_Stream3_IRQHandler) +INT_VECTOR(DMA1_Stream4_IRQHandler) +INT_VECTOR(DMA1_Stream5_IRQHandler) +INT_VECTOR(DMA1_Stream6_IRQHandler) +INT_VECTOR(ADC_IRQHandler) +INT_VECTOR(CAN1_TX_IRQHandler) +INT_VECTOR(CAN1_RX0_IRQHandler) +INT_VECTOR(CAN1_RX1_IRQHandler) +INT_VECTOR(CAN1_SCE_IRQHandler) +INT_VECTOR(EXTI9_5_IRQHandler) +INT_VECTOR(TIM1_BRK_TIM9_IRQHandler) +INT_VECTOR(TIM1_UP_TIM10_IRQHandler) +INT_VECTOR(TIM1_TRG_COM_TIM11_IRQHandler) +INT_VECTOR(TIM1_CC_IRQHandler) +INT_VECTOR(TIM2_IRQHandler) +INT_VECTOR(TIM3_IRQHandler) +INT_VECTOR(TIM4_IRQHandler) +INT_VECTOR(I2C1_EV_IRQHandler) +INT_VECTOR(I2C1_ER_IRQHandler) +INT_VECTOR(I2C2_EV_IRQHandler) +INT_VECTOR(I2C2_ER_IRQHandler) +INT_VECTOR(SPI1_IRQHandler) +INT_VECTOR(SPI2_IRQHandler) +INT_VECTOR(USART1_IRQHandler) +INT_VECTOR(USART2_IRQHandler) +INT_VECTOR(USART3_IRQHandler) +INT_VECTOR(EXTI15_10_IRQHandler) +INT_VECTOR(RTC_Alarm_IRQHandler) +INT_VECTOR(OTG_FS_WKUP_IRQHandler) +INT_VECTOR(TIM8_BRK_TIM12_IRQHandler) +INT_VECTOR(TIM8_UP_TIM13_IRQHandler) +INT_VECTOR(TIM8_TRG_COM_TIM14_IRQHandler) +INT_VECTOR(TIM8_CC_IRQHandler) +INT_VECTOR(DMA1_Stream7_IRQHandler) +INT_VECTOR(FMC_IRQHandler) +INT_VECTOR(SDMMC1_IRQHandler) +INT_VECTOR(TIM5_IRQHandler) +INT_VECTOR(SPI3_IRQHandler) +INT_VECTOR(UART4_IRQHandler) +INT_VECTOR(UART5_IRQHandler) +INT_VECTOR(TIM6_DAC_IRQHandler) +INT_VECTOR(TIM7_IRQHandler) +INT_VECTOR(DMA2_Stream0_IRQHandler) +INT_VECTOR(DMA2_Stream1_IRQHandler) +INT_VECTOR(DMA2_Stream2_IRQHandler) +INT_VECTOR(DMA2_Stream3_IRQHandler) +INT_VECTOR(DMA2_Stream4_IRQHandler) +INT_VECTOR(ETH_IRQHandler) +INT_VECTOR(ETH_WKUP_IRQHandler) +INT_VECTOR(CAN2_TX_IRQHandler) +INT_VECTOR(CAN2_RX0_IRQHandler) +INT_VECTOR(CAN2_RX1_IRQHandler) +INT_VECTOR(CAN2_SCE_IRQHandler) +INT_VECTOR(OTG_FS_IRQHandler) +INT_VECTOR(DMA2_Stream5_IRQHandler) +INT_VECTOR(DMA2_Stream6_IRQHandler) +INT_VECTOR(DMA2_Stream7_IRQHandler) +INT_VECTOR(USART6_IRQHandler) +INT_VECTOR(I2C3_EV_IRQHandler) +INT_VECTOR(I2C3_ER_IRQHandler) +INT_VECTOR(OTG_HS_EP1_OUT_IRQHandler) +INT_VECTOR(OTG_HS_EP1_IN_IRQHandler) +INT_VECTOR(OTG_HS_WKUP_IRQHandler) +INT_VECTOR(OTG_HS_IRQHandler) +INT_VECTOR(DCMI_IRQHandler) +INT_VECTOR_UNUSED(0) +INT_VECTOR(RNG_IRQHandler) +INT_VECTOR(FPU_IRQHandler) +INT_VECTOR(UART7_IRQHandler) +INT_VECTOR(UART8_IRQHandler) +INT_VECTOR(SPI4_IRQHandler) +INT_VECTOR(SPI5_IRQHandler) +INT_VECTOR(SPI6_IRQHandler) +INT_VECTOR(SAI1_IRQHandler) +INT_VECTOR(LTDC_IRQHandler) +INT_VECTOR(LTDC_ER_IRQHandler) +INT_VECTOR(DMA2D_IRQHandler) +INT_VECTOR(SAI2_IRQHandler) +INT_VECTOR(QUADSPI_IRQHandler) +INT_VECTOR(LPTIM1_IRQHandler) +INT_VECTOR(CEC_IRQHandler) +INT_VECTOR(I2C4_EV_IRQHandler) +INT_VECTOR(I2C4_ER_IRQHandler) +INT_VECTOR(SPDIF_RX_IRQHandler) diff --git a/hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f750xx_vectors.h b/hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f750xx_vectors.h new file mode 100644 index 0000000000..5d1891d32f --- /dev/null +++ b/hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f750xx_vectors.h @@ -0,0 +1,133 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance + * with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +INT_VECTOR_STACK_TOP(__StackTop) +INT_VECTOR_RESET_HANDLER(Reset_Handler) +INT_VECTOR_NMI_HANDLER(NMI_Handler) +INT_VECTOR_HARDFAULT_HANDLER(HardFault_Handler) +INT_VECTOR_MEMMANAGE_HANDLER(MemManage_Handler) +INT_VECTOR_BUSFAULT_HANDLER(BusFault_Handler) +INT_VECTOR_USAGEFAULT_HANDLER(UsageFault_Handler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_SVC_HANDLER(SVC_Handler) +INT_VECTOR_DEBUGMON_HANDLER(DebugMon_Handler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_PENDSV_HANDLER(PendSV_Handler) +INT_VECTOR_SYSTICK_HANDLER(SysTick_Handler) +INT_VECTOR(WWDG_IRQHandler) +INT_VECTOR(PVD_IRQHandler) +INT_VECTOR(TAMP_STAMP_IRQHandler) +INT_VECTOR(RTC_WKUP_IRQHandler) +INT_VECTOR(FLASH_IRQHandler) +INT_VECTOR(RCC_IRQHandler) +INT_VECTOR(EXTI0_IRQHandler) +INT_VECTOR(EXTI1_IRQHandler) +INT_VECTOR(EXTI2_IRQHandler) +INT_VECTOR(EXTI3_IRQHandler) +INT_VECTOR(EXTI4_IRQHandler) +INT_VECTOR(DMA1_Stream0_IRQHandler) +INT_VECTOR(DMA1_Stream1_IRQHandler) +INT_VECTOR(DMA1_Stream2_IRQHandler) +INT_VECTOR(DMA1_Stream3_IRQHandler) +INT_VECTOR(DMA1_Stream4_IRQHandler) +INT_VECTOR(DMA1_Stream5_IRQHandler) +INT_VECTOR(DMA1_Stream6_IRQHandler) +INT_VECTOR(ADC_IRQHandler) +INT_VECTOR(CAN1_TX_IRQHandler) +INT_VECTOR(CAN1_RX0_IRQHandler) +INT_VECTOR(CAN1_RX1_IRQHandler) +INT_VECTOR(CAN1_SCE_IRQHandler) +INT_VECTOR(EXTI9_5_IRQHandler) +INT_VECTOR(TIM1_BRK_TIM9_IRQHandler) +INT_VECTOR(TIM1_UP_TIM10_IRQHandler) +INT_VECTOR(TIM1_TRG_COM_TIM11_IRQHandler) +INT_VECTOR(TIM1_CC_IRQHandler) +INT_VECTOR(TIM2_IRQHandler) +INT_VECTOR(TIM3_IRQHandler) +INT_VECTOR(TIM4_IRQHandler) +INT_VECTOR(I2C1_EV_IRQHandler) +INT_VECTOR(I2C1_ER_IRQHandler) +INT_VECTOR(I2C2_EV_IRQHandler) +INT_VECTOR(I2C2_ER_IRQHandler) +INT_VECTOR(SPI1_IRQHandler) +INT_VECTOR(SPI2_IRQHandler) +INT_VECTOR(USART1_IRQHandler) +INT_VECTOR(USART2_IRQHandler) +INT_VECTOR(USART3_IRQHandler) +INT_VECTOR(EXTI15_10_IRQHandler) +INT_VECTOR(RTC_Alarm_IRQHandler) +INT_VECTOR(OTG_FS_WKUP_IRQHandler) +INT_VECTOR(TIM8_BRK_TIM12_IRQHandler) +INT_VECTOR(TIM8_UP_TIM13_IRQHandler) +INT_VECTOR(TIM8_TRG_COM_TIM14_IRQHandler) +INT_VECTOR(TIM8_CC_IRQHandler) +INT_VECTOR(DMA1_Stream7_IRQHandler) +INT_VECTOR(FMC_IRQHandler) +INT_VECTOR(SDMMC1_IRQHandler) +INT_VECTOR(TIM5_IRQHandler) +INT_VECTOR(SPI3_IRQHandler) +INT_VECTOR(UART4_IRQHandler) +INT_VECTOR(UART5_IRQHandler) +INT_VECTOR(TIM6_DAC_IRQHandler) +INT_VECTOR(TIM7_IRQHandler) +INT_VECTOR(DMA2_Stream0_IRQHandler) +INT_VECTOR(DMA2_Stream1_IRQHandler) +INT_VECTOR(DMA2_Stream2_IRQHandler) +INT_VECTOR(DMA2_Stream3_IRQHandler) +INT_VECTOR(DMA2_Stream4_IRQHandler) +INT_VECTOR(ETH_IRQHandler) +INT_VECTOR(ETH_WKUP_IRQHandler) +INT_VECTOR(CAN2_TX_IRQHandler) +INT_VECTOR(CAN2_RX0_IRQHandler) +INT_VECTOR(CAN2_RX1_IRQHandler) +INT_VECTOR(CAN2_SCE_IRQHandler) +INT_VECTOR(OTG_FS_IRQHandler) +INT_VECTOR(DMA2_Stream5_IRQHandler) +INT_VECTOR(DMA2_Stream6_IRQHandler) +INT_VECTOR(DMA2_Stream7_IRQHandler) +INT_VECTOR(USART6_IRQHandler) +INT_VECTOR(I2C3_EV_IRQHandler) +INT_VECTOR(I2C3_ER_IRQHandler) +INT_VECTOR(OTG_HS_EP1_OUT_IRQHandler) +INT_VECTOR(OTG_HS_EP1_IN_IRQHandler) +INT_VECTOR(OTG_HS_WKUP_IRQHandler) +INT_VECTOR(OTG_HS_IRQHandler) +INT_VECTOR(DCMI_IRQHandler) +INT_VECTOR(CRYP_IRQHandler) +INT_VECTOR(HASH_RNG_IRQHandler) +INT_VECTOR(FPU_IRQHandler) +INT_VECTOR(UART7_IRQHandler) +INT_VECTOR(UART8_IRQHandler) +INT_VECTOR(SPI4_IRQHandler) +INT_VECTOR(SPI5_IRQHandler) +INT_VECTOR(SPI6_IRQHandler) +INT_VECTOR(SAI1_IRQHandler) +INT_VECTOR(LTDC_IRQHandler) +INT_VECTOR(LTDC_ER_IRQHandler) +INT_VECTOR(DMA2D_IRQHandler) +INT_VECTOR(SAI2_IRQHandler) +INT_VECTOR(QUADSPI_IRQHandler) +INT_VECTOR(LPTIM1_IRQHandler) +INT_VECTOR(CEC_IRQHandler) +INT_VECTOR(I2C4_EV_IRQHandler) +INT_VECTOR(I2C4_ER_IRQHandler) +INT_VECTOR(SPDIF_RX_IRQHandler) diff --git a/hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f756xx_vectors.h b/hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f756xx_vectors.h new file mode 100644 index 0000000000..5d1891d32f --- /dev/null +++ b/hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f756xx_vectors.h @@ -0,0 +1,133 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance + * with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +INT_VECTOR_STACK_TOP(__StackTop) +INT_VECTOR_RESET_HANDLER(Reset_Handler) +INT_VECTOR_NMI_HANDLER(NMI_Handler) +INT_VECTOR_HARDFAULT_HANDLER(HardFault_Handler) +INT_VECTOR_MEMMANAGE_HANDLER(MemManage_Handler) +INT_VECTOR_BUSFAULT_HANDLER(BusFault_Handler) +INT_VECTOR_USAGEFAULT_HANDLER(UsageFault_Handler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_SVC_HANDLER(SVC_Handler) +INT_VECTOR_DEBUGMON_HANDLER(DebugMon_Handler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_PENDSV_HANDLER(PendSV_Handler) +INT_VECTOR_SYSTICK_HANDLER(SysTick_Handler) +INT_VECTOR(WWDG_IRQHandler) +INT_VECTOR(PVD_IRQHandler) +INT_VECTOR(TAMP_STAMP_IRQHandler) +INT_VECTOR(RTC_WKUP_IRQHandler) +INT_VECTOR(FLASH_IRQHandler) +INT_VECTOR(RCC_IRQHandler) +INT_VECTOR(EXTI0_IRQHandler) +INT_VECTOR(EXTI1_IRQHandler) +INT_VECTOR(EXTI2_IRQHandler) +INT_VECTOR(EXTI3_IRQHandler) +INT_VECTOR(EXTI4_IRQHandler) +INT_VECTOR(DMA1_Stream0_IRQHandler) +INT_VECTOR(DMA1_Stream1_IRQHandler) +INT_VECTOR(DMA1_Stream2_IRQHandler) +INT_VECTOR(DMA1_Stream3_IRQHandler) +INT_VECTOR(DMA1_Stream4_IRQHandler) +INT_VECTOR(DMA1_Stream5_IRQHandler) +INT_VECTOR(DMA1_Stream6_IRQHandler) +INT_VECTOR(ADC_IRQHandler) +INT_VECTOR(CAN1_TX_IRQHandler) +INT_VECTOR(CAN1_RX0_IRQHandler) +INT_VECTOR(CAN1_RX1_IRQHandler) +INT_VECTOR(CAN1_SCE_IRQHandler) +INT_VECTOR(EXTI9_5_IRQHandler) +INT_VECTOR(TIM1_BRK_TIM9_IRQHandler) +INT_VECTOR(TIM1_UP_TIM10_IRQHandler) +INT_VECTOR(TIM1_TRG_COM_TIM11_IRQHandler) +INT_VECTOR(TIM1_CC_IRQHandler) +INT_VECTOR(TIM2_IRQHandler) +INT_VECTOR(TIM3_IRQHandler) +INT_VECTOR(TIM4_IRQHandler) +INT_VECTOR(I2C1_EV_IRQHandler) +INT_VECTOR(I2C1_ER_IRQHandler) +INT_VECTOR(I2C2_EV_IRQHandler) +INT_VECTOR(I2C2_ER_IRQHandler) +INT_VECTOR(SPI1_IRQHandler) +INT_VECTOR(SPI2_IRQHandler) +INT_VECTOR(USART1_IRQHandler) +INT_VECTOR(USART2_IRQHandler) +INT_VECTOR(USART3_IRQHandler) +INT_VECTOR(EXTI15_10_IRQHandler) +INT_VECTOR(RTC_Alarm_IRQHandler) +INT_VECTOR(OTG_FS_WKUP_IRQHandler) +INT_VECTOR(TIM8_BRK_TIM12_IRQHandler) +INT_VECTOR(TIM8_UP_TIM13_IRQHandler) +INT_VECTOR(TIM8_TRG_COM_TIM14_IRQHandler) +INT_VECTOR(TIM8_CC_IRQHandler) +INT_VECTOR(DMA1_Stream7_IRQHandler) +INT_VECTOR(FMC_IRQHandler) +INT_VECTOR(SDMMC1_IRQHandler) +INT_VECTOR(TIM5_IRQHandler) +INT_VECTOR(SPI3_IRQHandler) +INT_VECTOR(UART4_IRQHandler) +INT_VECTOR(UART5_IRQHandler) +INT_VECTOR(TIM6_DAC_IRQHandler) +INT_VECTOR(TIM7_IRQHandler) +INT_VECTOR(DMA2_Stream0_IRQHandler) +INT_VECTOR(DMA2_Stream1_IRQHandler) +INT_VECTOR(DMA2_Stream2_IRQHandler) +INT_VECTOR(DMA2_Stream3_IRQHandler) +INT_VECTOR(DMA2_Stream4_IRQHandler) +INT_VECTOR(ETH_IRQHandler) +INT_VECTOR(ETH_WKUP_IRQHandler) +INT_VECTOR(CAN2_TX_IRQHandler) +INT_VECTOR(CAN2_RX0_IRQHandler) +INT_VECTOR(CAN2_RX1_IRQHandler) +INT_VECTOR(CAN2_SCE_IRQHandler) +INT_VECTOR(OTG_FS_IRQHandler) +INT_VECTOR(DMA2_Stream5_IRQHandler) +INT_VECTOR(DMA2_Stream6_IRQHandler) +INT_VECTOR(DMA2_Stream7_IRQHandler) +INT_VECTOR(USART6_IRQHandler) +INT_VECTOR(I2C3_EV_IRQHandler) +INT_VECTOR(I2C3_ER_IRQHandler) +INT_VECTOR(OTG_HS_EP1_OUT_IRQHandler) +INT_VECTOR(OTG_HS_EP1_IN_IRQHandler) +INT_VECTOR(OTG_HS_WKUP_IRQHandler) +INT_VECTOR(OTG_HS_IRQHandler) +INT_VECTOR(DCMI_IRQHandler) +INT_VECTOR(CRYP_IRQHandler) +INT_VECTOR(HASH_RNG_IRQHandler) +INT_VECTOR(FPU_IRQHandler) +INT_VECTOR(UART7_IRQHandler) +INT_VECTOR(UART8_IRQHandler) +INT_VECTOR(SPI4_IRQHandler) +INT_VECTOR(SPI5_IRQHandler) +INT_VECTOR(SPI6_IRQHandler) +INT_VECTOR(SAI1_IRQHandler) +INT_VECTOR(LTDC_IRQHandler) +INT_VECTOR(LTDC_ER_IRQHandler) +INT_VECTOR(DMA2D_IRQHandler) +INT_VECTOR(SAI2_IRQHandler) +INT_VECTOR(QUADSPI_IRQHandler) +INT_VECTOR(LPTIM1_IRQHandler) +INT_VECTOR(CEC_IRQHandler) +INT_VECTOR(I2C4_EV_IRQHandler) +INT_VECTOR(I2C4_ER_IRQHandler) +INT_VECTOR(SPDIF_RX_IRQHandler) diff --git a/hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f765xx_vectors.h b/hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f765xx_vectors.h new file mode 100644 index 0000000000..ae9015c10a --- /dev/null +++ b/hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f765xx_vectors.h @@ -0,0 +1,145 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance + * with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +INT_VECTOR_STACK_TOP(__StackTop) +INT_VECTOR_RESET_HANDLER(Reset_Handler) +INT_VECTOR_NMI_HANDLER(NMI_Handler) +INT_VECTOR_HARDFAULT_HANDLER(HardFault_Handler) +INT_VECTOR_MEMMANAGE_HANDLER(MemManage_Handler) +INT_VECTOR_BUSFAULT_HANDLER(BusFault_Handler) +INT_VECTOR_USAGEFAULT_HANDLER(UsageFault_Handler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_SVC_HANDLER(SVC_Handler) +INT_VECTOR_DEBUGMON_HANDLER(DebugMon_Handler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_PENDSV_HANDLER(PendSV_Handler) +INT_VECTOR_SYSTICK_HANDLER(SysTick_Handler) +INT_VECTOR(WWDG_IRQHandler) +INT_VECTOR(PVD_IRQHandler) +INT_VECTOR(TAMP_STAMP_IRQHandler) +INT_VECTOR(RTC_WKUP_IRQHandler) +INT_VECTOR(FLASH_IRQHandler) +INT_VECTOR(RCC_IRQHandler) +INT_VECTOR(EXTI0_IRQHandler) +INT_VECTOR(EXTI1_IRQHandler) +INT_VECTOR(EXTI2_IRQHandler) +INT_VECTOR(EXTI3_IRQHandler) +INT_VECTOR(EXTI4_IRQHandler) +INT_VECTOR(DMA1_Stream0_IRQHandler) +INT_VECTOR(DMA1_Stream1_IRQHandler) +INT_VECTOR(DMA1_Stream2_IRQHandler) +INT_VECTOR(DMA1_Stream3_IRQHandler) +INT_VECTOR(DMA1_Stream4_IRQHandler) +INT_VECTOR(DMA1_Stream5_IRQHandler) +INT_VECTOR(DMA1_Stream6_IRQHandler) +INT_VECTOR(ADC_IRQHandler) +INT_VECTOR(CAN1_TX_IRQHandler) +INT_VECTOR(CAN1_RX0_IRQHandler) +INT_VECTOR(CAN1_RX1_IRQHandler) +INT_VECTOR(CAN1_SCE_IRQHandler) +INT_VECTOR(EXTI9_5_IRQHandler) +INT_VECTOR(TIM1_BRK_TIM9_IRQHandler) +INT_VECTOR(TIM1_UP_TIM10_IRQHandler) +INT_VECTOR(TIM1_TRG_COM_TIM11_IRQHandler) +INT_VECTOR(TIM1_CC_IRQHandler) +INT_VECTOR(TIM2_IRQHandler) +INT_VECTOR(TIM3_IRQHandler) +INT_VECTOR(TIM4_IRQHandler) +INT_VECTOR(I2C1_EV_IRQHandler) +INT_VECTOR(I2C1_ER_IRQHandler) +INT_VECTOR(I2C2_EV_IRQHandler) +INT_VECTOR(I2C2_ER_IRQHandler) +INT_VECTOR(SPI1_IRQHandler) +INT_VECTOR(SPI2_IRQHandler) +INT_VECTOR(USART1_IRQHandler) +INT_VECTOR(USART2_IRQHandler) +INT_VECTOR(USART3_IRQHandler) +INT_VECTOR(EXTI15_10_IRQHandler) +INT_VECTOR(RTC_Alarm_IRQHandler) +INT_VECTOR(OTG_FS_WKUP_IRQHandler) +INT_VECTOR(TIM8_BRK_TIM12_IRQHandler) +INT_VECTOR(TIM8_UP_TIM13_IRQHandler) +INT_VECTOR(TIM8_TRG_COM_TIM14_IRQHandler) +INT_VECTOR(TIM8_CC_IRQHandler) +INT_VECTOR(DMA1_Stream7_IRQHandler) +INT_VECTOR(FMC_IRQHandler) +INT_VECTOR(SDMMC1_IRQHandler) +INT_VECTOR(TIM5_IRQHandler) +INT_VECTOR(SPI3_IRQHandler) +INT_VECTOR(UART4_IRQHandler) +INT_VECTOR(UART5_IRQHandler) +INT_VECTOR(TIM6_DAC_IRQHandler) +INT_VECTOR(TIM7_IRQHandler) +INT_VECTOR(DMA2_Stream0_IRQHandler) +INT_VECTOR(DMA2_Stream1_IRQHandler) +INT_VECTOR(DMA2_Stream2_IRQHandler) +INT_VECTOR(DMA2_Stream3_IRQHandler) +INT_VECTOR(DMA2_Stream4_IRQHandler) +INT_VECTOR(ETH_IRQHandler) +INT_VECTOR(ETH_WKUP_IRQHandler) +INT_VECTOR(CAN2_TX_IRQHandler) +INT_VECTOR(CAN2_RX0_IRQHandler) +INT_VECTOR(CAN2_RX1_IRQHandler) +INT_VECTOR(CAN2_SCE_IRQHandler) +INT_VECTOR(OTG_FS_IRQHandler) +INT_VECTOR(DMA2_Stream5_IRQHandler) +INT_VECTOR(DMA2_Stream6_IRQHandler) +INT_VECTOR(DMA2_Stream7_IRQHandler) +INT_VECTOR(USART6_IRQHandler) +INT_VECTOR(I2C3_EV_IRQHandler) +INT_VECTOR(I2C3_ER_IRQHandler) +INT_VECTOR(OTG_HS_EP1_OUT_IRQHandler) +INT_VECTOR(OTG_HS_EP1_IN_IRQHandler) +INT_VECTOR(OTG_HS_WKUP_IRQHandler) +INT_VECTOR(OTG_HS_IRQHandler) +INT_VECTOR(DCMI_IRQHandler) +INT_VECTOR_UNUSED(0) +INT_VECTOR(RNG_IRQHandler) +INT_VECTOR(FPU_IRQHandler) +INT_VECTOR(UART7_IRQHandler) +INT_VECTOR(UART8_IRQHandler) +INT_VECTOR(SPI4_IRQHandler) +INT_VECTOR(SPI5_IRQHandler) +INT_VECTOR(SPI6_IRQHandler) +INT_VECTOR(SAI1_IRQHandler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR(DMA2D_IRQHandler) +INT_VECTOR(SAI2_IRQHandler) +INT_VECTOR(QUADSPI_IRQHandler) +INT_VECTOR(LPTIM1_IRQHandler) +INT_VECTOR(CEC_IRQHandler) +INT_VECTOR(I2C4_EV_IRQHandler) +INT_VECTOR(I2C4_ER_IRQHandler) +INT_VECTOR(SPDIF_RX_IRQHandler) +INT_VECTOR_UNUSED(0) +INT_VECTOR(DFSDM1_FLT0_IRQHandler) +INT_VECTOR(DFSDM1_FLT1_IRQHandler) +INT_VECTOR(DFSDM1_FLT2_IRQHandler) +INT_VECTOR(DFSDM1_FLT3_IRQHandler) +INT_VECTOR(SDMMC2_IRQHandler) +INT_VECTOR(CAN3_TX_IRQHandler) +INT_VECTOR(CAN3_RX0_IRQHandler) +INT_VECTOR(CAN3_RX1_IRQHandler) +INT_VECTOR(CAN3_SCE_IRQHandler) +INT_VECTOR_UNUSED(0) +INT_VECTOR(MDIOS_IRQHandler) diff --git a/hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f767xx_vectors.h b/hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f767xx_vectors.h new file mode 100644 index 0000000000..48ac9b9ef1 --- /dev/null +++ b/hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f767xx_vectors.h @@ -0,0 +1,145 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance + * with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +INT_VECTOR_STACK_TOP(__StackTop) +INT_VECTOR_RESET_HANDLER(Reset_Handler) +INT_VECTOR_NMI_HANDLER(NMI_Handler) +INT_VECTOR_HARDFAULT_HANDLER(HardFault_Handler) +INT_VECTOR_MEMMANAGE_HANDLER(MemManage_Handler) +INT_VECTOR_BUSFAULT_HANDLER(BusFault_Handler) +INT_VECTOR_USAGEFAULT_HANDLER(UsageFault_Handler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_SVC_HANDLER(SVC_Handler) +INT_VECTOR_DEBUGMON_HANDLER(DebugMon_Handler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_PENDSV_HANDLER(PendSV_Handler) +INT_VECTOR_SYSTICK_HANDLER(SysTick_Handler) +INT_VECTOR(WWDG_IRQHandler) +INT_VECTOR(PVD_IRQHandler) +INT_VECTOR(TAMP_STAMP_IRQHandler) +INT_VECTOR(RTC_WKUP_IRQHandler) +INT_VECTOR(FLASH_IRQHandler) +INT_VECTOR(RCC_IRQHandler) +INT_VECTOR(EXTI0_IRQHandler) +INT_VECTOR(EXTI1_IRQHandler) +INT_VECTOR(EXTI2_IRQHandler) +INT_VECTOR(EXTI3_IRQHandler) +INT_VECTOR(EXTI4_IRQHandler) +INT_VECTOR(DMA1_Stream0_IRQHandler) +INT_VECTOR(DMA1_Stream1_IRQHandler) +INT_VECTOR(DMA1_Stream2_IRQHandler) +INT_VECTOR(DMA1_Stream3_IRQHandler) +INT_VECTOR(DMA1_Stream4_IRQHandler) +INT_VECTOR(DMA1_Stream5_IRQHandler) +INT_VECTOR(DMA1_Stream6_IRQHandler) +INT_VECTOR(ADC_IRQHandler) +INT_VECTOR(CAN1_TX_IRQHandler) +INT_VECTOR(CAN1_RX0_IRQHandler) +INT_VECTOR(CAN1_RX1_IRQHandler) +INT_VECTOR(CAN1_SCE_IRQHandler) +INT_VECTOR(EXTI9_5_IRQHandler) +INT_VECTOR(TIM1_BRK_TIM9_IRQHandler) +INT_VECTOR(TIM1_UP_TIM10_IRQHandler) +INT_VECTOR(TIM1_TRG_COM_TIM11_IRQHandler) +INT_VECTOR(TIM1_CC_IRQHandler) +INT_VECTOR(TIM2_IRQHandler) +INT_VECTOR(TIM3_IRQHandler) +INT_VECTOR(TIM4_IRQHandler) +INT_VECTOR(I2C1_EV_IRQHandler) +INT_VECTOR(I2C1_ER_IRQHandler) +INT_VECTOR(I2C2_EV_IRQHandler) +INT_VECTOR(I2C2_ER_IRQHandler) +INT_VECTOR(SPI1_IRQHandler) +INT_VECTOR(SPI2_IRQHandler) +INT_VECTOR(USART1_IRQHandler) +INT_VECTOR(USART2_IRQHandler) +INT_VECTOR(USART3_IRQHandler) +INT_VECTOR(EXTI15_10_IRQHandler) +INT_VECTOR(RTC_Alarm_IRQHandler) +INT_VECTOR(OTG_FS_WKUP_IRQHandler) +INT_VECTOR(TIM8_BRK_TIM12_IRQHandler) +INT_VECTOR(TIM8_UP_TIM13_IRQHandler) +INT_VECTOR(TIM8_TRG_COM_TIM14_IRQHandler) +INT_VECTOR(TIM8_CC_IRQHandler) +INT_VECTOR(DMA1_Stream7_IRQHandler) +INT_VECTOR(FMC_IRQHandler) +INT_VECTOR(SDMMC1_IRQHandler) +INT_VECTOR(TIM5_IRQHandler) +INT_VECTOR(SPI3_IRQHandler) +INT_VECTOR(UART4_IRQHandler) +INT_VECTOR(UART5_IRQHandler) +INT_VECTOR(TIM6_DAC_IRQHandler) +INT_VECTOR(TIM7_IRQHandler) +INT_VECTOR(DMA2_Stream0_IRQHandler) +INT_VECTOR(DMA2_Stream1_IRQHandler) +INT_VECTOR(DMA2_Stream2_IRQHandler) +INT_VECTOR(DMA2_Stream3_IRQHandler) +INT_VECTOR(DMA2_Stream4_IRQHandler) +INT_VECTOR(ETH_IRQHandler) +INT_VECTOR(ETH_WKUP_IRQHandler) +INT_VECTOR(CAN2_TX_IRQHandler) +INT_VECTOR(CAN2_RX0_IRQHandler) +INT_VECTOR(CAN2_RX1_IRQHandler) +INT_VECTOR(CAN2_SCE_IRQHandler) +INT_VECTOR(OTG_FS_IRQHandler) +INT_VECTOR(DMA2_Stream5_IRQHandler) +INT_VECTOR(DMA2_Stream6_IRQHandler) +INT_VECTOR(DMA2_Stream7_IRQHandler) +INT_VECTOR(USART6_IRQHandler) +INT_VECTOR(I2C3_EV_IRQHandler) +INT_VECTOR(I2C3_ER_IRQHandler) +INT_VECTOR(OTG_HS_EP1_OUT_IRQHandler) +INT_VECTOR(OTG_HS_EP1_IN_IRQHandler) +INT_VECTOR(OTG_HS_WKUP_IRQHandler) +INT_VECTOR(OTG_HS_IRQHandler) +INT_VECTOR(DCMI_IRQHandler) +INT_VECTOR_UNUSED(0) +INT_VECTOR(RNG_IRQHandler) +INT_VECTOR(FPU_IRQHandler) +INT_VECTOR(UART7_IRQHandler) +INT_VECTOR(UART8_IRQHandler) +INT_VECTOR(SPI4_IRQHandler) +INT_VECTOR(SPI5_IRQHandler) +INT_VECTOR(SPI6_IRQHandler) +INT_VECTOR(SAI1_IRQHandler) +INT_VECTOR(LTDC_IRQHandler) +INT_VECTOR(LTDC_ER_IRQHandler) +INT_VECTOR(DMA2D_IRQHandler) +INT_VECTOR(SAI2_IRQHandler) +INT_VECTOR(QUADSPI_IRQHandler) +INT_VECTOR(LPTIM1_IRQHandler) +INT_VECTOR(CEC_IRQHandler) +INT_VECTOR(I2C4_EV_IRQHandler) +INT_VECTOR(I2C4_ER_IRQHandler) +INT_VECTOR(SPDIF_RX_IRQHandler) +INT_VECTOR_UNUSED(0) +INT_VECTOR(DFSDM1_FLT0_IRQHandler) +INT_VECTOR(DFSDM1_FLT1_IRQHandler) +INT_VECTOR(DFSDM1_FLT2_IRQHandler) +INT_VECTOR(DFSDM1_FLT3_IRQHandler) +INT_VECTOR(SDMMC2_IRQHandler) +INT_VECTOR(CAN3_TX_IRQHandler) +INT_VECTOR(CAN3_RX0_IRQHandler) +INT_VECTOR(CAN3_RX1_IRQHandler) +INT_VECTOR(CAN3_SCE_IRQHandler) +INT_VECTOR(JPEG_IRQHandler) +INT_VECTOR(MDIOS_IRQHandler) diff --git a/hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f769xx_vectors.h b/hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f769xx_vectors.h new file mode 100644 index 0000000000..0a2ae617bd --- /dev/null +++ b/hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f769xx_vectors.h @@ -0,0 +1,145 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance + * with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +INT_VECTOR_STACK_TOP(__StackTop) +INT_VECTOR_RESET_HANDLER(Reset_Handler) +INT_VECTOR_NMI_HANDLER(NMI_Handler) +INT_VECTOR_HARDFAULT_HANDLER(HardFault_Handler) +INT_VECTOR_MEMMANAGE_HANDLER(MemManage_Handler) +INT_VECTOR_BUSFAULT_HANDLER(BusFault_Handler) +INT_VECTOR_USAGEFAULT_HANDLER(UsageFault_Handler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_SVC_HANDLER(SVC_Handler) +INT_VECTOR_DEBUGMON_HANDLER(DebugMon_Handler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_PENDSV_HANDLER(PendSV_Handler) +INT_VECTOR_SYSTICK_HANDLER(SysTick_Handler) +INT_VECTOR(WWDG_IRQHandler) +INT_VECTOR(PVD_IRQHandler) +INT_VECTOR(TAMP_STAMP_IRQHandler) +INT_VECTOR(RTC_WKUP_IRQHandler) +INT_VECTOR(FLASH_IRQHandler) +INT_VECTOR(RCC_IRQHandler) +INT_VECTOR(EXTI0_IRQHandler) +INT_VECTOR(EXTI1_IRQHandler) +INT_VECTOR(EXTI2_IRQHandler) +INT_VECTOR(EXTI3_IRQHandler) +INT_VECTOR(EXTI4_IRQHandler) +INT_VECTOR(DMA1_Stream0_IRQHandler) +INT_VECTOR(DMA1_Stream1_IRQHandler) +INT_VECTOR(DMA1_Stream2_IRQHandler) +INT_VECTOR(DMA1_Stream3_IRQHandler) +INT_VECTOR(DMA1_Stream4_IRQHandler) +INT_VECTOR(DMA1_Stream5_IRQHandler) +INT_VECTOR(DMA1_Stream6_IRQHandler) +INT_VECTOR(ADC_IRQHandler) +INT_VECTOR(CAN1_TX_IRQHandler) +INT_VECTOR(CAN1_RX0_IRQHandler) +INT_VECTOR(CAN1_RX1_IRQHandler) +INT_VECTOR(CAN1_SCE_IRQHandler) +INT_VECTOR(EXTI9_5_IRQHandler) +INT_VECTOR(TIM1_BRK_TIM9_IRQHandler) +INT_VECTOR(TIM1_UP_TIM10_IRQHandler) +INT_VECTOR(TIM1_TRG_COM_TIM11_IRQHandler) +INT_VECTOR(TIM1_CC_IRQHandler) +INT_VECTOR(TIM2_IRQHandler) +INT_VECTOR(TIM3_IRQHandler) +INT_VECTOR(TIM4_IRQHandler) +INT_VECTOR(I2C1_EV_IRQHandler) +INT_VECTOR(I2C1_ER_IRQHandler) +INT_VECTOR(I2C2_EV_IRQHandler) +INT_VECTOR(I2C2_ER_IRQHandler) +INT_VECTOR(SPI1_IRQHandler) +INT_VECTOR(SPI2_IRQHandler) +INT_VECTOR(USART1_IRQHandler) +INT_VECTOR(USART2_IRQHandler) +INT_VECTOR(USART3_IRQHandler) +INT_VECTOR(EXTI15_10_IRQHandler) +INT_VECTOR(RTC_Alarm_IRQHandler) +INT_VECTOR(OTG_FS_WKUP_IRQHandler) +INT_VECTOR(TIM8_BRK_TIM12_IRQHandler) +INT_VECTOR(TIM8_UP_TIM13_IRQHandler) +INT_VECTOR(TIM8_TRG_COM_TIM14_IRQHandler) +INT_VECTOR(TIM8_CC_IRQHandler) +INT_VECTOR(DMA1_Stream7_IRQHandler) +INT_VECTOR(FMC_IRQHandler) +INT_VECTOR(SDMMC1_IRQHandler) +INT_VECTOR(TIM5_IRQHandler) +INT_VECTOR(SPI3_IRQHandler) +INT_VECTOR(UART4_IRQHandler) +INT_VECTOR(UART5_IRQHandler) +INT_VECTOR(TIM6_DAC_IRQHandler) +INT_VECTOR(TIM7_IRQHandler) +INT_VECTOR(DMA2_Stream0_IRQHandler) +INT_VECTOR(DMA2_Stream1_IRQHandler) +INT_VECTOR(DMA2_Stream2_IRQHandler) +INT_VECTOR(DMA2_Stream3_IRQHandler) +INT_VECTOR(DMA2_Stream4_IRQHandler) +INT_VECTOR(ETH_IRQHandler) +INT_VECTOR(ETH_WKUP_IRQHandler) +INT_VECTOR(CAN2_TX_IRQHandler) +INT_VECTOR(CAN2_RX0_IRQHandler) +INT_VECTOR(CAN2_RX1_IRQHandler) +INT_VECTOR(CAN2_SCE_IRQHandler) +INT_VECTOR(OTG_FS_IRQHandler) +INT_VECTOR(DMA2_Stream5_IRQHandler) +INT_VECTOR(DMA2_Stream6_IRQHandler) +INT_VECTOR(DMA2_Stream7_IRQHandler) +INT_VECTOR(USART6_IRQHandler) +INT_VECTOR(I2C3_EV_IRQHandler) +INT_VECTOR(I2C3_ER_IRQHandler) +INT_VECTOR(OTG_HS_EP1_OUT_IRQHandler) +INT_VECTOR(OTG_HS_EP1_IN_IRQHandler) +INT_VECTOR(OTG_HS_WKUP_IRQHandler) +INT_VECTOR(OTG_HS_IRQHandler) +INT_VECTOR(DCMI_IRQHandler) +INT_VECTOR_UNUSED(0) +INT_VECTOR(RNG_IRQHandler) +INT_VECTOR(FPU_IRQHandler) +INT_VECTOR(UART7_IRQHandler) +INT_VECTOR(UART8_IRQHandler) +INT_VECTOR(SPI4_IRQHandler) +INT_VECTOR(SPI5_IRQHandler) +INT_VECTOR(SPI6_IRQHandler) +INT_VECTOR(SAI1_IRQHandler) +INT_VECTOR(LTDC_IRQHandler) +INT_VECTOR(LTDC_ER_IRQHandler) +INT_VECTOR(DMA2D_IRQHandler) +INT_VECTOR(SAI2_IRQHandler) +INT_VECTOR(QUADSPI_IRQHandler) +INT_VECTOR(LPTIM1_IRQHandler) +INT_VECTOR(CEC_IRQHandler) +INT_VECTOR(I2C4_EV_IRQHandler) +INT_VECTOR(I2C4_ER_IRQHandler) +INT_VECTOR(SPDIF_RX_IRQHandler) +INT_VECTOR(DSI_IRQHandler) +INT_VECTOR(DFSDM1_FLT0_IRQHandler) +INT_VECTOR(DFSDM1_FLT1_IRQHandler) +INT_VECTOR(DFSDM1_FLT2_IRQHandler) +INT_VECTOR(DFSDM1_FLT3_IRQHandler) +INT_VECTOR(SDMMC2_IRQHandler) +INT_VECTOR(CAN3_TX_IRQHandler) +INT_VECTOR(CAN3_RX0_IRQHandler) +INT_VECTOR(CAN3_RX1_IRQHandler) +INT_VECTOR(CAN3_SCE_IRQHandler) +INT_VECTOR(JPEG_IRQHandler) +INT_VECTOR(MDIOS_IRQHandler) diff --git a/hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f777xx_vectors.h b/hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f777xx_vectors.h new file mode 100644 index 0000000000..52a7add2ce --- /dev/null +++ b/hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f777xx_vectors.h @@ -0,0 +1,145 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance + * with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +INT_VECTOR_STACK_TOP(__StackTop) +INT_VECTOR_RESET_HANDLER(Reset_Handler) +INT_VECTOR_NMI_HANDLER(NMI_Handler) +INT_VECTOR_HARDFAULT_HANDLER(HardFault_Handler) +INT_VECTOR_MEMMANAGE_HANDLER(MemManage_Handler) +INT_VECTOR_BUSFAULT_HANDLER(BusFault_Handler) +INT_VECTOR_USAGEFAULT_HANDLER(UsageFault_Handler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_SVC_HANDLER(SVC_Handler) +INT_VECTOR_DEBUGMON_HANDLER(DebugMon_Handler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_PENDSV_HANDLER(PendSV_Handler) +INT_VECTOR_SYSTICK_HANDLER(SysTick_Handler) +INT_VECTOR(WWDG_IRQHandler) +INT_VECTOR(PVD_IRQHandler) +INT_VECTOR(TAMP_STAMP_IRQHandler) +INT_VECTOR(RTC_WKUP_IRQHandler) +INT_VECTOR(FLASH_IRQHandler) +INT_VECTOR(RCC_IRQHandler) +INT_VECTOR(EXTI0_IRQHandler) +INT_VECTOR(EXTI1_IRQHandler) +INT_VECTOR(EXTI2_IRQHandler) +INT_VECTOR(EXTI3_IRQHandler) +INT_VECTOR(EXTI4_IRQHandler) +INT_VECTOR(DMA1_Stream0_IRQHandler) +INT_VECTOR(DMA1_Stream1_IRQHandler) +INT_VECTOR(DMA1_Stream2_IRQHandler) +INT_VECTOR(DMA1_Stream3_IRQHandler) +INT_VECTOR(DMA1_Stream4_IRQHandler) +INT_VECTOR(DMA1_Stream5_IRQHandler) +INT_VECTOR(DMA1_Stream6_IRQHandler) +INT_VECTOR(ADC_IRQHandler) +INT_VECTOR(CAN1_TX_IRQHandler) +INT_VECTOR(CAN1_RX0_IRQHandler) +INT_VECTOR(CAN1_RX1_IRQHandler) +INT_VECTOR(CAN1_SCE_IRQHandler) +INT_VECTOR(EXTI9_5_IRQHandler) +INT_VECTOR(TIM1_BRK_TIM9_IRQHandler) +INT_VECTOR(TIM1_UP_TIM10_IRQHandler) +INT_VECTOR(TIM1_TRG_COM_TIM11_IRQHandler) +INT_VECTOR(TIM1_CC_IRQHandler) +INT_VECTOR(TIM2_IRQHandler) +INT_VECTOR(TIM3_IRQHandler) +INT_VECTOR(TIM4_IRQHandler) +INT_VECTOR(I2C1_EV_IRQHandler) +INT_VECTOR(I2C1_ER_IRQHandler) +INT_VECTOR(I2C2_EV_IRQHandler) +INT_VECTOR(I2C2_ER_IRQHandler) +INT_VECTOR(SPI1_IRQHandler) +INT_VECTOR(SPI2_IRQHandler) +INT_VECTOR(USART1_IRQHandler) +INT_VECTOR(USART2_IRQHandler) +INT_VECTOR(USART3_IRQHandler) +INT_VECTOR(EXTI15_10_IRQHandler) +INT_VECTOR(RTC_Alarm_IRQHandler) +INT_VECTOR(OTG_FS_WKUP_IRQHandler) +INT_VECTOR(TIM8_BRK_TIM12_IRQHandler) +INT_VECTOR(TIM8_UP_TIM13_IRQHandler) +INT_VECTOR(TIM8_TRG_COM_TIM14_IRQHandler) +INT_VECTOR(TIM8_CC_IRQHandler) +INT_VECTOR(DMA1_Stream7_IRQHandler) +INT_VECTOR(FMC_IRQHandler) +INT_VECTOR(SDMMC1_IRQHandler) +INT_VECTOR(TIM5_IRQHandler) +INT_VECTOR(SPI3_IRQHandler) +INT_VECTOR(UART4_IRQHandler) +INT_VECTOR(UART5_IRQHandler) +INT_VECTOR(TIM6_DAC_IRQHandler) +INT_VECTOR(TIM7_IRQHandler) +INT_VECTOR(DMA2_Stream0_IRQHandler) +INT_VECTOR(DMA2_Stream1_IRQHandler) +INT_VECTOR(DMA2_Stream2_IRQHandler) +INT_VECTOR(DMA2_Stream3_IRQHandler) +INT_VECTOR(DMA2_Stream4_IRQHandler) +INT_VECTOR(ETH_IRQHandler) +INT_VECTOR(ETH_WKUP_IRQHandler) +INT_VECTOR(CAN2_TX_IRQHandler) +INT_VECTOR(CAN2_RX0_IRQHandler) +INT_VECTOR(CAN2_RX1_IRQHandler) +INT_VECTOR(CAN2_SCE_IRQHandler) +INT_VECTOR(OTG_FS_IRQHandler) +INT_VECTOR(DMA2_Stream5_IRQHandler) +INT_VECTOR(DMA2_Stream6_IRQHandler) +INT_VECTOR(DMA2_Stream7_IRQHandler) +INT_VECTOR(USART6_IRQHandler) +INT_VECTOR(I2C3_EV_IRQHandler) +INT_VECTOR(I2C3_ER_IRQHandler) +INT_VECTOR(OTG_HS_EP1_OUT_IRQHandler) +INT_VECTOR(OTG_HS_EP1_IN_IRQHandler) +INT_VECTOR(OTG_HS_WKUP_IRQHandler) +INT_VECTOR(OTG_HS_IRQHandler) +INT_VECTOR(DCMI_IRQHandler) +INT_VECTOR(CRYP_IRQHandler) +INT_VECTOR(HASH_RNG_IRQHandler) +INT_VECTOR(FPU_IRQHandler) +INT_VECTOR(UART7_IRQHandler) +INT_VECTOR(UART8_IRQHandler) +INT_VECTOR(SPI4_IRQHandler) +INT_VECTOR(SPI5_IRQHandler) +INT_VECTOR(SPI6_IRQHandler) +INT_VECTOR(SAI1_IRQHandler) +INT_VECTOR(LTDC_IRQHandler) +INT_VECTOR(LTDC_ER_IRQHandler) +INT_VECTOR(DMA2D_IRQHandler) +INT_VECTOR(SAI2_IRQHandler) +INT_VECTOR(QUADSPI_IRQHandler) +INT_VECTOR(LPTIM1_IRQHandler) +INT_VECTOR(CEC_IRQHandler) +INT_VECTOR(I2C4_EV_IRQHandler) +INT_VECTOR(I2C4_ER_IRQHandler) +INT_VECTOR(SPDIF_RX_IRQHandler) +INT_VECTOR_UNUSED(0) +INT_VECTOR(DFSDM1_FLT0_IRQHandler) +INT_VECTOR(DFSDM1_FLT1_IRQHandler) +INT_VECTOR(DFSDM1_FLT2_IRQHandler) +INT_VECTOR(DFSDM1_FLT3_IRQHandler) +INT_VECTOR(SDMMC2_IRQHandler) +INT_VECTOR(CAN3_TX_IRQHandler) +INT_VECTOR(CAN3_RX0_IRQHandler) +INT_VECTOR(CAN3_RX1_IRQHandler) +INT_VECTOR(CAN3_SCE_IRQHandler) +INT_VECTOR(JPEG_IRQHandler) +INT_VECTOR(MDIOS_IRQHandler) diff --git a/hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f779xx_vectors.h b/hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f779xx_vectors.h new file mode 100644 index 0000000000..e9ec1afcc3 --- /dev/null +++ b/hw/mcu/stm/stm32f7xx/include/mcu/vectors/stm32f779xx_vectors.h @@ -0,0 +1,145 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance + * with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +INT_VECTOR_STACK_TOP(__StackTop) +INT_VECTOR_RESET_HANDLER(Reset_Handler) +INT_VECTOR_NMI_HANDLER(NMI_Handler) +INT_VECTOR_HARDFAULT_HANDLER(HardFault_Handler) +INT_VECTOR_MEMMANAGE_HANDLER(MemManage_Handler) +INT_VECTOR_BUSFAULT_HANDLER(BusFault_Handler) +INT_VECTOR_USAGEFAULT_HANDLER(UsageFault_Handler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_UNUSED(0) +INT_VECTOR_SVC_HANDLER(SVC_Handler) +INT_VECTOR_DEBUGMON_HANDLER(DebugMon_Handler) +INT_VECTOR_UNUSED(0) +INT_VECTOR_PENDSV_HANDLER(PendSV_Handler) +INT_VECTOR_SYSTICK_HANDLER(SysTick_Handler) +INT_VECTOR(WWDG_IRQHandler) +INT_VECTOR(PVD_IRQHandler) +INT_VECTOR(TAMP_STAMP_IRQHandler) +INT_VECTOR(RTC_WKUP_IRQHandler) +INT_VECTOR(FLASH_IRQHandler) +INT_VECTOR(RCC_IRQHandler) +INT_VECTOR(EXTI0_IRQHandler) +INT_VECTOR(EXTI1_IRQHandler) +INT_VECTOR(EXTI2_IRQHandler) +INT_VECTOR(EXTI3_IRQHandler) +INT_VECTOR(EXTI4_IRQHandler) +INT_VECTOR(DMA1_Stream0_IRQHandler) +INT_VECTOR(DMA1_Stream1_IRQHandler) +INT_VECTOR(DMA1_Stream2_IRQHandler) +INT_VECTOR(DMA1_Stream3_IRQHandler) +INT_VECTOR(DMA1_Stream4_IRQHandler) +INT_VECTOR(DMA1_Stream5_IRQHandler) +INT_VECTOR(DMA1_Stream6_IRQHandler) +INT_VECTOR(ADC_IRQHandler) +INT_VECTOR(CAN1_TX_IRQHandler) +INT_VECTOR(CAN1_RX0_IRQHandler) +INT_VECTOR(CAN1_RX1_IRQHandler) +INT_VECTOR(CAN1_SCE_IRQHandler) +INT_VECTOR(EXTI9_5_IRQHandler) +INT_VECTOR(TIM1_BRK_TIM9_IRQHandler) +INT_VECTOR(TIM1_UP_TIM10_IRQHandler) +INT_VECTOR(TIM1_TRG_COM_TIM11_IRQHandler) +INT_VECTOR(TIM1_CC_IRQHandler) +INT_VECTOR(TIM2_IRQHandler) +INT_VECTOR(TIM3_IRQHandler) +INT_VECTOR(TIM4_IRQHandler) +INT_VECTOR(I2C1_EV_IRQHandler) +INT_VECTOR(I2C1_ER_IRQHandler) +INT_VECTOR(I2C2_EV_IRQHandler) +INT_VECTOR(I2C2_ER_IRQHandler) +INT_VECTOR(SPI1_IRQHandler) +INT_VECTOR(SPI2_IRQHandler) +INT_VECTOR(USART1_IRQHandler) +INT_VECTOR(USART2_IRQHandler) +INT_VECTOR(USART3_IRQHandler) +INT_VECTOR(EXTI15_10_IRQHandler) +INT_VECTOR(RTC_Alarm_IRQHandler) +INT_VECTOR(OTG_FS_WKUP_IRQHandler) +INT_VECTOR(TIM8_BRK_TIM12_IRQHandler) +INT_VECTOR(TIM8_UP_TIM13_IRQHandler) +INT_VECTOR(TIM8_TRG_COM_TIM14_IRQHandler) +INT_VECTOR(TIM8_CC_IRQHandler) +INT_VECTOR(DMA1_Stream7_IRQHandler) +INT_VECTOR(FMC_IRQHandler) +INT_VECTOR(SDMMC1_IRQHandler) +INT_VECTOR(TIM5_IRQHandler) +INT_VECTOR(SPI3_IRQHandler) +INT_VECTOR(UART4_IRQHandler) +INT_VECTOR(UART5_IRQHandler) +INT_VECTOR(TIM6_DAC_IRQHandler) +INT_VECTOR(TIM7_IRQHandler) +INT_VECTOR(DMA2_Stream0_IRQHandler) +INT_VECTOR(DMA2_Stream1_IRQHandler) +INT_VECTOR(DMA2_Stream2_IRQHandler) +INT_VECTOR(DMA2_Stream3_IRQHandler) +INT_VECTOR(DMA2_Stream4_IRQHandler) +INT_VECTOR(ETH_IRQHandler) +INT_VECTOR(ETH_WKUP_IRQHandler) +INT_VECTOR(CAN2_TX_IRQHandler) +INT_VECTOR(CAN2_RX0_IRQHandler) +INT_VECTOR(CAN2_RX1_IRQHandler) +INT_VECTOR(CAN2_SCE_IRQHandler) +INT_VECTOR(OTG_FS_IRQHandler) +INT_VECTOR(DMA2_Stream5_IRQHandler) +INT_VECTOR(DMA2_Stream6_IRQHandler) +INT_VECTOR(DMA2_Stream7_IRQHandler) +INT_VECTOR(USART6_IRQHandler) +INT_VECTOR(I2C3_EV_IRQHandler) +INT_VECTOR(I2C3_ER_IRQHandler) +INT_VECTOR(OTG_HS_EP1_OUT_IRQHandler) +INT_VECTOR(OTG_HS_EP1_IN_IRQHandler) +INT_VECTOR(OTG_HS_WKUP_IRQHandler) +INT_VECTOR(OTG_HS_IRQHandler) +INT_VECTOR(DCMI_IRQHandler) +INT_VECTOR(CRYP_IRQHandler) +INT_VECTOR(HASH_RNG_IRQHandler) +INT_VECTOR(FPU_IRQHandler) +INT_VECTOR(UART7_IRQHandler) +INT_VECTOR(UART8_IRQHandler) +INT_VECTOR(SPI4_IRQHandler) +INT_VECTOR(SPI5_IRQHandler) +INT_VECTOR(SPI6_IRQHandler) +INT_VECTOR(SAI1_IRQHandler) +INT_VECTOR(LTDC_IRQHandler) +INT_VECTOR(LTDC_ER_IRQHandler) +INT_VECTOR(DMA2D_IRQHandler) +INT_VECTOR(SAI2_IRQHandler) +INT_VECTOR(QUADSPI_IRQHandler) +INT_VECTOR(LPTIM1_IRQHandler) +INT_VECTOR(CEC_IRQHandler) +INT_VECTOR(I2C4_EV_IRQHandler) +INT_VECTOR(I2C4_ER_IRQHandler) +INT_VECTOR(SPDIF_RX_IRQHandler) +INT_VECTOR(DSI_IRQHandler) +INT_VECTOR(DFSDM1_FLT0_IRQHandler) +INT_VECTOR(DFSDM1_FLT1_IRQHandler) +INT_VECTOR(DFSDM1_FLT2_IRQHandler) +INT_VECTOR(DFSDM1_FLT3_IRQHandler) +INT_VECTOR(SDMMC2_IRQHandler) +INT_VECTOR(CAN3_TX_IRQHandler) +INT_VECTOR(CAN3_RX0_IRQHandler) +INT_VECTOR(CAN3_RX1_IRQHandler) +INT_VECTOR(CAN3_SCE_IRQHandler) +INT_VECTOR(JPEG_IRQHandler) +INT_VECTOR(MDIOS_IRQHandler) diff --git a/hw/mcu/stm/stm32f7xx/src/clock_stm32f7xx.c b/hw/mcu/stm/stm32f7xx/src/clock_stm32f7xx.c index d04d7e79fd..a60145198f 100644 --- a/hw/mcu/stm/stm32f7xx/src/clock_stm32f7xx.c +++ b/hw/mcu/stm/stm32f7xx/src/clock_stm32f7xx.c @@ -253,13 +253,5 @@ SystemClock_Config(void) assert(0); } #endif - -#if ART_ACCLERATOR_ENABLE - __HAL_FLASH_ART_ENABLE(); -#endif - -#if PREFETCH_ENABLE - __HAL_FLASH_PREFETCH_BUFFER_ENABLE(); -#endif } #endif diff --git a/hw/mcu/stm/stm32f7xx/src/hal_system_init.c b/hw/mcu/stm/stm32f7xx/src/hal_system_init.c new file mode 100644 index 0000000000..01e408b451 --- /dev/null +++ b/hw/mcu/stm/stm32f7xx/src/hal_system_init.c @@ -0,0 +1,50 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance + * with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +#include "os/mynewt.h" +#include "mcu/stm32_hal.h" +#include + +extern char __vector_tbl_reloc__[]; + +void SystemClock_Config(void); + +void +hal_system_init(void) +{ + SCB->VTOR = (uint32_t)&__vector_tbl_reloc__; + + /* Configure System Clock */ + SystemClock_Config(); + + /* Update SystemCoreClock global variable */ + SystemCoreClockUpdate(); + + /* Relocate the vector table */ + NVIC_Relocate(); + +#if ART_ACCELERATOR_ENABLE + __HAL_FLASH_ART_ENABLE(); +#endif + +#if PREFETCH_ENABLE + __HAL_FLASH_PREFETCH_BUFFER_ENABLE(); +#endif +} + diff --git a/hw/mcu/stm/stm32f7xx/src/system_stm32f7xx.c b/hw/mcu/stm/stm32f7xx/src/system_stm32f7xx.c index a1906a6d5b..7674a8bbfd 100644 --- a/hw/mcu/stm/stm32f7xx/src/system_stm32f7xx.c +++ b/hw/mcu/stm/stm32f7xx/src/system_stm32f7xx.c @@ -115,15 +115,6 @@ void SystemInit(void) /* Disable all interrupts */ RCC->CIR = 0x00000000; - - /* Configure System Clock */ - SystemClock_Config(); - - /* Update SystemCoreClock global variable */ - SystemCoreClockUpdate(); - - /* Relocate the vector table */ - NVIC_Relocate(); } /** diff --git a/hw/mcu/stm/stm32f7xx/stm32f746.ld b/hw/mcu/stm/stm32f7xx/stm32f746.ld deleted file mode 100644 index e1929bfbd2..0000000000 --- a/hw/mcu/stm/stm32f7xx/stm32f746.ld +++ /dev/null @@ -1,217 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one - * or more contributor license agreements. See the NOTICE file - * distributed with this work for additional information - * regarding copyright ownership. The ASF licenses this file - * to you under the Apache License, Version 2.0 (the - * "License"); you may not use this file except in compliance - * with the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, - * software distributed under the License is distributed on an - * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY - * KIND, either express or implied. See the License for the - * specific language governing permissions and limitations - * under the License. - */ - -/* Linker script to place sections and symbol values. Should be used together - * with other linker script that defines memory regions FLASH and RAM. - * It references following symbols, which must be defined in code: - * Reset_Handler : Entry of reset handler - * - * It defines following symbols, which code can use without definition: - * __exidx_start - * __exidx_end - * __etext - * __data_start__ - * __preinit_array_start - * __preinit_array_end - * __init_array_start - * __init_array_end - * __fini_array_start - * __fini_array_end - * __data_end__ - * __bss_start__ - * __bss_end__ - * __end__ - * end - * __HeapBase - * __HeapLimit - * __StackLimit - * __StackTop - * __stack - * __coredata_start__ - * __coredata_end__ - * __corebss_start__ - * __corebss_end__ - * __ecoredata - * __ecorebss - */ -ENTRY(Reset_Handler) - -_estack = ORIGIN(DTCM) + LENGTH(DTCM); - -SECTIONS -{ - /* Reserve space at the start of the image for the header. */ - .imghdr (NOLOAD): - { - . = . + _imghdr_size; - } > FLASH - - __text = .; - - .text : - { - __isr_vector_start = .; - KEEP(*(.isr_vector)) - __isr_vector_end = .; - *(.text*) - - KEEP(*(.init)) - KEEP(*(.fini)) - - /* preinit data */ - PROVIDE_HIDDEN (__preinit_array_start = .); - KEEP(*(.preinit_array)) - PROVIDE_HIDDEN (__preinit_array_end = .); - - . = ALIGN(4); - /* init data */ - PROVIDE_HIDDEN (__init_array_start = .); - KEEP(*(SORT(.init_array.*))) - KEEP(*(.init_array)) - PROVIDE_HIDDEN (__init_array_end = .); - - . = ALIGN(4); - /* finit data */ - PROVIDE_HIDDEN (__fini_array_start = .); - KEEP(*(SORT(.fini_array.*))) - KEEP(*(.fini_array)) - PROVIDE_HIDDEN (__fini_array_end = .); - - /* .ctors */ - *crtbegin.o(.ctors) - *crtbegin?.o(.ctors) - *(EXCLUDE_FILE(*crtend?.o *crtend.o) .ctors) - *(SORT(.ctors.*)) - *(.ctors) - - /* .dtors */ - *crtbegin.o(.dtors) - *crtbegin?.o(.dtors) - *(EXCLUDE_FILE(*crtend?.o *crtend.o) .dtors) - *(SORT(.dtors.*)) - *(.dtors) - -INCLUDE "link_tables.ld.h" - *(.rodata*) - - KEEP(*(.eh_frame*)) - PROVIDE(mynewt_main = main); - } > FLASH - - .ARM.extab : - { - *(.ARM.extab* .gnu.linkonce.armextab.*) - } > FLASH - - __exidx_start = .; - .ARM.exidx : - { - *(.ARM.exidx* .gnu.linkonce.armexidx.*) - } > FLASH - - __exidx_end = .; - - __etext = .; - - .vector_relocation : - { - . = ALIGN(4); - __vector_tbl_reloc__ = .; - . = . + (__isr_vector_end - __isr_vector_start); - . = ALIGN(4); - } > DTCM - - .coredata : - { - __coredata_start__ = .; - *(.data.core) - . = ALIGN(4); - __coredata_end__ = .; - } > DTCM AT > FLASH - - __ecoredata = __etext + SIZEOF(.coredata); - - _sidata = LOADADDR(.data); - - .data : - { - . = ALIGN(4); - _sdata = .; - __data_start__ = _sdata; - *(vtable) - *(.data*) - - KEEP(*(.jcr*)) - . = ALIGN(4); - /* All data end */ - _edata = .; - __data_end__ = _edata; - - } > RAM AT > FLASH - - .corebss (NOLOAD): - { - . = ALIGN(4); - __corebss_start__ = .; - *(.bss.core) - . = ALIGN(4); - __corebss_end__ = .; - *(.corebss*) - *(.bss.core.nz) - . = ALIGN(4); - __ecorebss = .; - } > DTCM - - .bss : - { - . = ALIGN(4); - _sbss = .; - __bss_start__ = _sbss; - *(.bss*) - *(COMMON) - . = ALIGN(4); - _ebss = .; - __bss_end__ = _ebss; - } > RAM - - . = ALIGN(8); - __HeapBase = .; - __HeapLimit = ORIGIN(RAM) + LENGTH(RAM); - - _ram_start = ORIGIN(RAM); - _dtcmram_start = ORIGIN(DTCM); - _itcmram_start = ORIGIN(ITCM); - - /* .stack_dummy section doesn't contains any symbols. It is only - * used for linker to calculate size of stack sections, and assign - * values to stack symbols later */ - .stack_dummy (COPY): - { - *(.stack*) - } > DTCM - - /* Set stack top to end of DTCM; stack limit is bottom of stack */ - __StackTop = ORIGIN(DTCM) + LENGTH(DTCM); - __StackLimit = __StackTop - SIZEOF(.stack_dummy); - PROVIDE(__stack = __StackTop); - - /* Check for DTCM overflow */ - ASSERT(__StackLimit >= __ecorebss, "DTCM overflow!") -} - diff --git a/hw/mcu/stm/stm32f7xx/stm32f767.ld b/hw/mcu/stm/stm32f7xx/stm32f767.ld deleted file mode 100644 index e1929bfbd2..0000000000 --- a/hw/mcu/stm/stm32f7xx/stm32f767.ld +++ /dev/null @@ -1,217 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one - * or more contributor license agreements. See the NOTICE file - * distributed with this work for additional information - * regarding copyright ownership. The ASF licenses this file - * to you under the Apache License, Version 2.0 (the - * "License"); you may not use this file except in compliance - * with the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, - * software distributed under the License is distributed on an - * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY - * KIND, either express or implied. See the License for the - * specific language governing permissions and limitations - * under the License. - */ - -/* Linker script to place sections and symbol values. Should be used together - * with other linker script that defines memory regions FLASH and RAM. - * It references following symbols, which must be defined in code: - * Reset_Handler : Entry of reset handler - * - * It defines following symbols, which code can use without definition: - * __exidx_start - * __exidx_end - * __etext - * __data_start__ - * __preinit_array_start - * __preinit_array_end - * __init_array_start - * __init_array_end - * __fini_array_start - * __fini_array_end - * __data_end__ - * __bss_start__ - * __bss_end__ - * __end__ - * end - * __HeapBase - * __HeapLimit - * __StackLimit - * __StackTop - * __stack - * __coredata_start__ - * __coredata_end__ - * __corebss_start__ - * __corebss_end__ - * __ecoredata - * __ecorebss - */ -ENTRY(Reset_Handler) - -_estack = ORIGIN(DTCM) + LENGTH(DTCM); - -SECTIONS -{ - /* Reserve space at the start of the image for the header. */ - .imghdr (NOLOAD): - { - . = . + _imghdr_size; - } > FLASH - - __text = .; - - .text : - { - __isr_vector_start = .; - KEEP(*(.isr_vector)) - __isr_vector_end = .; - *(.text*) - - KEEP(*(.init)) - KEEP(*(.fini)) - - /* preinit data */ - PROVIDE_HIDDEN (__preinit_array_start = .); - KEEP(*(.preinit_array)) - PROVIDE_HIDDEN (__preinit_array_end = .); - - . = ALIGN(4); - /* init data */ - PROVIDE_HIDDEN (__init_array_start = .); - KEEP(*(SORT(.init_array.*))) - KEEP(*(.init_array)) - PROVIDE_HIDDEN (__init_array_end = .); - - . = ALIGN(4); - /* finit data */ - PROVIDE_HIDDEN (__fini_array_start = .); - KEEP(*(SORT(.fini_array.*))) - KEEP(*(.fini_array)) - PROVIDE_HIDDEN (__fini_array_end = .); - - /* .ctors */ - *crtbegin.o(.ctors) - *crtbegin?.o(.ctors) - *(EXCLUDE_FILE(*crtend?.o *crtend.o) .ctors) - *(SORT(.ctors.*)) - *(.ctors) - - /* .dtors */ - *crtbegin.o(.dtors) - *crtbegin?.o(.dtors) - *(EXCLUDE_FILE(*crtend?.o *crtend.o) .dtors) - *(SORT(.dtors.*)) - *(.dtors) - -INCLUDE "link_tables.ld.h" - *(.rodata*) - - KEEP(*(.eh_frame*)) - PROVIDE(mynewt_main = main); - } > FLASH - - .ARM.extab : - { - *(.ARM.extab* .gnu.linkonce.armextab.*) - } > FLASH - - __exidx_start = .; - .ARM.exidx : - { - *(.ARM.exidx* .gnu.linkonce.armexidx.*) - } > FLASH - - __exidx_end = .; - - __etext = .; - - .vector_relocation : - { - . = ALIGN(4); - __vector_tbl_reloc__ = .; - . = . + (__isr_vector_end - __isr_vector_start); - . = ALIGN(4); - } > DTCM - - .coredata : - { - __coredata_start__ = .; - *(.data.core) - . = ALIGN(4); - __coredata_end__ = .; - } > DTCM AT > FLASH - - __ecoredata = __etext + SIZEOF(.coredata); - - _sidata = LOADADDR(.data); - - .data : - { - . = ALIGN(4); - _sdata = .; - __data_start__ = _sdata; - *(vtable) - *(.data*) - - KEEP(*(.jcr*)) - . = ALIGN(4); - /* All data end */ - _edata = .; - __data_end__ = _edata; - - } > RAM AT > FLASH - - .corebss (NOLOAD): - { - . = ALIGN(4); - __corebss_start__ = .; - *(.bss.core) - . = ALIGN(4); - __corebss_end__ = .; - *(.corebss*) - *(.bss.core.nz) - . = ALIGN(4); - __ecorebss = .; - } > DTCM - - .bss : - { - . = ALIGN(4); - _sbss = .; - __bss_start__ = _sbss; - *(.bss*) - *(COMMON) - . = ALIGN(4); - _ebss = .; - __bss_end__ = _ebss; - } > RAM - - . = ALIGN(8); - __HeapBase = .; - __HeapLimit = ORIGIN(RAM) + LENGTH(RAM); - - _ram_start = ORIGIN(RAM); - _dtcmram_start = ORIGIN(DTCM); - _itcmram_start = ORIGIN(ITCM); - - /* .stack_dummy section doesn't contains any symbols. It is only - * used for linker to calculate size of stack sections, and assign - * values to stack symbols later */ - .stack_dummy (COPY): - { - *(.stack*) - } > DTCM - - /* Set stack top to end of DTCM; stack limit is bottom of stack */ - __StackTop = ORIGIN(DTCM) + LENGTH(DTCM); - __StackLimit = __StackTop - SIZEOF(.stack_dummy); - PROVIDE(__stack = __StackTop); - - /* Check for DTCM overflow */ - ASSERT(__StackLimit >= __ecorebss, "DTCM overflow!") -} -