253 lines
		
	
	
		
			8.9 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
			
		
		
	
	
			253 lines
		
	
	
		
			8.9 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
| ;/**************************************************************************//**
 | |
| ; * @file     startup_LPC11Uxx.s
 | |
| ; * @brief    CMSIS Cortex-M0 Core Device Startup File
 | |
| ; *           for the NXP LPC11Uxx Device Series
 | |
| ; * @version  V1.10
 | |
| ; * @date     24. November 2010
 | |
| ; *------- <<< Use Configuration Wizard in Context Menu >>> ------------------
 | |
| ; *
 | |
| ; * @note
 | |
| ; * Copyright (C) 2009-2010 ARM Limited. All rights reserved.
 | |
| ; *
 | |
| ; * @par
 | |
| ; * ARM Limited (ARM) is supplying this software for use with Cortex-M 
 | |
| ; * processor based microcontrollers.  This file can be freely distributed 
 | |
| ; * within development tools that are supporting such ARM based processors. 
 | |
| ; *
 | |
| ; * @par
 | |
| ; * THIS SOFTWARE IS PROVIDED "AS IS".  NO WARRANTIES, WHETHER EXPRESS, IMPLIED
 | |
| ; * OR STATUTORY, INCLUDING, BUT NOT LIMITED TO, IMPLIED WARRANTIES OF
 | |
| ; * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE APPLY TO THIS SOFTWARE.
 | |
| ; * ARM SHALL NOT, IN ANY CIRCUMSTANCES, BE LIABLE FOR SPECIAL, INCIDENTAL, OR
 | |
| ; * CONSEQUENTIAL DAMAGES, FOR ANY REASON WHATSOEVER.
 | |
| ; *
 | |
| ; ******************************************************************************/
 | |
| 
 | |
| 
 | |
| ; <h> Stack Configuration
 | |
| ;   <o> Stack Size (in Bytes) <0x0-0xFFFFFFFF:8>
 | |
| ; </h>
 | |
| 
 | |
| Stack_Size      EQU     0x00000200
 | |
| 
 | |
|                 AREA    STACK, NOINIT, READWRITE, ALIGN=3
 | |
| Stack_Mem       SPACE   Stack_Size
 | |
| __initial_sp
 | |
| 
 | |
| 
 | |
| ; <h> Heap Configuration
 | |
| ;   <o>  Heap Size (in Bytes) <0x0-0xFFFFFFFF:8>
 | |
| ; </h>
 | |
| 
 | |
| Heap_Size       EQU     0x00000100
 | |
| 
 | |
|                 AREA    HEAP, NOINIT, READWRITE, ALIGN=3
 | |
| __heap_base
 | |
| Heap_Mem        SPACE   Heap_Size
 | |
| __heap_limit
 | |
| 
 | |
| 
 | |
|                 PRESERVE8
 | |
|                 THUMB
 | |
| 
 | |
| 
 | |
| ; Vector Table Mapped to Address 0 at Reset
 | |
| 
 | |
|                 AREA    RESET, DATA, READONLY
 | |
|                 EXPORT  __Vectors
 | |
| 
 | |
| __Vectors       DCD     __initial_sp              ; Top of Stack
 | |
|                 DCD     Reset_Handler             ; Reset Handler
 | |
|                 DCD     NMI_Handler               ; NMI Handler
 | |
|                 DCD     HardFault_Handler         ; Hard Fault Handler
 | |
|                 DCD     0                         ; Reserved
 | |
|                 DCD     0                         ; Reserved
 | |
|                 DCD     0                         ; Reserved
 | |
|                 DCD     0                         ; Reserved
 | |
|                 DCD     0                         ; Reserved
 | |
|                 DCD     0                         ; Reserved
 | |
|                 DCD     0                         ; Reserved
 | |
|                 DCD     SVC_Handler               ; SVCall Handler
 | |
|                 DCD     0                         ; Reserved
 | |
|                 DCD     0                         ; Reserved
 | |
|                 DCD     PendSV_Handler            ; PendSV Handler
 | |
|                 DCD     SysTick_Handler           ; SysTick Handler
 | |
| 
 | |
|                 ; External Interrupts
 | |
|                 DCD     FLEX_INT0_IRQHandler      ; All GPIO pin can be routed to FLEX_INTx
 | |
|                 DCD     FLEX_INT1_IRQHandler          
 | |
|                 DCD     FLEX_INT2_IRQHandler                       
 | |
|                 DCD     FLEX_INT3_IRQHandler                         
 | |
