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
							 |