;/*! ; \file startup_gd32f450.S ; \brief start up file ; ; \version 2016-08-15, V1.0.0, firmware for GD32F4xx ; \version 2018-12-12, V2.0.0, firmware for GD32F4xx ; \version 2018-12-25, V2.1.0, firmware for GD32F4xx (The version is for mbed) ;*/ ; ;/* ; Copyright (c) 2018, GigaDevice Semiconductor Inc. ; ; All rights reserved. ; ; 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 of the copyright holder 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 HOLDER 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. ;*/ .syntax unified .cpu cortex-m4 .fpu softvfp .thumb .global VecTab .global Default_Handler /* start address of the initialization .data */ .word _sidata /* start address of the .data section */ .word _sdata /* end address of the .data section */ .word _edata /* start address of the .bss section */ .word _sbss /* end address of the .bss section */ .word _ebss /* reset Handler */ .section .text.Reset_Handler .weak Reset_Handler .type Reset_Handler, %function Reset_Handler: ldr r0, =_estack mov sp, r0 /* set stack pointer */ /* copy the data segment into RAM */ movs r1, #0 b DataInit CopyData: ldr r3, =_sidata ldr r3, [r3, r1] str r3, [r0, r1] adds r1, r1, #4 DataInit: ldr r0, =_sdata ldr r3, =_edata adds r2, r0, r1 cmp r2, r3 bcc CopyData ldr r2, =_sbss ldr r3, =_ebss cmp r2, r3 bcc ZeroFill ZeroFill: movs r3, #0 str r3, [r2], #4 /* system clock intitialization*/ bl SystemInit /* static constructors */ // bl __libc_init_array /* jump to application's entry point */ // bl main bl _start bx lr .size Reset_Handler, .-Reset_Handler .section .text.Default_Handler,"ax",%progbits Default_Handler: /* infinite loop */ b . .size Default_Handler, .-Default_Handler .section .isr_vector,"a",%progbits .type VecTab, %object .size VecTab, .-VecTab VecTab: .word _estack /* Top of Stack */ .word Reset_Handler /* Reset Handler */ .word NMI_Handler /* NMI Handler */ .word HardFault_Handler /* Hard Fault Handler */ .word MemManage_Handler /* MPU Fault Handler */ .word BusFault_Handler /* Bus Fault Handler */ .word UsageFault_Handler /* Usage Fault Handler */ .word 0 /* Reserved */ .word 0 /* Reserved */ .word 0 /* Reserved */ .word 0 /* Reserved */ .word SVC_Handler /* SVCall Handler */ .word DebugMon_Handler /* Debug Monitor Handler */ .word 0 /* Reserved */ .word PendSV_Handler /* PendSV Handler */ .word SysTick_Handler /* SysTick Handler */ /* external interrupts handler */ .word WWDGT_IRQHandler /* 16:Window Watchdog Timer */ .word LVD_IRQHandler /* 17:LVD through EXTI Line detect */ .word TAMPER_STAMP_IRQHandler /* 18:Tamper and TimeStamp through EXTI Line detect */ .word RTC_WKUP_IRQHandler /* 19:RTC Wakeup through EXTI Line */ .word FMC_IRQHandler /* 20:FMC */ .word RCU_CTC_IRQHandler /* 21:RCU and CTC */ .word EXTI0_IRQHandler /* 22:EXTI Line 0 */ .word EXTI1_IRQHandler /* 23:EXTI Line 1 */ .word EXTI2_IRQHandler /* 24:EXTI Line 2 */ .word EXTI3_IRQHandler /* 25:EXTI Line 3 */ .word EXTI4_IRQHandler /* 26:EXTI Line 4 */ .word DMA0_Channel0_IRQHandler /* 27:DMA0 Channel0 */ .word DMA0_Channel1_IRQHandler /* 28:DMA0 Channel1 */ .word DMA0_Channel2_IRQHandler /* 29:DMA0 Channel2 */ .word DMA0_Channel3_IRQHandler /* 30:DMA0 Channel3 */ .word DMA0_Channel4_IRQHandler /* 31:DMA0 Channel4 */ .word DMA0_Channel5_IRQHandler /* 32:DMA0 Channel5 */ .word DMA0_Channel6_IRQHandler /* 33:DMA0 Channel6 */ .word ADC_IRQHandler /* 34:ADC */ .word CAN0_TX_IRQHandler /* 35:CAN0 TX */ .word CAN0_RX0_IRQHandler /* 36:CAN0 RX0 */ .word CAN0_RX1_IRQHandler /* 37:CAN0 RX1 */ .word CAN0_EWMC_IRQHandler /* 38:CAN0 EWMC */ .word EXTI5_9_IRQHandler /* 39:EXTI5 to EXTI9 */ .word TIMER0_BRK_TIMER8_IRQHandler /* 40:TIMER0 Break and TIMER8 */ .word TIMER0_UP_TIMER9_IRQHandler /* 41:TIMER0 Update and TIMER9 */ .word TIMER0_TRG_CMT_TIMER10_IRQHandler /* 42:TIMER0 Trigger and Commutation and TIMER10 */ .word TIMER0_Channel_IRQHandler /* 43:TIMER0 Capture Compare */ .word TIMER1_IRQHandler /* 44:TIMER1 */ .word TIMER2_IRQHandler /* 45:TIMER2 */ .word TIMER3_IRQHandler /* 46:TIMER3 */ .word I2C0_EV_IRQHandler /* 47:I2C0 Event */ .word I2C0_ER_IRQHandler /* 48:I2C0 Error */ .word I2C1_EV_IRQHandler /* 49:I2C1 Event */ .word I2C1_ER_IRQHandler /* 50:I2C1 Error */ .word SPI0_IRQHandler /* 51:SPI0 */ .word SPI1_IRQHandler /* 52:SPI1 */ .word USART0_IRQHandler /* 53:USART0 */ .word USART1_IRQHandler /* 54:USART1 */ .word USART2_IRQHandler /* 55:USART2 */ .word EXTI10_15_IRQHandler /* 56:EXTI10 to EXTI15 */ .word RTC_Alarm_IRQHandler /* 57:RTC Alarm */ .word USBFS_WKUP_IRQHandler /* 58:USBFS Wakeup */ .word TIMER7_BRK_TIMER11_IRQHandler /* 59:TIMER7 Break and TIMER11 */ .word TIMER7_UP_TIMER12_IRQHandler /* 60:TIMER7 Update and TIMER12 */ .word TIMER7_TRG_CMT_TIMER13_IRQHandler /* 61:TIMER7 Trigger and Commutation and TIMER13 */ .word TIMER7_Channel_IRQHandler /* 62:TIMER7 Channel Capture Compare */ .word DMA0_Channel7_IRQHandler /* 63:DMA0 Channel7 */ .word EXMC_IRQHandler /* 64:EXMC */ .word SDIO_IRQHandler /* 65:SDIO */ .word TIMER4_IRQHandler /* 66:TIMER4 */ .word SPI2_IRQHandler /* 67:SPI2 */ .word UART3_IRQHandler /* 68:UART3 */ .word UART4_IRQHandler /* 69:UART4 */ .word TIMER5_DAC_IRQHandler /* 70:TIMER5 and DAC0 DAC1 Underrun error */ .word TIMER6_IRQHandler /* 71:TIMER6 */ .word DMA1_Channel0_IRQHandler /* 72:DMA1 Channel0 */ .word DMA1_Channel1_IRQHandler /* 73:DMA1 Channel1 */ .word DMA1_Channel2_IRQHandler /* 74:DMA1 Channel2 */ .word DMA1_Channel3_IRQHandler /* 75:DMA1 Channel3 */ .word DMA1_Channel4_IRQHandler /* 76:DMA1 Channel4 */ .word ENET_IRQHandler /* 77:Ethernet */ .word ENET_WKUP_IRQHandler /* 78:Ethernet Wakeup through EXTI Line */ .word CAN1_TX_IRQHandler /* 79:CAN1 TX */ .word CAN1_RX0_IRQHandler /* 80:CAN1 RX0 */ .word CAN1_RX1_IRQHandler /* 81:CAN1 RX1 */ .word CAN1_EWMC_IRQHandler /* 82:CAN1 EWMC */ .word USBFS_IRQHandler /* 83:USBFS */ .word DMA1_Channel5_IRQHandler /* 84:DMA1 Channel5 */ .word DMA1_Channel6_IRQHandler /* 85:DMA1 Channel6 */ .word DMA1_Channel7_IRQHandler /* 86:DMA1 Channel7 */ .word USART5_IRQHandler /* 87:USART5 */ .word I2C2_EV_IRQHandler /* 88:I2C2 Event */ .word I2C2_ER_IRQHandler /* 89:I2C2 Error */ .word USBHS_EP1_Out_IRQHandler /* 90:USBHS Endpoint 1 Out */ .word USBHS_EP1_In_IRQHandler /* 91:USBHS Endpoint 1 in */ .word USBHS_WKUP_IRQHandler /* 92:USBHS Wakeup through EXTI Line */ .word USBHS_IRQHandler /* 93:USBHS */ .word DCI_IRQHandler /* 94:DCI */ .word 0 /* 95:Reserved */ .word TRNG_IRQHandler /* 96:TRNG */ .word FPU_IRQHandler /* 97:FPU */ .word UART6_IRQHandler /* 98:UART6 */ .word UART7_IRQHandler /* 99:UART7 */ .word SPI3_IRQHandler /* 100:SPI3 */ .word SPI4_IRQHandler /* 101:SPI4 */ .word SPI5_IRQHandler /* 102:SPI5 */ .word 0 /* 103:Reserved */ .word TLI_IRQHandler /* 104:TLI */ .word TLI_ER_IRQHandler /* 105:TLI Error */ .word IPA_IRQHandler /* 106:IPA */ /* dummy Exception Handlers */ .weak NMI_Handler .thumb_set NMI_Handler,Default_Handler .weak HardFault_Handler .thumb_set HardFault_Handler,Default_Handler .weak MemManage_Handler .thumb_set MemManage_Handler,Default_Handler .weak BusFault_Handler .thumb_set BusFault_Handler,Default_Handler .weak UsageFault_Handler .thumb_set UsageFault_Handler,Default_Handler .weak SVC_Handler .thumb_set SVC_Handler,Default_Handler .weak DebugMon_Handler .thumb_set DebugMon_Handler,Default_Handler .weak PendSV_Handler .thumb_set PendSV_Handler,Default_Handler .weak SysTick_Handler .thumb_set SysTick_Handler,Default_Handler .weak WWDGT_IRQHandler .thumb_set WWDGT_IRQHandler,Default_Handler .weak LVD_IRQHandler .thumb_set LVD_IRQHandler,Default_Handler .weak TAMPER_STAMP_IRQHandler .thumb_set TAMPER_STAMP_IRQHandler,Default_Handler .weak RTC_WKUP_IRQHandler .thumb_set RTC_WKUP_IRQHandler,Default_Handler .weak FMC_IRQHandler .thumb_set FMC_IRQHandler,Default_Handler .weak RCU_CTC_IRQHandler .thumb_set RCU_CTC_IRQHandler,Default_Handler .weak EXTI0_IRQHandler .thumb_set EXTI0_IRQHandler,Default_Handler .weak EXTI1_IRQHandler .thumb_set EXTI1_IRQHandler,Default_Handler .weak EXTI2_IRQHandler .thumb_set EXTI2_IRQHandler,Default_Handler .weak EXTI3_IRQHandler .thumb_set EXTI3_IRQHandler,Default_Handler .weak EXTI4_IRQHandler .thumb_set EXTI4_IRQHandler,Default_Handler .weak DMA0_Channel0_IRQHandler .thumb_set DMA0_Channel0_IRQHandler,Default_Handler .weak DMA0_Channel1_IRQHandler .thumb_set DMA0_Channel1_IRQHandler,Default_Handler .weak DMA0_Channel2_IRQHandler .thumb_set DMA0_Channel2_IRQHandler,Default_Handler .weak DMA0_Channel3_IRQHandler .thumb_set DMA0_Channel3_IRQHandler,Default_Handler .weak DMA0_Channel4_IRQHandler .thumb_set DMA0_Channel4_IRQHandler,Default_Handler .weak DMA0_Channel5_IRQHandler .thumb_set DMA0_Channel5_IRQHandler,Default_Handler .weak DMA0_Channel6_IRQHandler .thumb_set DMA0_Channel6_IRQHandler,Default_Handler .weak ADC_IRQHandler .thumb_set ADC_IRQHandler,Default_Handler .weak CAN0_TX_IRQHandler .thumb_set CAN0_TX_IRQHandler,Default_Handler .weak CAN0_RX0_IRQHandler .thumb_set CAN0_RX0_IRQHandler,Default_Handler .weak CAN0_RX1_IRQHandler .thumb_set CAN0_RX1_IRQHandler,Default_Handler .weak CAN0_EWMC_IRQHandler .thumb_set CAN0_EWMC_IRQHandler,Default_Handler .weak EXTI5_9_IRQHandler .thumb_set EXTI5_9_IRQHandler,Default_Handler .weak TIMER0_BRK_TIMER8_IRQHandler .thumb_set TIMER0_BRK_TIMER8_IRQHandler,Default_Handler .weak TIMER0_UP_TIMER9_IRQHandler .thumb_set TIMER0_UP_TIMER9_IRQHandler,Default_Handler .weak TIMER0_TRG_CMT_TIMER10_IRQHandler .thumb_set TIMER0_TRG_CMT_TIMER10_IRQHandler,Default_Handler .weak TIMER0_Channel_IRQHandler .thumb_set TIMER0_Channel_IRQHandler,Default_Handler .weak TIMER1_IRQHandler .thumb_set TIMER1_IRQHandler,Default_Handler .weak TIMER2_IRQHandler .thumb_set TIMER2_IRQHandler,Default_Handler .weak TIMER3_IRQHandler .thumb_set TIMER3_IRQHandler,Default_Handler .weak I2C0_EV_IRQHandler .thumb_set I2C0_EV_IRQHandler,Default_Handler .weak I2C0_ER_IRQHandler .thumb_set I2C0_ER_IRQHandler,Default_Handler .weak I2C1_EV_IRQHandler .thumb_set I2C1_EV_IRQHandler,Default_Handler .weak I2C1_ER_IRQHandler .thumb_set I2C1_ER_IRQHandler,Default_Handler .weak SPI0_IRQHandler .thumb_set SPI0_IRQHandler,Default_Handler .weak SPI1_IRQHandler .thumb_set SPI1_IRQHandler,Default_Handler .weak USART0_IRQHandler .thumb_set USART0_IRQHandler,Default_Handler .weak USART1_IRQHandler .thumb_set USART1_IRQHandler,Default_Handler .weak USART2_IRQHandler .thumb_set USART2_IRQHandler,Default_Handler .weak EXTI10_15_IRQHandler .thumb_set EXTI10_15_IRQHandler,Default_Handler .weak RTC_Alarm_IRQHandler .thumb_set RTC_Alarm_IRQHandler,Default_Handler .weak USBFS_WKUP_IRQHandler .thumb_set USBFS_WKUP_IRQHandler,Default_Handler .weak TIMER7_BRK_TIMER11_IRQHandler .thumb_set TIMER7_BRK_TIMER11_IRQHandler,Default_Handler .weak TIMER7_UP_TIMER12_IRQHandler .thumb_set TIMER7_UP_TIMER12_IRQHandler,Default_Handler .weak TIMER7_TRG_CMT_TIMER13_IRQHandler .thumb_set TIMER7_TRG_CMT_TIMER13_IRQHandler,Default_Handler .weak TIMER7_Channel_IRQHandler .thumb_set TIMER7_Channel_IRQHandler,Default_Handler .weak DMA0_Channel7_IRQHandler .thumb_set DMA0_Channel7_IRQHandler,Default_Handler .weak EXMC_IRQHandler .thumb_set EXMC_IRQHandler,Default_Handler .weak SDIO_IRQHandler .thumb_set SDIO_IRQHandler,Default_Handler .weak TIMER4_IRQHandler .thumb_set TIMER4_IRQHandler,Default_Handler .weak SPI2_IRQHandler .thumb_set SPI2_IRQHandler,Default_Handler .weak UART3_IRQHandler .thumb_set UART3_IRQHandler,Default_Handler .weak UART4_IRQHandler .thumb_set UART4_IRQHandler,Default_Handler .weak TIMER5_DAC_IRQHandler .thumb_set TIMER5_DAC_IRQHandler,Default_Handler .weak TIMER6_IRQHandler .thumb_set TIMER6_IRQHandler,Default_Handler .weak DMA1_Channel0_IRQHandler .thumb_set DMA1_Channel0_IRQHandler,Default_Handler .weak DMA1_Channel1_IRQHandler .thumb_set DMA1_Channel1_IRQHandler,Default_Handler .weak DMA1_Channel2_IRQHandler .thumb_set DMA1_Channel2_IRQHandler,Default_Handler .weak DMA1_Channel3_IRQHandler .thumb_set DMA1_Channel3_IRQHandler,Default_Handler .weak DMA1_Channel4_IRQHandler .thumb_set DMA1_Channel4_IRQHandler,Default_Handler .weak ENET_IRQHandler .thumb_set ENET_IRQHandler,Default_Handler .weak ENET_WKUP_IRQHandler .thumb_set ENET_WKUP_IRQHandler,Default_Handler .weak CAN1_TX_IRQHandler .thumb_set CAN1_TX_IRQHandler,Default_Handler .weak CAN1_RX0_IRQHandler .thumb_set CAN1_RX0_IRQHandler,Default_Handler .weak CAN1_RX1_IRQHandler .thumb_set CAN1_RX1_IRQHandler,Default_Handler .weak CAN1_EWMC_IRQHandler .thumb_set CAN1_EWMC_IRQHandler,Default_Handler .weak USBFS_IRQHandler .thumb_set USBFS_IRQHandler,Default_Handler .weak DMA1_Channel5_IRQHandler .thumb_set DMA1_Channel5_IRQHandler,Default_Handler .weak DMA1_Channel6_IRQHandler .thumb_set DMA1_Channel6_IRQHandler,Default_Handler .weak DMA1_Channel7_IRQHandler .thumb_set DMA1_Channel7_IRQHandler,Default_Handler .weak USART5_IRQHandler .thumb_set USART5_IRQHandler,Default_Handler .weak I2C2_EV_IRQHandler .thumb_set I2C2_EV_IRQHandler,Default_Handler .weak I2C2_ER_IRQHandler .thumb_set I2C2_ER_IRQHandler,Default_Handler .weak USBHS_EP1_Out_IRQHandler .thumb_set USBHS_EP1_Out_IRQHandler,Default_Handler .weak USBHS_EP1_In_IRQHandler .thumb_set USBHS_EP1_In_IRQHandler,Default_Handler .weak USBHS_WKUP_IRQHandler .thumb_set USBHS_WKUP_IRQHandler,Default_Handler .weak USBHS_IRQHandler .thumb_set USBHS_IRQHandler,Default_Handler .weak DCI_IRQHandler .thumb_set DCI_IRQHandler,Default_Handler .weak TRNG_IRQHandler .thumb_set TRNG_IRQHandler,Default_Handler .weak FPU_IRQHandler .thumb_set FPU_IRQHandler,Default_Handler .weak UART6_IRQHandler .thumb_set UART6_IRQHandler,Default_Handler .weak UART7_IRQHandler .thumb_set UART7_IRQHandler,Default_Handler .weak SPI3_IRQHandler .thumb_set SPI3_IRQHandler,Default_Handler .weak SPI4_IRQHandler .thumb_set SPI4_IRQHandler,Default_Handler .weak SPI5_IRQHandler .thumb_set SPI5_IRQHandler,Default_Handler .weak TLI_IRQHandler .thumb_set TLI_IRQHandler,Default_Handler .weak TLI_ER_IRQHandler .thumb_set TLI_ER_IRQHandler,Default_Handler .weak IPA_IRQHandler .thumb_set IPA_IRQHandler,Default_Handler