|                 DCD     FLEX_INT4_IRQHandler                        
 | |
|                 DCD     FLEX_INT5_IRQHandler
 | |
|                 DCD     FLEX_INT6_IRQHandler
 | |
|                 DCD     FLEX_INT7_IRQHandler                       
 | |
|                 DCD     GINT0_IRQHandler                         
 | |
|                 DCD     GINT1_IRQHandler          ; PIO0 (0:7)              
 | |
|                 DCD     Reserved_IRQHandler		  ; Reserved
 | |
|                 DCD     Reserved_IRQHandler
 | |
|                 DCD     Reserved_IRQHandler       
 | |
|                 DCD     Reserved_IRQHandler                       
 | |
|                 DCD     SSP1_IRQHandler           ; SSP1               
 | |
|                 DCD     I2C_IRQHandler            ; I2C
 | |
|                 DCD     TIMER16_0_IRQHandler      ; 16-bit Timer0
 | |
|                 DCD     TIMER16_1_IRQHandler      ; 16-bit Timer1
 | |
|                 DCD     TIMER32_0_IRQHandler      ; 32-bit Timer0
 | |
|                 DCD     TIMER32_1_IRQHandler      ; 32-bit Timer1
 | |
|                 DCD     SSP0_IRQHandler           ; SSP0
 | |
|                 DCD     UART_IRQHandler           ; UART
 | |
|                 DCD     USB_IRQHandler            ; USB IRQ
 | |
|                 DCD     USB_FIQHandler            ; USB FIQ
 | |
|                 DCD     ADC_IRQHandler            ; A/D Converter
 | |
|                 DCD     WDT_IRQHandler            ; Watchdog timer
 | |
|                 DCD     BOD_IRQHandler            ; Brown Out Detect
 | |
|                 DCD     FMC_IRQHandler            ; IP2111 Flash Memory Controller
 | |
|                 DCD     Reserved_IRQHandler	       ; Reserved
 | |
|                 DCD     Reserved_IRQHandler       ; Reserved
 | |
|                 DCD     USBWakeup_IRQHandler      ; USB wake up
 | |
|                 DCD     Reserved_IRQHandler       ; Reserved
 | |
| 
 | |
| 
 | |
|                 IF      :LNOT::DEF:NO_CRP
 | |
|                 AREA    |.ARM.__at_0x02FC|, CODE, READONLY
 | |
| CRP_Key         DCD     0xFFFFFFFF
 | |
|                 ENDIF
 | |
| 
 | |
| 
 | |
|                 AREA    |.text|, CODE, READONLY
 | |
| 
 | |
| 
 | |
| ; Reset Handler
 | |
| 
 | |
| Reset_Handler   PROC
 | |
|                 EXPORT  Reset_Handler             [WEAK]
 | |
|                 IMPORT  SystemInit
 | |
|                 IMPORT  __main
 | |
|                 LDR     R0, =SystemInit
 | |
|                 BLX     R0
 | |
|                 LDR     R0, =__main
 | |
|                 BX      R0
 | |
|                 ENDP
 | |
| 
 | |
| 
 | |
| ; Dummy Exception Handlers (infinite loops which can be modified)                
 | |
| 
 | |
| ; now, under COMMON NMI.c and NMI.h, a real NMI handler is created if NMI is enabled 
 | |
| ; for particular peripheral.
 | |
| ;NMI_Handler     PROC
 | |
| ;                EXPORT  NMI_Handler               [WEAK]
 | |
| ;                B       .
 | |
| ;                ENDP
 | |
| HardFault_Handler\
 | |
|                 PROC
 | |
|                 EXPORT  HardFault_Handler         [WEAK]
 | |
|                 B       .
 | |
|                 ENDP
 | |
| SVC_Handler     PROC
 | |
|                 EXPORT  SVC_Handler               [WEAK]
 | |
|                 B       .
 | |
|                 ENDP
 | |
| PendSV_Handler  PROC
 | |
|                 EXPORT  PendSV_Handler            [WEAK]
 | |
|                 B       .
 | |
|                 ENDP
 | |
| SysTick_Handler PROC
 | |
|                 EXPORT  SysTick_Handler           [WEAK]
 | |
|                 B       .
 | |
|                 ENDP
 | |
| Reserved_IRQHandler PROC
 | |
|                 EXPORT  Reserved_IRQHandler       [WEAK]
 | |
|                 B       .
 | |
|                 ENDP
 | |
| 
 | |
| Default_Handler PROC
 | |
|                 EXPORT  NMI_Handler               [WEAK]
 | |
