/* --------------------------------------------------------------------------*/ /* @file: startup_LPC54018.S */ /* @purpose: CMSIS Cortex-M4 Core Device Startup File */ /* LPC54018 */ /* @version: 1.2 */ /* @date: 2017-6-8 */ /* --------------------------------------------------------------------------*/ /* */ /* Copyright 1997-2016 Freescale Semiconductor, Inc. */ /* Copyright 2016-2019 NXP */ /* All rights reserved. */ /* */ /* SPDX-License-Identifier: BSD-3-Clause */ /*****************************************************************************/ /* Version: GCC for ARM Embedded Processors */ /*****************************************************************************/ .syntax unified .arch armv7-m .section .isr_vector, "a" .align 2 .globl __Vectors __Vectors: .long __StackTop /* Top of Stack */ .long Reset_Handler /* Reset Handler */ .long NMI_Handler /* NMI Handler*/ .long HardFault_Handler /* Hard Fault Handler*/ .long MemManage_Handler /* MPU Fault Handler*/ .long BusFault_Handler /* Bus Fault Handler*/ .long UsageFault_Handler /* Usage Fault Handler*/ .long 0 /* Reserved*/ .long 0 /* Reserved*/ .long 0xEDDC94BD /* Enhanced image marker, set to 0x0 for legacy boot */ .long 0x160 /* Pointer to enhanced boot block, set to 0x0 for legacy boot */ .long SVC_Handler /* SVCall Handler*/ .long DebugMon_Handler /* Debug Monitor Handler*/ .long 0 /* Reserved*/ .long PendSV_Handler /* PendSV Handler*/ .long SysTick_Handler /* SysTick Handler*/ /* External Interrupts */ .long WDT_BOD_IRQHandler /* Windowed watchdog timer, Brownout detect */ .long DMA0_IRQHandler /* DMA controller */ .long GINT0_IRQHandler /* GPIO group 0 */ .long GINT1_IRQHandler /* GPIO group 1 */ .long PIN_INT0_IRQHandler /* Pin interrupt 0 or pattern match engine slice 0 */ .long PIN_INT1_IRQHandler /* Pin interrupt 1or pattern match engine slice 1 */ .long PIN_INT2_IRQHandler /* Pin interrupt 2 or pattern match engine slice 2 */ .long PIN_INT3_IRQHandler /* Pin interrupt 3 or pattern match engine slice 3 */ .long UTICK0_IRQHandler /* Micro-tick Timer */ .long MRT0_IRQHandler /* Multi-rate timer */ .long CTIMER0_IRQHandler /* Standard counter/timer CTIMER0 */ .long CTIMER1_IRQHandler /* Standard counter/timer CTIMER1 */ .long SCT0_IRQHandler /* SCTimer/PWM */ .long CTIMER3_IRQHandler /* Standard counter/timer CTIMER3 */ .long FLEXCOMM0_IRQHandler /* Flexcomm Interface 0 (USART, SPI, I2C, FLEXCOMM) */ .long FLEXCOMM1_IRQHandler /* Flexcomm Interface 1 (USART, SPI, I2C, FLEXCOMM) */ .long FLEXCOMM2_IRQHandler /* Flexcomm Interface 2 (USART, SPI, I2C, FLEXCOMM) */ .long FLEXCOMM3_IRQHandler /* Flexcomm Interface 3 (USART, SPI, I2C, FLEXCOMM) */ .long FLEXCOMM4_IRQHandler /* Flexcomm Interface 4 (USART, SPI, I2C, FLEXCOMM) */ .long FLEXCOMM5_IRQHandler /* Flexcomm Interface 5 (USART, SPI, I2C,, FLEXCOMM) */ .long FLEXCOMM6_IRQHandler /* Flexcomm Interface 6 (USART, SPI, I2C, I2S,, FLEXCOMM) */ .long FLEXCOMM7_IRQHandler /* Flexcomm Interface 7 (USART, SPI, I2C, I2S,, FLEXCOMM) */ .long ADC0_SEQA_IRQHandler /* ADC0 sequence A completion. */ .long ADC0_SEQB_IRQHandler /* ADC0 sequence B completion. */ .long ADC0_THCMP_IRQHandler /* ADC0 threshold compare and error. */ .long DMIC0_IRQHandler /* Digital microphone and DMIC subsystem */ .long HWVAD0_IRQHandler /* Hardware Voice Activity Detector */ .long USB0_NEEDCLK_IRQHandler /* USB Activity Wake-up Interrupt */ .long USB0_IRQHandler /* USB device */ .long RTC_IRQHandler /* RTC alarm and wake-up interrupts */ .long FLEXCOMM10_IRQHandler /* Flexcomm Interface 10 (SPI, FLEXCOMM) */ .long Reserved47_IRQHandler /* Reserved interrupt */ .long PIN_INT4_IRQHandler /* Pin interrupt 4 or pattern match engine slice 4 int */ .long PIN_INT5_IRQHandler /* Pin interrupt 5 or pattern match engine slice 5 int */ .long PIN_INT6_IRQHandler /* Pin interrupt 6 or pattern match engine slice 6 int */ .long PIN_INT7_IRQHandler /* Pin interrupt 7 or pattern match engine slice 7 int */ .long CTIMER2_IRQHandler /* Standard counter/timer CTIMER2 */ .long CTIMER4_IRQHandler /* Standard counter/timer CTIMER4 */ .long RIT_IRQHandler /* Repetitive Interrupt Timer */ .long SPIFI0_IRQHandler /* SPI flash interface */ .long FLEXCOMM8_IRQHandler /* Flexcomm Interface 8 (USART, SPI, I2C, FLEXCOMM) */ .long FLEXCOMM9_IRQHandler /* Flexcomm Interface 9 (USART, SPI, I2C, FLEXCOMM) */ .long SDIO_IRQHandler /* SD/MMC */ .long CAN0_IRQ0_IRQHandler /* CAN0 interrupt0 */ .long CAN0_IRQ1_IRQHandler /* CAN0 interrupt1 */ .long CAN1_IRQ0_IRQHandler /* CAN1 interrupt0 */ .long CAN1_IRQ1_IRQHandler /* CAN1 interrupt1 */ .long USB1_IRQHandler /* USB1 interrupt */ .long USB1_NEEDCLK_IRQHandler /* USB1 activity */ .long ETHERNET_IRQHandler /* Ethernet */ .long ETHERNET_PMT_IRQHandler /* Ethernet power management interrupt */ .long ETHERNET_MACLP_IRQHandler /* Ethernet MAC interrupt */ .long Reserved68_IRQHandler /* Reserved interrupt */ .long LCD_IRQHandler /* LCD interrupt */ .long SHA_IRQHandler /* SHA interrupt */ .long SMARTCARD0_IRQHandler /* Smart card 0 interrupt */ .long SMARTCARD1_IRQHandler /* Smart card 1 interrupt */ .size __Vectors, . - __Vectors .long 0 /* Reserved */ .long 0 /* Reserved */ .long 0 /* Reserved */ .long 0 /* Reserved */ .long 0 /* Reserved */ .long 0 /* Reserved */ .long 0 /* Reserved */ .long 0 /* Reserved */ .long 0 /* Reserved */ .long 0 /* Reserved */ .long 0 /* Reserved */ .long 0 /* Reserved */ .long 0 /* Reserved */ .long 0 /* Reserved */ .long 0 /* Reserved */ #ifndef IMG_BAUDRATE #define IMG_BAUDRATE 0 #endif __image_header: .long 0xFEEDA5A5 /* (0x00, 0x160) Header Marker */ #ifdef XIP_IMAGE #ifdef ADD_CRC .long 0x2 /* (0x04) Image Type */ #else .long 0x3 /* (0x04) Image Type */ #endif #else #ifdef ADD_CRC .long 0x0 /* (0x04) Image Type */ #else .long 0x1 /* (0x04) Image Type */ #endif #endif #ifdef XIP_IMAGE .long 0x10000000 /* (0x08) Load_address */ #else .long 0x00000000 /* (0x08) Load_address */ #endif .long __IMAGE_SIZE - 4 /* (0x0C) load_length, exclude 4 bytes CRC field */ .long 0 /* (0x10) CRC value (only applicable to NON Non-secure images) */ .long 0 /* (0x14) Version (only applicable to DUAL_ENH image type */ .long 0 /* (0x18) EMC static memory configuration settings, required for EMC boot */ .long IMG_BAUDRATE /* image baudrate */ .long 0 /* Reserved */ .long 0xEDDC94BD /* (0x24) Image_marker */ .long 0 /* (0x28) SBZ */ .long 0 /* (0x2C) reserved */ #ifdef W25Q128JVFM /* SPI Descriptor - W25Q128JVFM */ .long 0x00000000 /* 0xFFFFFFFF to default 1-bit SPI mode ;DevStrAdr */ .long 0x001870EF /* mfgId + extCount */ .long 0x00000000 /* extid 0-3 */ .long 0x00000000 /* extid 4-7 */ .long 0x0001001D /* caps */ .long 0x00000100 /* Blks + RESV1 */ .long 0x00010000 /* blkSize */ .long 0x00000000 /* subBlks + subBlkSize */ .long 0x00000100 /* pageSize + RESV2 */ .long 0x00003F00 /* maxReadSize */ .long 0x68506850 /* maxClkRate,maxReadRate,maxHSReadRate,maxProgramRate */ .long 0x04030050 /* maxHSProgramRate,initDeInitFxId,clearStatusFxId,getStatusFxId, */ .long 0x14110D09 /* setStatusFxId,setOptionsFxId,getReadCmdFxId,getWriteCmdFxId */ #endif #ifdef MXL12835F /* SPI Descriptor - MXL12835F */ .long 0x00000000 /* 0xFFFFFFFF to default 1-bit SPI mode ;DevStrAdr */ .long 0x001820C2 /* mfgId + extCount */ .long 0x00000000 /* extid 0-3 */ .long 0x00000000 /* extid 4-7 */ .long 0x0001001D /* caps */ .long 0x00000100 /* Blks + RESV1 */ .long 0x00010000 /* blkSize */ .long 0x00000000 /* subBlks + subBlkSize */ .long 0x00000100 /* pageSize + RESV2 */ .long 0x00003F00 /* maxReadSize */ .long 0x68506850 /* maxClkRate,maxReadRate,maxHSReadRate,maxProgramRate */ .long 0x06030050 /* maxHSProgramRate,initDeInitFxId,clearStatusFxId,getStatusFxId */ .long 0x14110F0B /* setStatusFxId,setOptionsFxId,getReadCmdFxId,getWriteCmdFxId */ #endif .text .thumb /* Reset Handler */ .thumb_func .align 2 .globl Reset_Handler .weak Reset_Handler .type Reset_Handler, %function Reset_Handler: #ifndef __NO_SYSTEM_INIT movs r0,#56 ldr r1, =0x40000220 str r0, [r1] /* Enable SRAM clock used by Stack */ ldr r0,=SystemInit blx r0 #endif /* Loop to copy data from read only memory to RAM. The ranges * of copy from/to are specified by following symbols evaluated in * linker script. * __etext: End of code section, i.e., begin of data sections to copy from. * __data_start__/__data_end__: RAM address range that data should be * copied to. Both must be aligned to 4 bytes boundary. */ ldr r1, =__etext ldr r2, =__data_start__ ldr r3, =__data_end__ #if 1 /* Here are two copies of loop implemenations. First one favors code size * and the second one favors performance. Default uses the first one. * Change to "#if 0" to use the second one */ .LC0: cmp r2, r3 ittt lt ldrlt r0, [r1], #4 strlt r0, [r2], #4 blt .LC0 #else subs r3, r2 ble .LC1 .LC0: subs r3, #4 ldr r0, [r1, r3] str r0, [r2, r3] bgt .LC0 .LC1: #endif #ifdef __STARTUP_CLEAR_BSS /* This part of work usually is done in C library startup code. Otherwise, * define this macro to enable it in this startup. * * Loop to zero out BSS section, which uses following symbols * in linker script: * __bss_start__: start of BSS section. Must align to 4 * __bss_end__: end of BSS section. Must align to 4 */ ldr r1, =__bss_start__ ldr r2, =__bss_end__ movs r0, 0 .LC2: cmp r1, r2 itt lt strlt r0, [r1], #4 blt .LC2 #endif /* __STARTUP_CLEAR_BSS */ #ifndef __START #define __START _start #endif #ifndef __ATOLLIC__ ldr r0,=__START blx r0 #else ldr r0,=__libc_init_array blx r0 ldr r0,=main bx r0 #endif .pool .size Reset_Handler, . - Reset_Handler .align 1 .thumb_func .weak DefaultISR .type DefaultISR, %function DefaultISR: b DefaultISR .size DefaultISR, . - DefaultISR .align 1 .thumb_func .weak NMI_Handler .type NMI_Handler, %function NMI_Handler: ldr r0,=NMI_Handler bx r0 .size NMI_Handler, . - NMI_Handler .align 1 .thumb_func .weak HardFault_Handler .type HardFault_Handler, %function HardFault_Handler: ldr r0,=HardFault_Handler bx r0 .size HardFault_Handler, . - HardFault_Handler .align 1 .thumb_func .weak SVC_Handler .type SVC_Handler, %function SVC_Handler: ldr r0,=SVC_Handler bx r0 .size SVC_Handler, . - SVC_Handler .align 1 .thumb_func .weak PendSV_Handler .type PendSV_Handler, %function PendSV_Handler: ldr r0,=PendSV_Handler bx r0 .size PendSV_Handler, . - PendSV_Handler .align 1 .thumb_func .weak SysTick_Handler .type SysTick_Handler, %function SysTick_Handler: ldr r0,=SysTick_Handler bx r0 .size SysTick_Handler, . - SysTick_Handler .align 1 .thumb_func .weak WDT_BOD_IRQHandler .type WDT_BOD_IRQHandler, %function WDT_BOD_IRQHandler: ldr r0,=WDT_BOD_DriverIRQHandler bx r0 .size WDT_BOD_IRQHandler, . - WDT_BOD_IRQHandler .align 1 .thumb_func .weak DMA0_IRQHandler .type DMA0_IRQHandler, %function DMA0_IRQHandler: ldr r0,=DMA0_DriverIRQHandler bx r0 .size DMA0_IRQHandler, . - DMA0_IRQHandler .align 1 .thumb_func .weak GINT0_IRQHandler .type GINT0_IRQHandler, %function GINT0_IRQHandler: ldr r0,=GINT0_DriverIRQHandler bx r0 .size GINT0_IRQHandler, . - GINT0_IRQHandler .align 1 .thumb_func .weak GINT1_IRQHandler .type GINT1_IRQHandler, %function GINT1_IRQHandler: ldr r0,=GINT1_DriverIRQHandler bx r0 .size GINT1_IRQHandler, . - GINT1_IRQHandler .align 1 .thumb_func .weak PIN_INT0_IRQHandler .type PIN_INT0_IRQHandler, %function PIN_INT0_IRQHandler: ldr r0,=PIN_INT0_DriverIRQHandler bx r0 .size PIN_INT0_IRQHandler, . - PIN_INT0_IRQHandler .align 1 .thumb_func .weak PIN_INT1_IRQHandler .type PIN_INT1_IRQHandler, %function PIN_INT1_IRQHandler: ldr r0,=PIN_INT1_DriverIRQHandler bx r0 .size PIN_INT1_IRQHandler, . - PIN_INT1_IRQHandler .align 1 .thumb_func .weak PIN_INT2_IRQHandler .type PIN_INT2_IRQHandler, %function PIN_INT2_IRQHandler: ldr r0,=PIN_INT2_DriverIRQHandler bx r0 .size PIN_INT2_IRQHandler, . - PIN_INT2_IRQHandler .align 1 .thumb_func .weak PIN_INT3_IRQHandler .type PIN_INT3_IRQHandler, %function PIN_INT3_IRQHandler: ldr r0,=PIN_INT3_DriverIRQHandler bx r0 .size PIN_INT3_IRQHandler, . - PIN_INT3_IRQHandler .align 1 .thumb_func .weak UTICK0_IRQHandler .type UTICK0_IRQHandler, %function UTICK0_IRQHandler: ldr r0,=UTICK0_DriverIRQHandler bx r0 .size UTICK0_IRQHandler, . - UTICK0_IRQHandler .align 1 .thumb_func .weak MRT0_IRQHandler .type MRT0_IRQHandler, %function MRT0_IRQHandler: ldr r0,=MRT0_DriverIRQHandler bx r0 .size MRT0_IRQHandler, . - MRT0_IRQHandler .align 1 .thumb_func .weak CTIMER0_IRQHandler .type CTIMER0_IRQHandler, %function CTIMER0_IRQHandler: ldr r0,=CTIMER0_DriverIRQHandler bx r0 .size CTIMER0_IRQHandler, . - CTIMER0_IRQHandler .align 1 .thumb_func .weak CTIMER1_IRQHandler .type CTIMER1_IRQHandler, %function CTIMER1_IRQHandler: ldr r0,=CTIMER1_DriverIRQHandler bx r0 .size CTIMER1_IRQHandler, . - CTIMER1_IRQHandler .align 1 .thumb_func .weak SCT0_IRQHandler .type SCT0_IRQHandler, %function SCT0_IRQHandler: ldr r0,=SCT0_DriverIRQHandler bx r0 .size SCT0_IRQHandler, . - SCT0_IRQHandler .align 1 .thumb_func .weak CTIMER3_IRQHandler .type CTIMER3_IRQHandler, %function CTIMER3_IRQHandler: ldr r0,=CTIMER3_DriverIRQHandler bx r0 .size CTIMER3_IRQHandler, . - CTIMER3_IRQHandler .align 1 .thumb_func .weak FLEXCOMM0_IRQHandler .type FLEXCOMM0_IRQHandler, %function FLEXCOMM0_IRQHandler: ldr r0,=FLEXCOMM0_DriverIRQHandler bx r0 .size FLEXCOMM0_IRQHandler, . - FLEXCOMM0_IRQHandler .align 1 .thumb_func .weak FLEXCOMM1_IRQHandler .type FLEXCOMM1_IRQHandler, %function FLEXCOMM1_IRQHandler: ldr r0,=FLEXCOMM1_DriverIRQHandler bx r0 .size FLEXCOMM1_IRQHandler, . - FLEXCOMM1_IRQHandler .align 1 .thumb_func .weak FLEXCOMM2_IRQHandler .type FLEXCOMM2_IRQHandler, %function FLEXCOMM2_IRQHandler: ldr r0,=FLEXCOMM2_DriverIRQHandler bx r0 .size FLEXCOMM2_IRQHandler, . - FLEXCOMM2_IRQHandler .align 1 .thumb_func .weak FLEXCOMM3_IRQHandler .type FLEXCOMM3_IRQHandler, %function FLEXCOMM3_IRQHandler: ldr r0,=FLEXCOMM3_DriverIRQHandler bx r0 .size FLEXCOMM3_IRQHandler, . - FLEXCOMM3_IRQHandler .align 1 .thumb_func .weak FLEXCOMM4_IRQHandler .type FLEXCOMM4_IRQHandler, %function FLEXCOMM4_IRQHandler: ldr r0,=FLEXCOMM4_DriverIRQHandler bx r0 .size FLEXCOMM4_IRQHandler, . - FLEXCOMM4_IRQHandler .align 1 .thumb_func .weak FLEXCOMM5_IRQHandler .type FLEXCOMM5_IRQHandler, %function FLEXCOMM5_IRQHandler: ldr r0,=FLEXCOMM5_DriverIRQHandler bx r0 .size FLEXCOMM5_IRQHandler, . - FLEXCOMM5_IRQHandler .align 1 .thumb_func .weak FLEXCOMM6_IRQHandler .type FLEXCOMM6_IRQHandler, %function FLEXCOMM6_IRQHandler: ldr r0,=FLEXCOMM6_DriverIRQHandler bx r0 .size FLEXCOMM6_IRQHandler, . - FLEXCOMM6_IRQHandler .align 1 .thumb_func .weak FLEXCOMM7_IRQHandler .type FLEXCOMM7_IRQHandler, %function FLEXCOMM7_IRQHandler: ldr r0,=FLEXCOMM7_DriverIRQHandler bx r0 .size FLEXCOMM7_IRQHandler, . - FLEXCOMM7_IRQHandler .align 1 .thumb_func .weak ADC0_SEQA_IRQHandler .type ADC0_SEQA_IRQHandler, %function ADC0_SEQA_IRQHandler: ldr r0,=ADC0_SEQA_DriverIRQHandler bx r0 .size ADC0_SEQA_IRQHandler, . - ADC0_SEQA_IRQHandler .align 1 .thumb_func .weak ADC0_SEQB_IRQHandler .type ADC0_SEQB_IRQHandler, %function ADC0_SEQB_IRQHandler: ldr r0,=ADC0_SEQB_DriverIRQHandler bx r0 .size ADC0_SEQB_IRQHandler, . - ADC0_SEQB_IRQHandler .align 1 .thumb_func .weak ADC0_THCMP_IRQHandler .type ADC0_THCMP_IRQHandler, %function ADC0_THCMP_IRQHandler: ldr r0,=ADC0_THCMP_DriverIRQHandler bx r0 .size ADC0_THCMP_IRQHandler, . - ADC0_THCMP_IRQHandler .align 1 .thumb_func .weak DMIC0_IRQHandler .type DMIC0_IRQHandler, %function DMIC0_IRQHandler: ldr r0,=DMIC0_DriverIRQHandler bx r0 .size DMIC0_IRQHandler, . - DMIC0_IRQHandler .align 1 .thumb_func .weak HWVAD0_IRQHandler .type HWVAD0_IRQHandler, %function HWVAD0_IRQHandler: ldr r0,=HWVAD0_DriverIRQHandler bx r0 .size HWVAD0_IRQHandler, . - HWVAD0_IRQHandler .align 1 .thumb_func .weak USB0_NEEDCLK_IRQHandler .type USB0_NEEDCLK_IRQHandler, %function USB0_NEEDCLK_IRQHandler: ldr r0,=USB0_NEEDCLK_DriverIRQHandler bx r0 .size USB0_NEEDCLK_IRQHandler, . - USB0_NEEDCLK_IRQHandler .align 1 .thumb_func .weak USB0_IRQHandler .type USB0_IRQHandler, %function USB0_IRQHandler: ldr r0,=USB0_DriverIRQHandler bx r0 .size USB0_IRQHandler, . - USB0_IRQHandler .align 1 .thumb_func .weak RTC_IRQHandler .type RTC_IRQHandler, %function RTC_IRQHandler: ldr r0,=RTC_DriverIRQHandler bx r0 .size RTC_IRQHandler, . - RTC_IRQHandler .align 1 .thumb_func .weak FLEXCOMM10_IRQHandler .type FLEXCOMM10_IRQHandler, %function FLEXCOMM10_IRQHandler: ldr r0,=FLEXCOMM10_DriverIRQHandler bx r0 .size FLEXCOMM10_IRQHandler, . - FLEXCOMM10_IRQHandler .align 1 .thumb_func .weak Reserved47_IRQHandler .type Reserved47_IRQHandler, %function Reserved47_IRQHandler: ldr r0,=Reserved47_DriverIRQHandler bx r0 .size Reserved47_IRQHandler, . - Reserved47_IRQHandler .align 1 .thumb_func .weak PIN_INT4_IRQHandler .type PIN_INT4_IRQHandler, %function PIN_INT4_IRQHandler: ldr r0,=PIN_INT4_DriverIRQHandler bx r0 .size PIN_INT4_IRQHandler, . - PIN_INT4_IRQHandler .align 1 .thumb_func .weak PIN_INT5_IRQHandler .type PIN_INT5_IRQHandler, %function PIN_INT5_IRQHandler: ldr r0,=PIN_INT5_DriverIRQHandler bx r0 .size PIN_INT5_IRQHandler, . - PIN_INT5_IRQHandler .align 1 .thumb_func .weak PIN_INT6_IRQHandler .type PIN_INT6_IRQHandler, %function PIN_INT6_IRQHandler: ldr r0,=PIN_INT6_DriverIRQHandler bx r0 .size PIN_INT6_IRQHandler, . - PIN_INT6_IRQHandler .align 1 .thumb_func .weak PIN_INT7_IRQHandler .type PIN_INT7_IRQHandler, %function PIN_INT7_IRQHandler: ldr r0,=PIN_INT7_DriverIRQHandler bx r0 .size PIN_INT7_IRQHandler, . - PIN_INT7_IRQHandler .align 1 .thumb_func .weak CTIMER2_IRQHandler .type CTIMER2_IRQHandler, %function CTIMER2_IRQHandler: ldr r0,=CTIMER2_DriverIRQHandler bx r0 .size CTIMER2_IRQHandler, . - CTIMER2_IRQHandler .align 1 .thumb_func .weak CTIMER4_IRQHandler .type CTIMER4_IRQHandler, %function CTIMER4_IRQHandler: ldr r0,=CTIMER4_DriverIRQHandler bx r0 .size CTIMER4_IRQHandler, . - CTIMER4_IRQHandler .align 1 .thumb_func .weak RIT_IRQHandler .type RIT_IRQHandler, %function RIT_IRQHandler: ldr r0,=RIT_DriverIRQHandler bx r0 .size RIT_IRQHandler, . - RIT_IRQHandler .align 1 .thumb_func .weak SPIFI0_IRQHandler .type SPIFI0_IRQHandler, %function SPIFI0_IRQHandler: ldr r0,=SPIFI0_DriverIRQHandler bx r0 .size SPIFI0_IRQHandler, . - SPIFI0_IRQHandler .align 1 .thumb_func .weak FLEXCOMM8_IRQHandler .type FLEXCOMM8_IRQHandler, %function FLEXCOMM8_IRQHandler: ldr r0,=FLEXCOMM8_DriverIRQHandler bx r0 .size FLEXCOMM8_IRQHandler, . - FLEXCOMM8_IRQHandler .align 1 .thumb_func .weak FLEXCOMM9_IRQHandler .type FLEXCOMM9_IRQHandler, %function FLEXCOMM9_IRQHandler: ldr r0,=FLEXCOMM9_DriverIRQHandler bx r0 .size FLEXCOMM9_IRQHandler, . - FLEXCOMM9_IRQHandler .align 1 .thumb_func .weak SDIO_IRQHandler .type SDIO_IRQHandler, %function SDIO_IRQHandler: ldr r0,=SDIO_DriverIRQHandler bx r0 .size SDIO_IRQHandler, . - SDIO_IRQHandler .align 1 .thumb_func .weak CAN0_IRQ0_IRQHandler .type CAN0_IRQ0_IRQHandler, %function CAN0_IRQ0_IRQHandler: ldr r0,=CAN0_IRQ0_DriverIRQHandler bx r0 .size CAN0_IRQ0_IRQHandler, . - CAN0_IRQ0_IRQHandler .align 1 .thumb_func .weak CAN0_IRQ1_IRQHandler .type CAN0_IRQ1_IRQHandler, %function CAN0_IRQ1_IRQHandler: ldr r0,=CAN0_IRQ1_DriverIRQHandler bx r0 .size CAN0_IRQ1_IRQHandler, . - CAN0_IRQ1_IRQHandler .align 1 .thumb_func .weak CAN1_IRQ0_IRQHandler .type CAN1_IRQ0_IRQHandler, %function CAN1_IRQ0_IRQHandler: ldr r0,=CAN1_IRQ0_DriverIRQHandler bx r0 .size CAN1_IRQ0_IRQHandler, . - CAN1_IRQ0_IRQHandler .align 1 .thumb_func .weak CAN1_IRQ1_IRQHandler .type CAN1_IRQ1_IRQHandler, %function CAN1_IRQ1_IRQHandler: ldr r0,=CAN1_IRQ1_DriverIRQHandler bx r0 .size CAN1_IRQ1_IRQHandler, . - CAN1_IRQ1_IRQHandler .align 1 .thumb_func .weak USB1_IRQHandler .type USB1_IRQHandler, %function USB1_IRQHandler: ldr r0,=USB1_DriverIRQHandler bx r0 .size USB1_IRQHandler, . - USB1_IRQHandler .align 1 .thumb_func .weak USB1_NEEDCLK_IRQHandler .type USB1_NEEDCLK_IRQHandler, %function USB1_NEEDCLK_IRQHandler: ldr r0,=USB1_NEEDCLK_DriverIRQHandler bx r0 .size USB1_NEEDCLK_IRQHandler, . - USB1_NEEDCLK_IRQHandler .align 1 .thumb_func .weak ETHERNET_IRQHandler .type ETHERNET_IRQHandler, %function ETHERNET_IRQHandler: ldr r0,=ETHERNET_DriverIRQHandler bx r0 .size ETHERNET_IRQHandler, . - ETHERNET_IRQHandler .align 1 .thumb_func .weak ETHERNET_PMT_IRQHandler .type ETHERNET_PMT_IRQHandler, %function ETHERNET_PMT_IRQHandler: ldr r0,=ETHERNET_PMT_DriverIRQHandler bx r0 .size ETHERNET_PMT_IRQHandler, . - ETHERNET_PMT_IRQHandler .align 1 .thumb_func .weak ETHERNET_MACLP_IRQHandler .type ETHERNET_MACLP_IRQHandler, %function ETHERNET_MACLP_IRQHandler: ldr r0,=ETHERNET_MACLP_DriverIRQHandler bx r0 .size ETHERNET_MACLP_IRQHandler, . - ETHERNET_MACLP_IRQHandler .align 1 .thumb_func .weak Reserved68_IRQHandler .type Reserved68_IRQHandler, %function Reserved68_IRQHandler: ldr r0,=Reserved68_DriverIRQHandler bx r0 .size Reserved68_IRQHandler, . - Reserved68_IRQHandler .align 1 .thumb_func .weak LCD_IRQHandler .type LCD_IRQHandler, %function LCD_IRQHandler: ldr r0,=LCD_DriverIRQHandler bx r0 .size LCD_IRQHandler, . - LCD_IRQHandler .align 1 .thumb_func .weak SHA_IRQHandler .type SHA_IRQHandler, %function SHA_IRQHandler: ldr r0,=SHA_DriverIRQHandler bx r0 .size SHA_IRQHandler, . - SHA_IRQHandler .align 1 .thumb_func .weak SMARTCARD0_IRQHandler .type SMARTCARD0_IRQHandler, %function SMARTCARD0_IRQHandler: ldr r0,=SMARTCARD0_DriverIRQHandler bx r0 .size SMARTCARD0_IRQHandler, . - SMARTCARD0_IRQHandler .align 1 .thumb_func .weak SMARTCARD1_IRQHandler .type SMARTCARD1_IRQHandler, %function SMARTCARD1_IRQHandler: ldr r0,=SMARTCARD1_DriverIRQHandler bx r0 .size SMARTCARD1_IRQHandler, . - SMARTCARD1_IRQHandler /* Macro to define default handlers. Default handler * will be weak symbol and just dead loops. They can be * overwritten by other handlers */ .macro def_irq_handler handler_name .weak \handler_name .set \handler_name, DefaultISR .endm /* Exception Handlers */ def_irq_handler MemManage_Handler def_irq_handler BusFault_Handler def_irq_handler UsageFault_Handler def_irq_handler DebugMon_Handler def_irq_handler WDT_BOD_DriverIRQHandler def_irq_handler DMA0_DriverIRQHandler def_irq_handler GINT0_DriverIRQHandler def_irq_handler GINT1_DriverIRQHandler def_irq_handler PIN_INT0_DriverIRQHandler def_irq_handler PIN_INT1_DriverIRQHandler def_irq_handler PIN_INT2_DriverIRQHandler def_irq_handler PIN_INT3_DriverIRQHandler def_irq_handler UTICK0_DriverIRQHandler def_irq_handler MRT0_DriverIRQHandler def_irq_handler CTIMER0_DriverIRQHandler def_irq_handler CTIMER1_DriverIRQHandler def_irq_handler SCT0_DriverIRQHandler def_irq_handler CTIMER3_DriverIRQHandler def_irq_handler FLEXCOMM0_DriverIRQHandler def_irq_handler FLEXCOMM1_DriverIRQHandler def_irq_handler FLEXCOMM2_DriverIRQHandler def_irq_handler FLEXCOMM3_DriverIRQHandler def_irq_handler FLEXCOMM4_DriverIRQHandler def_irq_handler FLEXCOMM5_DriverIRQHandler def_irq_handler FLEXCOMM6_DriverIRQHandler def_irq_handler FLEXCOMM7_DriverIRQHandler def_irq_handler ADC0_SEQA_DriverIRQHandler def_irq_handler ADC0_SEQB_DriverIRQHandler def_irq_handler ADC0_THCMP_DriverIRQHandler def_irq_handler DMIC0_DriverIRQHandler def_irq_handler HWVAD0_DriverIRQHandler def_irq_handler USB0_NEEDCLK_DriverIRQHandler def_irq_handler USB0_DriverIRQHandler def_irq_handler RTC_DriverIRQHandler def_irq_handler FLEXCOMM10_DriverIRQHandler def_irq_handler Reserved47_DriverIRQHandler def_irq_handler PIN_INT4_DriverIRQHandler def_irq_handler PIN_INT5_DriverIRQHandler def_irq_handler PIN_INT6_DriverIRQHandler def_irq_handler PIN_INT7_DriverIRQHandler def_irq_handler CTIMER2_DriverIRQHandler def_irq_handler CTIMER4_DriverIRQHandler def_irq_handler RIT_DriverIRQHandler def_irq_handler SPIFI0_DriverIRQHandler def_irq_handler FLEXCOMM8_DriverIRQHandler def_irq_handler FLEXCOMM9_DriverIRQHandler def_irq_handler SDIO_DriverIRQHandler def_irq_handler CAN0_IRQ0_DriverIRQHandler def_irq_handler CAN0_IRQ1_DriverIRQHandler def_irq_handler CAN1_IRQ0_DriverIRQHandler def_irq_handler CAN1_IRQ1_DriverIRQHandler def_irq_handler USB1_DriverIRQHandler def_irq_handler USB1_NEEDCLK_DriverIRQHandler def_irq_handler ETHERNET_DriverIRQHandler def_irq_handler ETHERNET_PMT_DriverIRQHandler def_irq_handler ETHERNET_MACLP_DriverIRQHandler def_irq_handler Reserved68_DriverIRQHandler def_irq_handler LCD_DriverIRQHandler def_irq_handler SHA_DriverIRQHandler def_irq_handler SMARTCARD0_DriverIRQHandler def_irq_handler SMARTCARD1_DriverIRQHandler .end