1/* ------------------------------------------------------------------------- */
2/*  @file:    startup_LPC54018M.s                                            */
3/*  @purpose: CMSIS Cortex-M4 Core Device Startup File                       */
4/*            LPC54018M                                                      */
5/*  @version: 1.2                                                            */
6/*  @date:    2017-6-8                                                       */
7/*  @build:   b231018                                                        */
8/* ------------------------------------------------------------------------- */
9/*                                                                           */
10/* Copyright 1997-2016 Freescale Semiconductor, Inc.                         */
11/* Copyright 2016-2023 NXP                                                   */
12/* SPDX-License-Identifier: BSD-3-Clause                                     */
13/*****************************************************************************/
14/* Version: GCC for ARM Embedded Processors                                  */
15/*****************************************************************************/
16    .syntax unified
17    .arch armv7-m
18
19    .section .isr_vector, "a"
20    .align 2
21    .globl __Vectors
22__Vectors:
23    .long   __StackTop                                      /* Top of Stack */
24    .long   Reset_Handler                                   /* Reset Handler */
25    .long   NMI_Handler                                     /* NMI Handler*/
26    .long   HardFault_Handler                               /* Hard Fault Handler*/
27    .long   MemManage_Handler                               /* MPU Fault Handler*/
28    .long   BusFault_Handler                                /* Bus Fault Handler*/
29    .long   UsageFault_Handler                              /* Usage Fault Handler*/
30    .long   0                                               /* Reserved*/
31    .long   0                                               /* Reserved*/
32    .long   0xEDDC94BD                                      /* Enhanced image marker, set to 0x0 for legacy boot*/
33    .long   0x160                                           /* Pointer to enhanced boot block, set to 0x0 for legacy boot*/
34    .long   SVC_Handler                                     /* SVCall Handler*/
35    .long   DebugMon_Handler                                /* Debug Monitor Handler*/
36    .long   0                                               /* Reserved*/
37    .long   PendSV_Handler                                  /* PendSV Handler*/
38    .long   SysTick_Handler                                 /* SysTick Handler*/
39
40                                                            /* External Interrupts*/
41    .long   WDT_BOD_IRQHandler                              /* Windowed watchdog timer, Brownout detect*/
42    .long   DMA0_IRQHandler                                 /* DMA controller*/
43    .long   GINT0_IRQHandler                                /* GPIO group 0*/
44    .long   GINT1_IRQHandler                                /* GPIO group 1*/
45    .long   PIN_INT0_IRQHandler                             /* Pin interrupt 0 or pattern match engine slice 0*/
46    .long   PIN_INT1_IRQHandler                             /* Pin interrupt 1or pattern match engine slice 1*/
47    .long   PIN_INT2_IRQHandler                             /* Pin interrupt 2 or pattern match engine slice 2*/
48    .long   PIN_INT3_IRQHandler                             /* Pin interrupt 3 or pattern match engine slice 3*/
49    .long   UTICK0_IRQHandler                               /* Micro-tick Timer*/
50    .long   MRT0_IRQHandler                                 /* Multi-rate timer*/
51    .long   CTIMER0_IRQHandler                              /* Standard counter/timer CTIMER0*/
52    .long   CTIMER1_IRQHandler                              /* Standard counter/timer CTIMER1*/
53    .long   SCT0_IRQHandler                                 /* SCTimer/PWM*/
54    .long   CTIMER3_IRQHandler                              /* Standard counter/timer CTIMER3*/
55    .long   FLEXCOMM0_IRQHandler                            /* Flexcomm Interface 0 (USART, SPI, I2C, FLEXCOMM)*/
56    .long   FLEXCOMM1_IRQHandler                            /* Flexcomm Interface 1 (USART, SPI, I2C, FLEXCOMM)*/
57    .long   FLEXCOMM2_IRQHandler                            /* Flexcomm Interface 2 (USART, SPI, I2C, FLEXCOMM)*/
58    .long   FLEXCOMM3_IRQHandler                            /* Flexcomm Interface 3 (USART, SPI, I2C, FLEXCOMM)*/
59    .long   FLEXCOMM4_IRQHandler                            /* Flexcomm Interface 4 (USART, SPI, I2C, FLEXCOMM)*/
60    .long   FLEXCOMM5_IRQHandler                            /* Flexcomm Interface 5 (USART, SPI, I2C,, FLEXCOMM)*/
61    .long   FLEXCOMM6_IRQHandler                            /* Flexcomm Interface 6 (USART, SPI, I2C, I2S,, FLEXCOMM)*/
62    .long   FLEXCOMM7_IRQHandler                            /* Flexcomm Interface 7 (USART, SPI, I2C, I2S,, FLEXCOMM)*/
63    .long   ADC0_SEQA_IRQHandler                            /* ADC0 sequence A completion.*/
64    .long   ADC0_SEQB_IRQHandler                            /* ADC0 sequence B completion.*/
65    .long   ADC0_THCMP_IRQHandler                           /* ADC0 threshold compare and error.*/
66    .long   DMIC0_IRQHandler                                /* Digital microphone and DMIC subsystem*/
67    .long   HWVAD0_IRQHandler                               /* Hardware Voice Activity Detector*/
68    .long   USB0_NEEDCLK_IRQHandler                         /* USB Activity Wake-up Interrupt*/
69    .long   USB0_IRQHandler                                 /* USB device*/
70    .long   RTC_IRQHandler                                  /* RTC alarm and wake-up interrupts*/
71    .long   FLEXCOMM10_IRQHandler                           /* Flexcomm Interface 10 (SPI, FLEXCOMM)*/
72    .long   Reserved47_IRQHandler                           /* Reserved interrupt*/
73    .long   PIN_INT4_IRQHandler                             /* Pin interrupt 4 or pattern match engine slice 4 int*/
74    .long   PIN_INT5_IRQHandler                             /* Pin interrupt 5 or pattern match engine slice 5 int*/
75    .long   PIN_INT6_IRQHandler                             /* Pin interrupt 6 or pattern match engine slice 6 int*/
76    .long   PIN_INT7_IRQHandler                             /* Pin interrupt 7 or pattern match engine slice 7 int*/
77    .long   CTIMER2_IRQHandler                              /* Standard counter/timer CTIMER2*/
78    .long   CTIMER4_IRQHandler                              /* Standard counter/timer CTIMER4*/
79    .long   RIT_IRQHandler                                  /* Repetitive Interrupt Timer*/
80    .long   SPIFI0_IRQHandler                               /* SPI flash interface*/
81    .long   FLEXCOMM8_IRQHandler                            /* Flexcomm Interface 8 (USART, SPI, I2C, FLEXCOMM)*/
82    .long   FLEXCOMM9_IRQHandler                            /* Flexcomm Interface 9 (USART, SPI, I2C, FLEXCOMM)*/
83    .long   SDIO_IRQHandler                                 /* SD/MMC */
84    .long   CAN0_IRQ0_IRQHandler                            /* CAN0 interrupt0*/
85    .long   CAN0_IRQ1_IRQHandler                            /* CAN0 interrupt1*/
86    .long   CAN1_IRQ0_IRQHandler                            /* CAN1 interrupt0*/
87    .long   CAN1_IRQ1_IRQHandler                            /* CAN1 interrupt1*/
88    .long   USB1_IRQHandler                                 /* USB1 interrupt*/
89    .long   USB1_NEEDCLK_IRQHandler                         /* USB1 activity*/
90    .long   ETHERNET_IRQHandler                             /* Ethernet*/
91    .long   ETHERNET_PMT_IRQHandler                         /* Ethernet power management interrupt*/
92    .long   ETHERNET_MACLP_IRQHandler                       /* Ethernet MAC interrupt*/
93    .long   Reserved68_IRQHandler                           /* Reserved interrupt*/
94    .long   LCD_IRQHandler                                  /* LCD interrupt*/
95    .long   SHA_IRQHandler                                  /* SHA interrupt*/
96    .long   SMARTCARD0_IRQHandler                           /* Smart card 0 interrupt*/
97    .long   SMARTCARD1_IRQHandler                           /* Smart card 1 interrupt*/
98
99    .size   __Vectors, . - __Vectors
100
101
102    .long   0                                               /* Reserved */
103    .long   0                                               /* Reserved */
104    .long   0                                               /* Reserved */
105    .long   0                                               /* Reserved */
106    .long   0                                               /* Reserved */
107    .long   0                                               /* Reserved */
108    .long   0                                               /* Reserved */
109    .long   0                                               /* Reserved */
110    .long   0                                               /* Reserved */
111    .long   0                                               /* Reserved */
112    .long   0                                               /* Reserved */
113    .long   0                                               /* Reserved */
114    .long   0                                               /* Reserved */
115    .long   0                                               /* Reserved */
116    .long   0                                               /* Reserved */
117
118#ifndef IMG_BAUDRATE
119#define IMG_BAUDRATE 0
120#endif
121
122__image_header:
123    .long   0xFEEDA5A5                                      /* (0x00, 0x160) Header Marker */
124    #ifdef XIP_IMAGE
125          #ifdef ADD_CRC
126          .long   0x2                                       /* (0x04) Image Type */
127          #else
128          .long   0x3                                       /* (0x04) Image Type */
129          #endif
130    #else
131          #ifdef ADD_CRC
132          .long   0x0                                       /* (0x04) Image Type */
133          #else
134          .long   0x1                                       /* (0x04) Image Type */
135          #endif
136    #endif
137
138    #ifdef XIP_IMAGE
139          .long   0x10000000                                /* (0x08) Load_address */
140    #else
141          .long   0x00000000                                /* (0x08) Load_address */
142    #endif
143    .long   __IMAGE_SIZE - 4                                /* (0x0C) load_length, exclude 4 bytes CRC field */
144    .long   0                                               /* (0x10) CRC value (only applicable to NON Non-secure images) */
145    .long   0                                               /* (0x14) Version (only applicable to DUAL_ENH image type */
146    .long   0                                               /* (0x18) EMC static memory configuration settings, required for EMC boot */
147    .long   IMG_BAUDRATE                                    /* image baudrate */
148    .long   0                                               /* Reserved */
149    .long   0xEDDC94BD                                      /* (0x24) Image_marker */
150    .long   0                                               /* (0x28) SBZ */
151    .long   0                                               /* (0x2C) reserved */
152
153    /* SPI Descriptor - Winbond W25Q32JV */
154    .long   0x00000000                                      /* 0xFFFFFFFF to default 1-bit SPI mode  ;DevStrAdr */
155    .long   0x001640EF                                      /* mfgId + extCount */
156    .long   0x00000000                                      /* extid 0-3 */
157    .long   0x00000000                                      /* reserved */
158    .long   0x1301001D                                      /* caps */
159    .long   0x00000000                                      /* Blks + RESV1 */
160    .long   0x00000000                                      /* blkSize */
161    .long   0x00000000                                      /* reserved */
162    .long   0x00000100                                      /* pageSize + RESV2 */
163    .long   0x00000000                                      /* maxReadSize */
164    .long   0x00000000                                      /* maxClkRate,maxReadRate,maxHSReadRate,maxProgramRate */
165    .long   0x04030050                                      /* maxHSProgramRate,initDeInitFxId,clearStatusFxId,getStatusFxId */
166    .long   0x14110D09                                      /* setStatusFxId,setOptionsFxId,getReadCmdFxId,getWriteCmdFxId */
167
168    .text
169    .thumb
170
171#if defined (__cplusplus)
172#ifdef __REDLIB__
173#error Redlib does not support C++
174#endif
175#endif
176/* Reset Handler */
177
178    .thumb_func
179    .align 2
180    .globl   Reset_Handler
181    .weak    Reset_Handler
182    .type    Reset_Handler, %function
183Reset_Handler:
184#ifndef __NO_SYSTEM_INIT
185    movs  r0,#56
186    ldr   r1, =0x40000220
187    str   r0, [r1]           /* Enable SRAM clock used by Stack */
188    ldr   r0,=SystemInit
189    blx   r0
190#endif
191/*     Loop to copy data from read only memory to RAM. The ranges
192 *      of copy from/to are specified by following symbols evaluated in
193 *      linker script.
194 *      __etext: End of code section, i.e., begin of data sections to copy from.
195 *      __data_start__/__data_end__: RAM address range that data should be
196 *      copied to. Both must be aligned to 4 bytes boundary.  */
197
198    ldr    r1, =__etext
199    ldr    r2, =__data_start__
200    ldr    r3, =__data_end__
201
202#if 1
203/* Here are two copies of loop implemenations. First one favors code size
204 * and the second one favors performance. Default uses the first one.
205 * Change to "#if 0" to use the second one */
206.LC0:
207    cmp     r2, r3
208    ittt    lt
209    ldrlt   r0, [r1], #4
210    strlt   r0, [r2], #4
211    blt    .LC0
212#else
213    subs    r3, r2
214    ble    .LC1
215.LC0:
216    subs    r3, #4
217    ldr    r0, [r1, r3]
218    str    r0, [r2, r3]
219    bgt    .LC0
220.LC1:
221#endif
222
223#ifdef __STARTUP_CLEAR_BSS
224/*     This part of work usually is done in C library startup code. Otherwise,
225 *     define this macro to enable it in this startup.
226 *
227 *     Loop to zero out BSS section, which uses following symbols
228 *     in linker script:
229 *      __bss_start__: start of BSS section. Must align to 4
230 *      __bss_end__: end of BSS section. Must align to 4
231 */
232    ldr r1, =__bss_start__
233    ldr r2, =__bss_end__
234
235    movs    r0, 0
236.LC2:
237    cmp     r1, r2
238    itt    lt
239    strlt   r0, [r1], #4
240    blt    .LC2
241#endif /* __STARTUP_CLEAR_BSS */
242
243#ifndef __START
244#ifdef __REDLIB__
245#define __START __main
246#else
247#define __START _start
248#endif
249#endif
250#ifndef __ATOLLIC__
251    ldr   r0,=__START
252    blx   r0
253#else
254    ldr   r0,=__libc_init_array
255    blx   r0
256    ldr   r0,=main
257    bx    r0
258#endif
259    .pool
260    .size Reset_Handler, . - Reset_Handler
261
262    .align  1
263    .thumb_func
264    .weak DefaultISR
265    .type DefaultISR, %function
266DefaultISR:
267    b DefaultISR
268    .size DefaultISR, . - DefaultISR
269
270    .align 1
271    .thumb_func
272    .weak NMI_Handler
273    .type NMI_Handler, %function
274NMI_Handler:
275    ldr   r0,=NMI_Handler
276    bx    r0
277    .size NMI_Handler, . - NMI_Handler
278
279    .align 1
280    .thumb_func
281    .weak HardFault_Handler
282    .type HardFault_Handler, %function
283HardFault_Handler:
284    ldr   r0,=HardFault_Handler
285    bx    r0
286    .size HardFault_Handler, . - HardFault_Handler
287
288    .align 1
289    .thumb_func
290    .weak SVC_Handler
291    .type SVC_Handler, %function
292SVC_Handler:
293    ldr   r0,=SVC_Handler
294    bx    r0
295    .size SVC_Handler, . - SVC_Handler
296
297    .align 1
298    .thumb_func
299    .weak PendSV_Handler
300    .type PendSV_Handler, %function
301PendSV_Handler:
302    ldr   r0,=PendSV_Handler
303    bx    r0
304    .size PendSV_Handler, . - PendSV_Handler
305
306    .align 1
307    .thumb_func
308    .weak SysTick_Handler
309    .type SysTick_Handler, %function
310SysTick_Handler:
311    ldr   r0,=SysTick_Handler
312    bx    r0
313    .size SysTick_Handler, . - SysTick_Handler
314
315    .align 1
316    .thumb_func
317    .weak WDT_BOD_IRQHandler
318    .type WDT_BOD_IRQHandler, %function
319WDT_BOD_IRQHandler:
320    ldr   r0,=WDT_BOD_DriverIRQHandler
321    bx    r0
322    .size WDT_BOD_IRQHandler, . - WDT_BOD_IRQHandler
323
324    .align 1
325    .thumb_func
326    .weak DMA0_IRQHandler
327    .type DMA0_IRQHandler, %function
328DMA0_IRQHandler:
329    ldr   r0,=DMA0_DriverIRQHandler
330    bx    r0
331    .size DMA0_IRQHandler, . - DMA0_IRQHandler
332
333    .align 1
334    .thumb_func
335    .weak GINT0_IRQHandler
336    .type GINT0_IRQHandler, %function
337GINT0_IRQHandler:
338    ldr   r0,=GINT0_DriverIRQHandler
339    bx    r0
340    .size GINT0_IRQHandler, . - GINT0_IRQHandler
341
342    .align 1
343    .thumb_func
344    .weak GINT1_IRQHandler
345    .type GINT1_IRQHandler, %function
346GINT1_IRQHandler:
347    ldr   r0,=GINT1_DriverIRQHandler
348    bx    r0
349    .size GINT1_IRQHandler, . - GINT1_IRQHandler
350
351    .align 1
352    .thumb_func
353    .weak PIN_INT0_IRQHandler
354    .type PIN_INT0_IRQHandler, %function
355PIN_INT0_IRQHandler:
356    ldr   r0,=PIN_INT0_DriverIRQHandler
357    bx    r0
358    .size PIN_INT0_IRQHandler, . - PIN_INT0_IRQHandler
359
360    .align 1
361    .thumb_func
362    .weak PIN_INT1_IRQHandler
363    .type PIN_INT1_IRQHandler, %function
364PIN_INT1_IRQHandler:
365    ldr   r0,=PIN_INT1_DriverIRQHandler
366    bx    r0
367    .size PIN_INT1_IRQHandler, . - PIN_INT1_IRQHandler
368
369    .align 1
370    .thumb_func
371    .weak PIN_INT2_IRQHandler
372    .type PIN_INT2_IRQHandler, %function
373PIN_INT2_IRQHandler:
374    ldr   r0,=PIN_INT2_DriverIRQHandler
375    bx    r0
376    .size PIN_INT2_IRQHandler, . - PIN_INT2_IRQHandler
377
378    .align 1
379    .thumb_func
380    .weak PIN_INT3_IRQHandler
381    .type PIN_INT3_IRQHandler, %function
382PIN_INT3_IRQHandler:
383    ldr   r0,=PIN_INT3_DriverIRQHandler
384    bx    r0
385    .size PIN_INT3_IRQHandler, . - PIN_INT3_IRQHandler
386
387    .align 1
388    .thumb_func
389    .weak UTICK0_IRQHandler
390    .type UTICK0_IRQHandler, %function
391UTICK0_IRQHandler:
392    ldr   r0,=UTICK0_DriverIRQHandler
393    bx    r0
394    .size UTICK0_IRQHandler, . - UTICK0_IRQHandler
395
396    .align 1
397    .thumb_func
398    .weak MRT0_IRQHandler
399    .type MRT0_IRQHandler, %function
400MRT0_IRQHandler:
401    ldr   r0,=MRT0_DriverIRQHandler
402    bx    r0
403    .size MRT0_IRQHandler, . - MRT0_IRQHandler
404
405    .align 1
406    .thumb_func
407    .weak CTIMER0_IRQHandler
408    .type CTIMER0_IRQHandler, %function
409CTIMER0_IRQHandler:
410    ldr   r0,=CTIMER0_DriverIRQHandler
411    bx    r0
412    .size CTIMER0_IRQHandler, . - CTIMER0_IRQHandler
413
414    .align 1
415    .thumb_func
416    .weak CTIMER1_IRQHandler
417    .type CTIMER1_IRQHandler, %function
418CTIMER1_IRQHandler:
419    ldr   r0,=CTIMER1_DriverIRQHandler
420    bx    r0
421    .size CTIMER1_IRQHandler, . - CTIMER1_IRQHandler
422
423    .align 1
424    .thumb_func
425    .weak SCT0_IRQHandler
426    .type SCT0_IRQHandler, %function
427SCT0_IRQHandler:
428    ldr   r0,=SCT0_DriverIRQHandler
429    bx    r0
430    .size SCT0_IRQHandler, . - SCT0_IRQHandler
431
432    .align 1
433    .thumb_func
434    .weak CTIMER3_IRQHandler
435    .type CTIMER3_IRQHandler, %function
436CTIMER3_IRQHandler:
437    ldr   r0,=CTIMER3_DriverIRQHandler
438    bx    r0
439    .size CTIMER3_IRQHandler, . - CTIMER3_IRQHandler
440
441    .align 1
442    .thumb_func
443    .weak FLEXCOMM0_IRQHandler
444    .type FLEXCOMM0_IRQHandler, %function
445FLEXCOMM0_IRQHandler:
446    ldr   r0,=FLEXCOMM0_DriverIRQHandler
447    bx    r0
448    .size FLEXCOMM0_IRQHandler, . - FLEXCOMM0_IRQHandler
449
450    .align 1
451    .thumb_func
452    .weak FLEXCOMM1_IRQHandler
453    .type FLEXCOMM1_IRQHandler, %function
454FLEXCOMM1_IRQHandler:
455    ldr   r0,=FLEXCOMM1_DriverIRQHandler
456    bx    r0
457    .size FLEXCOMM1_IRQHandler, . - FLEXCOMM1_IRQHandler
458
459    .align 1
460    .thumb_func
461    .weak FLEXCOMM2_IRQHandler
462    .type FLEXCOMM2_IRQHandler, %function
463FLEXCOMM2_IRQHandler:
464    ldr   r0,=FLEXCOMM2_DriverIRQHandler
465    bx    r0
466    .size FLEXCOMM2_IRQHandler, . - FLEXCOMM2_IRQHandler
467
468    .align 1
469    .thumb_func
470    .weak FLEXCOMM3_IRQHandler
471    .type FLEXCOMM3_IRQHandler, %function
472FLEXCOMM3_IRQHandler:
473    ldr   r0,=FLEXCOMM3_DriverIRQHandler
474    bx    r0
475    .size FLEXCOMM3_IRQHandler, . - FLEXCOMM3_IRQHandler
476
477    .align 1
478    .thumb_func
479    .weak FLEXCOMM4_IRQHandler
480    .type FLEXCOMM4_IRQHandler, %function
481FLEXCOMM4_IRQHandler:
482    ldr   r0,=FLEXCOMM4_DriverIRQHandler
483    bx    r0
484    .size FLEXCOMM4_IRQHandler, . - FLEXCOMM4_IRQHandler
485
486    .align 1
487    .thumb_func
488    .weak FLEXCOMM5_IRQHandler
489    .type FLEXCOMM5_IRQHandler, %function
490FLEXCOMM5_IRQHandler:
491    ldr   r0,=FLEXCOMM5_DriverIRQHandler
492    bx    r0
493    .size FLEXCOMM5_IRQHandler, . - FLEXCOMM5_IRQHandler
494
495    .align 1
496    .thumb_func
497    .weak FLEXCOMM6_IRQHandler
498    .type FLEXCOMM6_IRQHandler, %function
499FLEXCOMM6_IRQHandler:
500    ldr   r0,=FLEXCOMM6_DriverIRQHandler
501    bx    r0
502    .size FLEXCOMM6_IRQHandler, . - FLEXCOMM6_IRQHandler
503
504    .align 1
505    .thumb_func
506    .weak FLEXCOMM7_IRQHandler
507    .type FLEXCOMM7_IRQHandler, %function
508FLEXCOMM7_IRQHandler:
509    ldr   r0,=FLEXCOMM7_DriverIRQHandler
510    bx    r0
511    .size FLEXCOMM7_IRQHandler, . - FLEXCOMM7_IRQHandler
512
513    .align 1
514    .thumb_func
515    .weak ADC0_SEQA_IRQHandler
516    .type ADC0_SEQA_IRQHandler, %function
517ADC0_SEQA_IRQHandler:
518    ldr   r0,=ADC0_SEQA_DriverIRQHandler
519    bx    r0
520    .size ADC0_SEQA_IRQHandler, . - ADC0_SEQA_IRQHandler
521
522    .align 1
523    .thumb_func
524    .weak ADC0_SEQB_IRQHandler
525    .type ADC0_SEQB_IRQHandler, %function
526ADC0_SEQB_IRQHandler:
527    ldr   r0,=ADC0_SEQB_DriverIRQHandler
528    bx    r0
529    .size ADC0_SEQB_IRQHandler, . - ADC0_SEQB_IRQHandler
530
531    .align 1
532    .thumb_func
533    .weak ADC0_THCMP_IRQHandler
534    .type ADC0_THCMP_IRQHandler, %function
535ADC0_THCMP_IRQHandler:
536    ldr   r0,=ADC0_THCMP_DriverIRQHandler
537    bx    r0
538    .size ADC0_THCMP_IRQHandler, . - ADC0_THCMP_IRQHandler
539
540    .align 1
541    .thumb_func
542    .weak DMIC0_IRQHandler
543    .type DMIC0_IRQHandler, %function
544DMIC0_IRQHandler:
545    ldr   r0,=DMIC0_DriverIRQHandler
546    bx    r0
547    .size DMIC0_IRQHandler, . - DMIC0_IRQHandler
548
549    .align 1
550    .thumb_func
551    .weak HWVAD0_IRQHandler
552    .type HWVAD0_IRQHandler, %function
553HWVAD0_IRQHandler:
554    ldr   r0,=HWVAD0_DriverIRQHandler
555    bx    r0
556    .size HWVAD0_IRQHandler, . - HWVAD0_IRQHandler
557
558    .align 1
559    .thumb_func
560    .weak USB0_NEEDCLK_IRQHandler
561    .type USB0_NEEDCLK_IRQHandler, %function
562USB0_NEEDCLK_IRQHandler:
563    ldr   r0,=USB0_NEEDCLK_DriverIRQHandler
564    bx    r0
565    .size USB0_NEEDCLK_IRQHandler, . - USB0_NEEDCLK_IRQHandler
566
567    .align 1
568    .thumb_func
569    .weak USB0_IRQHandler
570    .type USB0_IRQHandler, %function
571USB0_IRQHandler:
572    ldr   r0,=USB0_DriverIRQHandler
573    bx    r0
574    .size USB0_IRQHandler, . - USB0_IRQHandler
575
576    .align 1
577    .thumb_func
578    .weak RTC_IRQHandler
579    .type RTC_IRQHandler, %function
580RTC_IRQHandler:
581    ldr   r0,=RTC_DriverIRQHandler
582    bx    r0
583    .size RTC_IRQHandler, . - RTC_IRQHandler
584
585    .align 1
586    .thumb_func
587    .weak FLEXCOMM10_IRQHandler
588    .type FLEXCOMM10_IRQHandler, %function
589FLEXCOMM10_IRQHandler:
590    ldr   r0,=FLEXCOMM10_DriverIRQHandler
591    bx    r0
592    .size FLEXCOMM10_IRQHandler, . - FLEXCOMM10_IRQHandler
593
594    .align 1
595    .thumb_func
596    .weak Reserved47_IRQHandler
597    .type Reserved47_IRQHandler, %function
598Reserved47_IRQHandler:
599    ldr   r0,=Reserved47_DriverIRQHandler
600    bx    r0
601    .size Reserved47_IRQHandler, . - Reserved47_IRQHandler
602
603    .align 1
604    .thumb_func
605    .weak PIN_INT4_IRQHandler
606    .type PIN_INT4_IRQHandler, %function
607PIN_INT4_IRQHandler:
608    ldr   r0,=PIN_INT4_DriverIRQHandler
609    bx    r0
610    .size PIN_INT4_IRQHandler, . - PIN_INT4_IRQHandler
611
612    .align 1
613    .thumb_func
614    .weak PIN_INT5_IRQHandler
615    .type PIN_INT5_IRQHandler, %function
616PIN_INT5_IRQHandler:
617    ldr   r0,=PIN_INT5_DriverIRQHandler
618    bx    r0
619    .size PIN_INT5_IRQHandler, . - PIN_INT5_IRQHandler
620
621    .align 1
622    .thumb_func
623    .weak PIN_INT6_IRQHandler
624    .type PIN_INT6_IRQHandler, %function
625PIN_INT6_IRQHandler:
626    ldr   r0,=PIN_INT6_DriverIRQHandler
627    bx    r0
628    .size PIN_INT6_IRQHandler, . - PIN_INT6_IRQHandler
629
630    .align 1
631    .thumb_func
632    .weak PIN_INT7_IRQHandler
633    .type PIN_INT7_IRQHandler, %function
634PIN_INT7_IRQHandler:
635    ldr   r0,=PIN_INT7_DriverIRQHandler
636    bx    r0
637    .size PIN_INT7_IRQHandler, . - PIN_INT7_IRQHandler
638
639    .align 1
640    .thumb_func
641    .weak CTIMER2_IRQHandler
642    .type CTIMER2_IRQHandler, %function
643CTIMER2_IRQHandler:
644    ldr   r0,=CTIMER2_DriverIRQHandler
645    bx    r0
646    .size CTIMER2_IRQHandler, . - CTIMER2_IRQHandler
647
648    .align 1
649    .thumb_func
650    .weak CTIMER4_IRQHandler
651    .type CTIMER4_IRQHandler, %function
652CTIMER4_IRQHandler:
653    ldr   r0,=CTIMER4_DriverIRQHandler
654    bx    r0
655    .size CTIMER4_IRQHandler, . - CTIMER4_IRQHandler
656
657    .align 1
658    .thumb_func
659    .weak RIT_IRQHandler
660    .type RIT_IRQHandler, %function
661RIT_IRQHandler:
662    ldr   r0,=RIT_DriverIRQHandler
663    bx    r0
664    .size RIT_IRQHandler, . - RIT_IRQHandler
665
666    .align 1
667    .thumb_func
668    .weak SPIFI0_IRQHandler
669    .type SPIFI0_IRQHandler, %function
670SPIFI0_IRQHandler:
671    ldr   r0,=SPIFI0_DriverIRQHandler
672    bx    r0
673    .size SPIFI0_IRQHandler, . - SPIFI0_IRQHandler
674
675    .align 1
676    .thumb_func
677    .weak FLEXCOMM8_IRQHandler
678    .type FLEXCOMM8_IRQHandler, %function
679FLEXCOMM8_IRQHandler:
680    ldr   r0,=FLEXCOMM8_DriverIRQHandler
681    bx    r0
682    .size FLEXCOMM8_IRQHandler, . - FLEXCOMM8_IRQHandler
683
684    .align 1
685    .thumb_func
686    .weak FLEXCOMM9_IRQHandler
687    .type FLEXCOMM9_IRQHandler, %function
688FLEXCOMM9_IRQHandler:
689    ldr   r0,=FLEXCOMM9_DriverIRQHandler
690    bx    r0
691    .size FLEXCOMM9_IRQHandler, . - FLEXCOMM9_IRQHandler
692
693    .align 1
694    .thumb_func
695    .weak SDIO_IRQHandler
696    .type SDIO_IRQHandler, %function
697SDIO_IRQHandler:
698    ldr   r0,=SDIO_DriverIRQHandler
699    bx    r0
700    .size SDIO_IRQHandler, . - SDIO_IRQHandler
701
702    .align 1
703    .thumb_func
704    .weak CAN0_IRQ0_IRQHandler
705    .type CAN0_IRQ0_IRQHandler, %function
706CAN0_IRQ0_IRQHandler:
707    ldr   r0,=CAN0_IRQ0_DriverIRQHandler
708    bx    r0
709    .size CAN0_IRQ0_IRQHandler, . - CAN0_IRQ0_IRQHandler
710
711    .align 1
712    .thumb_func
713    .weak CAN0_IRQ1_IRQHandler
714    .type CAN0_IRQ1_IRQHandler, %function
715CAN0_IRQ1_IRQHandler:
716    ldr   r0,=CAN0_IRQ1_DriverIRQHandler
717    bx    r0
718    .size CAN0_IRQ1_IRQHandler, . - CAN0_IRQ1_IRQHandler
719
720    .align 1
721    .thumb_func
722    .weak CAN1_IRQ0_IRQHandler
723    .type CAN1_IRQ0_IRQHandler, %function
724CAN1_IRQ0_IRQHandler:
725    ldr   r0,=CAN1_IRQ0_DriverIRQHandler
726    bx    r0
727    .size CAN1_IRQ0_IRQHandler, . - CAN1_IRQ0_IRQHandler
728
729    .align 1
730    .thumb_func
731    .weak CAN1_IRQ1_IRQHandler
732    .type CAN1_IRQ1_IRQHandler, %function
733CAN1_IRQ1_IRQHandler:
734    ldr   r0,=CAN1_IRQ1_DriverIRQHandler
735    bx    r0
736    .size CAN1_IRQ1_IRQHandler, . - CAN1_IRQ1_IRQHandler
737
738    .align 1
739    .thumb_func
740    .weak USB1_IRQHandler
741    .type USB1_IRQHandler, %function
742USB1_IRQHandler:
743    ldr   r0,=USB1_DriverIRQHandler
744    bx    r0
745    .size USB1_IRQHandler, . - USB1_IRQHandler
746
747    .align 1
748    .thumb_func
749    .weak USB1_NEEDCLK_IRQHandler
750    .type USB1_NEEDCLK_IRQHandler, %function
751USB1_NEEDCLK_IRQHandler:
752    ldr   r0,=USB1_NEEDCLK_DriverIRQHandler
753    bx    r0
754    .size USB1_NEEDCLK_IRQHandler, . - USB1_NEEDCLK_IRQHandler
755
756    .align 1
757    .thumb_func
758    .weak ETHERNET_IRQHandler
759    .type ETHERNET_IRQHandler, %function
760ETHERNET_IRQHandler:
761    ldr   r0,=ETHERNET_DriverIRQHandler
762    bx    r0
763    .size ETHERNET_IRQHandler, . - ETHERNET_IRQHandler
764
765    .align 1
766    .thumb_func
767    .weak ETHERNET_PMT_IRQHandler
768    .type ETHERNET_PMT_IRQHandler, %function
769ETHERNET_PMT_IRQHandler:
770    ldr   r0,=ETHERNET_PMT_DriverIRQHandler
771    bx    r0
772    .size ETHERNET_PMT_IRQHandler, . - ETHERNET_PMT_IRQHandler
773
774    .align 1
775    .thumb_func
776    .weak ETHERNET_MACLP_IRQHandler
777    .type ETHERNET_MACLP_IRQHandler, %function
778ETHERNET_MACLP_IRQHandler:
779    ldr   r0,=ETHERNET_MACLP_DriverIRQHandler
780    bx    r0
781    .size ETHERNET_MACLP_IRQHandler, . - ETHERNET_MACLP_IRQHandler
782
783    .align 1
784    .thumb_func
785    .weak Reserved68_IRQHandler
786    .type Reserved68_IRQHandler, %function
787Reserved68_IRQHandler:
788    ldr   r0,=Reserved68_DriverIRQHandler
789    bx    r0
790    .size Reserved68_IRQHandler, . - Reserved68_IRQHandler
791
792    .align 1
793    .thumb_func
794    .weak LCD_IRQHandler
795    .type LCD_IRQHandler, %function
796LCD_IRQHandler:
797    ldr   r0,=LCD_DriverIRQHandler
798    bx    r0
799    .size LCD_IRQHandler, . - LCD_IRQHandler
800
801    .align 1
802    .thumb_func
803    .weak SHA_IRQHandler
804    .type SHA_IRQHandler, %function
805SHA_IRQHandler:
806    ldr   r0,=SHA_DriverIRQHandler
807    bx    r0
808    .size SHA_IRQHandler, . - SHA_IRQHandler
809
810    .align 1
811    .thumb_func
812    .weak SMARTCARD0_IRQHandler
813    .type SMARTCARD0_IRQHandler, %function
814SMARTCARD0_IRQHandler:
815    ldr   r0,=SMARTCARD0_DriverIRQHandler
816    bx    r0
817    .size SMARTCARD0_IRQHandler, . - SMARTCARD0_IRQHandler
818
819    .align 1
820    .thumb_func
821    .weak SMARTCARD1_IRQHandler
822    .type SMARTCARD1_IRQHandler, %function
823SMARTCARD1_IRQHandler:
824    ldr   r0,=SMARTCARD1_DriverIRQHandler
825    bx    r0
826    .size SMARTCARD1_IRQHandler, . - SMARTCARD1_IRQHandler
827
828
829/*    Macro to define default handlers. Default handler
830 *    will be weak symbol and just dead loops. They can be
831 *    overwritten by other handlers */
832    .macro def_irq_handler  handler_name
833    .weak \handler_name
834    .set  \handler_name, DefaultISR
835    .endm
836/* Exception Handlers */
837    def_irq_handler    MemManage_Handler
838    def_irq_handler    BusFault_Handler
839    def_irq_handler    UsageFault_Handler
840    def_irq_handler    DebugMon_Handler
841    def_irq_handler    WDT_BOD_DriverIRQHandler
842    def_irq_handler    DMA0_DriverIRQHandler
843    def_irq_handler    GINT0_DriverIRQHandler
844    def_irq_handler    GINT1_DriverIRQHandler
845    def_irq_handler    PIN_INT0_DriverIRQHandler
846    def_irq_handler    PIN_INT1_DriverIRQHandler
847    def_irq_handler    PIN_INT2_DriverIRQHandler
848    def_irq_handler    PIN_INT3_DriverIRQHandler
849    def_irq_handler    UTICK0_DriverIRQHandler
850    def_irq_handler    MRT0_DriverIRQHandler
851    def_irq_handler    CTIMER0_DriverIRQHandler
852    def_irq_handler    CTIMER1_DriverIRQHandler
853    def_irq_handler    SCT0_DriverIRQHandler
854    def_irq_handler    CTIMER3_DriverIRQHandler
855    def_irq_handler    FLEXCOMM0_DriverIRQHandler
856    def_irq_handler    FLEXCOMM1_DriverIRQHandler
857    def_irq_handler    FLEXCOMM2_DriverIRQHandler
858    def_irq_handler    FLEXCOMM3_DriverIRQHandler
859    def_irq_handler    FLEXCOMM4_DriverIRQHandler
860    def_irq_handler    FLEXCOMM5_DriverIRQHandler
861    def_irq_handler    FLEXCOMM6_DriverIRQHandler
862    def_irq_handler    FLEXCOMM7_DriverIRQHandler
863    def_irq_handler    ADC0_SEQA_DriverIRQHandler
864    def_irq_handler    ADC0_SEQB_DriverIRQHandler
865    def_irq_handler    ADC0_THCMP_DriverIRQHandler
866    def_irq_handler    DMIC0_DriverIRQHandler
867    def_irq_handler    HWVAD0_DriverIRQHandler
868    def_irq_handler    USB0_NEEDCLK_DriverIRQHandler
869    def_irq_handler    USB0_DriverIRQHandler
870    def_irq_handler    RTC_DriverIRQHandler
871    def_irq_handler    FLEXCOMM10_DriverIRQHandler
872    def_irq_handler    Reserved47_DriverIRQHandler
873    def_irq_handler    PIN_INT4_DriverIRQHandler
874    def_irq_handler    PIN_INT5_DriverIRQHandler
875    def_irq_handler    PIN_INT6_DriverIRQHandler
876    def_irq_handler    PIN_INT7_DriverIRQHandler
877    def_irq_handler    CTIMER2_DriverIRQHandler
878    def_irq_handler    CTIMER4_DriverIRQHandler
879    def_irq_handler    RIT_DriverIRQHandler
880    def_irq_handler    SPIFI0_DriverIRQHandler
881    def_irq_handler    FLEXCOMM8_DriverIRQHandler
882    def_irq_handler    FLEXCOMM9_DriverIRQHandler
883    def_irq_handler    SDIO_DriverIRQHandler
884    def_irq_handler    CAN0_IRQ0_DriverIRQHandler
885    def_irq_handler    CAN0_IRQ1_DriverIRQHandler
886    def_irq_handler    CAN1_IRQ0_DriverIRQHandler
887    def_irq_handler    CAN1_IRQ1_DriverIRQHandler
888    def_irq_handler    USB1_DriverIRQHandler
889    def_irq_handler    USB1_NEEDCLK_DriverIRQHandler
890    def_irq_handler    ETHERNET_DriverIRQHandler
891    def_irq_handler    ETHERNET_PMT_DriverIRQHandler
892    def_irq_handler    ETHERNET_MACLP_DriverIRQHandler
893    def_irq_handler    Reserved68_DriverIRQHandler
894    def_irq_handler    LCD_DriverIRQHandler
895    def_irq_handler    SHA_DriverIRQHandler
896    def_irq_handler    SMARTCARD0_DriverIRQHandler
897    def_irq_handler    SMARTCARD1_DriverIRQHandler
898
899    .end
900