|                 EXPORT  FLEX_INT0_IRQHandler      [WEAK]
 | |
|                 EXPORT  FLEX_INT1_IRQHandler      [WEAK]
 | |
|                 EXPORT  FLEX_INT2_IRQHandler      [WEAK]
 | |
|                 EXPORT  FLEX_INT3_IRQHandler      [WEAK]
 | |
|                 EXPORT  FLEX_INT4_IRQHandler      [WEAK]
 | |
|                 EXPORT  FLEX_INT5_IRQHandler      [WEAK]
 | |
|                 EXPORT  FLEX_INT6_IRQHandler      [WEAK]
 | |
|                 EXPORT  FLEX_INT7_IRQHandler      [WEAK]
 | |
|                 EXPORT  GINT0_IRQHandler          [WEAK]
 | |
|                 EXPORT  GINT1_IRQHandler          [WEAK]
 | |
|                 EXPORT  SSP1_IRQHandler           [WEAK]
 | |
|                 EXPORT  I2C_IRQHandler            [WEAK]
 | |
|                 EXPORT  TIMER16_0_IRQHandler      [WEAK]
 | |
|                 EXPORT  TIMER16_1_IRQHandler      [WEAK]
 | |
|                 EXPORT  TIMER32_0_IRQHandler      [WEAK]
 | |
|                 EXPORT  TIMER32_1_IRQHandler      [WEAK]
 | |
|                 EXPORT  SSP0_IRQHandler           [WEAK]
 | |
|                 EXPORT  UART_IRQHandler           [WEAK]
 | |
| 
 | |
|                 EXPORT  USB_IRQHandler            [WEAK]
 | |
|                 EXPORT  USB_FIQHandler            [WEAK]
 | |
|                 EXPORT  ADC_IRQHandler            [WEAK]
 | |
|                 EXPORT  WDT_IRQHandler            [WEAK]
 | |
|                 EXPORT  BOD_IRQHandler            [WEAK]
 | |
|                 EXPORT  FMC_IRQHandler            [WEAK]
 | |
|                 EXPORT	USBWakeup_IRQHandler      [WEAK]
 | |
| 
 | |
| NMI_Handler
 | |
| FLEX_INT0_IRQHandler
 | |
| FLEX_INT1_IRQHandler
 | |
| FLEX_INT2_IRQHandler
 | |
| FLEX_INT3_IRQHandler
 | |
| FLEX_INT4_IRQHandler
 | |
| FLEX_INT5_IRQHandler
 | |
| FLEX_INT6_IRQHandler
 | |
| FLEX_INT7_IRQHandler
 | |
| GINT0_IRQHandler
 | |
| GINT1_IRQHandler
 | |
| SSP1_IRQHandler
 | |
| I2C_IRQHandler
 | |
| TIMER16_0_IRQHandler
 | |
| TIMER16_1_IRQHandler
 | |
| TIMER32_0_IRQHandler
 | |
| TIMER32_1_IRQHandler
 | |
| SSP0_IRQHandler
 | |
| UART_IRQHandler
 | |
| USB_IRQHandler
 | |
| USB_FIQHandler
 | |
| ADC_IRQHandler
 | |
| WDT_IRQHandler
 | |
| BOD_IRQHandler
 | |
| FMC_IRQHandler
 | |
| USBWakeup_IRQHandler
 | |
| 
 | |
|                 B       .
 | |
| 
 | |
|                 ENDP
 | |
| 
 | |
| 
 | |
|                 ALIGN
 | |
| 
 | |
| 
 | |
| ; User Initial Stack & Heap
 | |
| 
 | |
|                 IF      :DEF:__MICROLIB
 | |
|                 
 | |
|                 EXPORT  __initial_sp
 | |
|                 EXPORT  __heap_base
 | |
|                 EXPORT  __heap_limit
 | |
|                 
 | |
|                 ELSE
 | |
|                 
 | |
|                 IMPORT  __use_two_region_memory
 | |
|                 EXPORT  __user_initial_stackheap
 | |
| __user_initial_stackheap
 | |
| 
 | |
|                 LDR     R0, =  Heap_Mem
 | |
|                 LDR     R1, =(Stack_Mem + Stack_Size)
 | |
|                 LDR     R2, = (Heap_Mem +  Heap_Size)
 | |
|                 LDR     R3, = Stack_Mem
 | |
|                 BX      LR
 | |
| 
 | |
|                 ALIGN
 | |
| 
 | |
|                 ENDIF
 | |
| 
 | |
| 
 | |
|                 END
 | 
