mbed library sources. Supersedes mbed-src.

Fork of mbed by teralytic

Committer:
bogdanm
Date:
Thu Oct 01 15:25:22 2015 +0300
Revision:
0:9b334a45a8ff
Child:
144:ef7eb2e8f9f7
Initial commit on mbed-dev

Replaces mbed-src (now inactive)

Who changed what in which revision?

UserRevisionLine numberNew contents of line
bogdanm 0:9b334a45a8ff 1 ;/**************************************************************************//**
bogdanm 0:9b334a45a8ff 2 ; * @file startup_LPC11U6x.s
bogdanm 0:9b334a45a8ff 3 ; * @brief CMSIS Cortex-M0+ Core Device Startup File for
bogdanm 0:9b334a45a8ff 4 ; * NXP LPC11U6x Device Series
bogdanm 0:9b334a45a8ff 5 ; * @version V1.00
bogdanm 0:9b334a45a8ff 6 ; * @date 22. October 2013
bogdanm 0:9b334a45a8ff 7 ; *
bogdanm 0:9b334a45a8ff 8 ; * @note
bogdanm 0:9b334a45a8ff 9 ; * Copyright (C) 2013 ARM Limited. All rights reserved.
bogdanm 0:9b334a45a8ff 10 ; *
bogdanm 0:9b334a45a8ff 11 ; * @par
bogdanm 0:9b334a45a8ff 12 ; * ARM Limited (ARM) is supplying this software for use with Cortex-M
bogdanm 0:9b334a45a8ff 13 ; * processor based microcontrollers. This file can be freely distributed
bogdanm 0:9b334a45a8ff 14 ; * within development tools that are supporting such ARM based processors.
bogdanm 0:9b334a45a8ff 15 ; *
bogdanm 0:9b334a45a8ff 16 ; * @par
bogdanm 0:9b334a45a8ff 17 ; * THIS SOFTWARE IS PROVIDED "AS IS". NO WARRANTIES, WHETHER EXPRESS, IMPLIED
bogdanm 0:9b334a45a8ff 18 ; * OR STATUTORY, INCLUDING, BUT NOT LIMITED TO, IMPLIED WARRANTIES OF
bogdanm 0:9b334a45a8ff 19 ; * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE APPLY TO THIS SOFTWARE.
bogdanm 0:9b334a45a8ff 20 ; * ARM SHALL NOT, IN ANY CIRCUMSTANCES, BE LIABLE FOR SPECIAL, INCIDENTAL, OR
bogdanm 0:9b334a45a8ff 21 ; * CONSEQUENTIAL DAMAGES, FOR ANY REASON WHATSOEVER.
bogdanm 0:9b334a45a8ff 22 ; *
bogdanm 0:9b334a45a8ff 23 ; ******************************************************************************/
bogdanm 0:9b334a45a8ff 24
bogdanm 0:9b334a45a8ff 25 ; *------- <<< Use Configuration Wizard in Context Menu >>> ------------------
bogdanm 0:9b334a45a8ff 26
bogdanm 0:9b334a45a8ff 27 ; <h> Stack Configuration
bogdanm 0:9b334a45a8ff 28 ; <o> Stack Size (in Bytes) <0x0-0xFFFFFFFF:8>
bogdanm 0:9b334a45a8ff 29 ; </h>
bogdanm 0:9b334a45a8ff 30
bogdanm 0:9b334a45a8ff 31 AREA STACK, NOINIT, READWRITE, ALIGN=3
bogdanm 0:9b334a45a8ff 32 EXPORT __initial_sp
bogdanm 0:9b334a45a8ff 33
bogdanm 0:9b334a45a8ff 34 __initial_sp EQU 0x10008000 ; Top of RAM from LPC1U68
bogdanm 0:9b334a45a8ff 35
bogdanm 0:9b334a45a8ff 36
bogdanm 0:9b334a45a8ff 37 ; <h> Heap Configuration
bogdanm 0:9b334a45a8ff 38 ; <o> Heap Size (in Bytes) <0x0-0xFFFFFFFF:8>
bogdanm 0:9b334a45a8ff 39 ; </h>
bogdanm 0:9b334a45a8ff 40
bogdanm 0:9b334a45a8ff 41 Heap_Size EQU 0x00000000
bogdanm 0:9b334a45a8ff 42
bogdanm 0:9b334a45a8ff 43 AREA HEAP, NOINIT, READWRITE, ALIGN=3
bogdanm 0:9b334a45a8ff 44 __heap_base
bogdanm 0:9b334a45a8ff 45 Heap_Mem SPACE Heap_Size
bogdanm 0:9b334a45a8ff 46 __heap_limit
bogdanm 0:9b334a45a8ff 47
bogdanm 0:9b334a45a8ff 48
bogdanm 0:9b334a45a8ff 49 PRESERVE8
bogdanm 0:9b334a45a8ff 50 THUMB
bogdanm 0:9b334a45a8ff 51
bogdanm 0:9b334a45a8ff 52
bogdanm 0:9b334a45a8ff 53 ; Vector Table Mapped to Address 0 at Reset
bogdanm 0:9b334a45a8ff 54
bogdanm 0:9b334a45a8ff 55 AREA RESET, DATA, READONLY
bogdanm 0:9b334a45a8ff 56 EXPORT __Vectors
bogdanm 0:9b334a45a8ff 57
bogdanm 0:9b334a45a8ff 58 __Vectors DCD __initial_sp ; Top of Stack
bogdanm 0:9b334a45a8ff 59 DCD Reset_Handler ; Reset Handler
bogdanm 0:9b334a45a8ff 60 DCD NMI_Handler ; NMI Handler
bogdanm 0:9b334a45a8ff 61 DCD HardFault_Handler ; Hard Fault Handler
bogdanm 0:9b334a45a8ff 62 DCD 0 ; Reserved
bogdanm 0:9b334a45a8ff 63 DCD 0 ; Reserved
bogdanm 0:9b334a45a8ff 64 DCD 0 ; Reserved
bogdanm 0:9b334a45a8ff 65 DCD 0 ; Reserved
bogdanm 0:9b334a45a8ff 66 DCD 0 ; Reserved
bogdanm 0:9b334a45a8ff 67 DCD 0 ; Reserved
bogdanm 0:9b334a45a8ff 68 DCD 0 ; Reserved
bogdanm 0:9b334a45a8ff 69 DCD SVC_Handler ; SVCall Handler
bogdanm 0:9b334a45a8ff 70 DCD 0 ; Reserved
bogdanm 0:9b334a45a8ff 71 DCD 0 ; Reserved
bogdanm 0:9b334a45a8ff 72 DCD PendSV_Handler ; PendSV Handler
bogdanm 0:9b334a45a8ff 73 DCD SysTick_Handler ; SysTick Handler
bogdanm 0:9b334a45a8ff 74
bogdanm 0:9b334a45a8ff 75 ; External Interrupts
bogdanm 0:9b334a45a8ff 76 DCD PIN_INT0_IRQHandler ; 16+ 0 GPIO pin interrupt 0
bogdanm 0:9b334a45a8ff 77 DCD PIN_INT1_IRQHandler ; 16+ 1 GPIO pin interrupt 1
bogdanm 0:9b334a45a8ff 78 DCD PIN_INT2_IRQHandler ; 16+ 2 GPIO pin interrupt 2
bogdanm 0:9b334a45a8ff 79 DCD PIN_INT3_IRQHandler ; 16+ 3 GPIO pin interrupt 3
bogdanm 0:9b334a45a8ff 80 DCD PIN_INT4_IRQHandler ; 16+ 4 GPIO pin interrupt 4
bogdanm 0:9b334a45a8ff 81 DCD PIN_INT5_IRQHandler ; 16+ 5 GPIO pin interrupt 5
bogdanm 0:9b334a45a8ff 82 DCD PIN_INT6_IRQHandler ; 16+ 6 GPIO pin interrupt 6
bogdanm 0:9b334a45a8ff 83 DCD PIN_INT7_IRQHandler ; 16+ 7 GPIO pin interrupt 7
bogdanm 0:9b334a45a8ff 84 DCD GINT0_IRQHandler ; 16+ 8 GPIO GROUP0 interrupt
bogdanm 0:9b334a45a8ff 85 DCD GINT1_IRQHandler ; 16+ 9 GPIO GROUP1 interrupt
bogdanm 0:9b334a45a8ff 86 DCD I2C1_IRQHandler ; 16+10 I2C1 interrupt
bogdanm 0:9b334a45a8ff 87 DCD USART1_4_IRQHandler ; 16+11 Combined USART1 and USART4 interrupts
bogdanm 0:9b334a45a8ff 88 DCD USART2_3_IRQHandler ; 16+12 Combined USART2 and USART3 interrupts
bogdanm 0:9b334a45a8ff 89 DCD SCT0_1_IRQHandler ; 16+13 Combined SCT0 and SCT1 interrupts
bogdanm 0:9b334a45a8ff 90 DCD SSP1_IRQHandler ; 16+14 SSP1 interrupt
bogdanm 0:9b334a45a8ff 91 DCD I2C0_IRQHandler ; 16+15 I2C0 interrupt
bogdanm 0:9b334a45a8ff 92 DCD CT16B0_IRQHandler ; 16+16 CT16B0 interrupt
bogdanm 0:9b334a45a8ff 93 DCD CT16B1_IRQHandler ; 16+17 CT16B1 interrupt
bogdanm 0:9b334a45a8ff 94 DCD CT32B0_IRQHandler ; 16+18 CT32B0 interrupt
bogdanm 0:9b334a45a8ff 95 DCD CT32B1_IRQHandler ; 16+19 CT32B1 interrupt
bogdanm 0:9b334a45a8ff 96 DCD SSP0_IRQHandler ; 16+20 SSP0 interrupt
bogdanm 0:9b334a45a8ff 97 DCD USART0_IRQHandler ; 16+21 USART0 interrupt
bogdanm 0:9b334a45a8ff 98 DCD USB_IRQHandler ; 16+22 USB interrupt
bogdanm 0:9b334a45a8ff 99 DCD USB_FIQ_IRQHandler ; 16+23 USB_FIQ interrupt
bogdanm 0:9b334a45a8ff 100 DCD ADC_A_IRQHandler ; 16+24 Combined ADC_A end-of-sequence A and threshold crossing interrupts
bogdanm 0:9b334a45a8ff 101 DCD RTC_IRQHandler ; 16+25 RTC interrupt
bogdanm 0:9b334a45a8ff 102 DCD BOD_WDT_IRQHandler ; 16+26 Combined BOD and WWDT interrupt
bogdanm 0:9b334a45a8ff 103 DCD FLASH_IRQHandler ; 16+27 Combined flash and EEPROM controller interrupts
bogdanm 0:9b334a45a8ff 104 DCD DMA_IRQHandler ; 16+28 DMA interrupt
bogdanm 0:9b334a45a8ff 105 DCD ADC_B_IRQHandler ; 16+29 Combined ADC_A end-of-sequence A and threshold crossing interrupts
bogdanm 0:9b334a45a8ff 106 DCD USBWAKEUP_IRQHandler ; 16+30 USB_WAKEUP interrupt
bogdanm 0:9b334a45a8ff 107 DCD 0 ; 16+31 Reserved
bogdanm 0:9b334a45a8ff 108
bogdanm 0:9b334a45a8ff 109 ; <h> Code Read Protection
bogdanm 0:9b334a45a8ff 110 ; <o> Code Read Protection <0xFFFFFFFF=>CRP Disabled
bogdanm 0:9b334a45a8ff 111 ; <0x12345678=>CRP Level 1
bogdanm 0:9b334a45a8ff 112 ; <0x87654321=>CRP Level 2
bogdanm 0:9b334a45a8ff 113 ; <0x43218765=>CRP Level 3 (ARE YOU SURE?)
bogdanm 0:9b334a45a8ff 114 ; <0x4E697370=>NO ISP (ARE YOU SURE?)
bogdanm 0:9b334a45a8ff 115 ; </h>
bogdanm 0:9b334a45a8ff 116 IF :LNOT::DEF:NO_CRP
bogdanm 0:9b334a45a8ff 117 AREA |.ARM.__at_0x02FC|, CODE, READONLY
bogdanm 0:9b334a45a8ff 118 DCD 0xFFFFFFFF
bogdanm 0:9b334a45a8ff 119 ENDIF
bogdanm 0:9b334a45a8ff 120
bogdanm 0:9b334a45a8ff 121 AREA |.text|, CODE, READONLY
bogdanm 0:9b334a45a8ff 122
bogdanm 0:9b334a45a8ff 123
bogdanm 0:9b334a45a8ff 124 ; Reset Handler
bogdanm 0:9b334a45a8ff 125
bogdanm 0:9b334a45a8ff 126 Reset_Handler PROC
bogdanm 0:9b334a45a8ff 127 EXPORT Reset_Handler [WEAK]
bogdanm 0:9b334a45a8ff 128 IMPORT SystemInit
bogdanm 0:9b334a45a8ff 129 IMPORT __main
bogdanm 0:9b334a45a8ff 130 LDR R0, =SystemInit
bogdanm 0:9b334a45a8ff 131 BLX R0
bogdanm 0:9b334a45a8ff 132 LDR R0, =__main
bogdanm 0:9b334a45a8ff 133 BX R0
bogdanm 0:9b334a45a8ff 134 ENDP
bogdanm 0:9b334a45a8ff 135
bogdanm 0:9b334a45a8ff 136
bogdanm 0:9b334a45a8ff 137 ; Dummy Exception Handlers (infinite loops which can be modified)
bogdanm 0:9b334a45a8ff 138
bogdanm 0:9b334a45a8ff 139 NMI_Handler PROC
bogdanm 0:9b334a45a8ff 140 EXPORT NMI_Handler [WEAK]
bogdanm 0:9b334a45a8ff 141 B .
bogdanm 0:9b334a45a8ff 142 ENDP
bogdanm 0:9b334a45a8ff 143 HardFault_Handler\
bogdanm 0:9b334a45a8ff 144 PROC
bogdanm 0:9b334a45a8ff 145 EXPORT HardFault_Handler [WEAK]
bogdanm 0:9b334a45a8ff 146 B .
bogdanm 0:9b334a45a8ff 147 ENDP
bogdanm 0:9b334a45a8ff 148 SVC_Handler PROC
bogdanm 0:9b334a45a8ff 149 EXPORT SVC_Handler [WEAK]
bogdanm 0:9b334a45a8ff 150 B .
bogdanm 0:9b334a45a8ff 151 ENDP
bogdanm 0:9b334a45a8ff 152 PendSV_Handler PROC
bogdanm 0:9b334a45a8ff 153 EXPORT PendSV_Handler [WEAK]
bogdanm 0:9b334a45a8ff 154 B .
bogdanm 0:9b334a45a8ff 155 ENDP
bogdanm 0:9b334a45a8ff 156 SysTick_Handler PROC
bogdanm 0:9b334a45a8ff 157 EXPORT SysTick_Handler [WEAK]
bogdanm 0:9b334a45a8ff 158 B .
bogdanm 0:9b334a45a8ff 159 ENDP
bogdanm 0:9b334a45a8ff 160 Reserved_IRQHandler PROC
bogdanm 0:9b334a45a8ff 161 EXPORT Reserved_IRQHandler [WEAK]
bogdanm 0:9b334a45a8ff 162 B .
bogdanm 0:9b334a45a8ff 163 ENDP
bogdanm 0:9b334a45a8ff 164
bogdanm 0:9b334a45a8ff 165 Default_Handler PROC
bogdanm 0:9b334a45a8ff 166 EXPORT PIN_INT0_IRQHandler [WEAK]
bogdanm 0:9b334a45a8ff 167 EXPORT PIN_INT1_IRQHandler [WEAK]
bogdanm 0:9b334a45a8ff 168 EXPORT PIN_INT2_IRQHandler [WEAK]
bogdanm 0:9b334a45a8ff 169 EXPORT PIN_INT3_IRQHandler [WEAK]
bogdanm 0:9b334a45a8ff 170 EXPORT PIN_INT4_IRQHandler [WEAK]
bogdanm 0:9b334a45a8ff 171 EXPORT PIN_INT5_IRQHandler [WEAK]
bogdanm 0:9b334a45a8ff 172 EXPORT PIN_INT6_IRQHandler [WEAK]
bogdanm 0:9b334a45a8ff 173 EXPORT PIN_INT7_IRQHandler [WEAK]
bogdanm 0:9b334a45a8ff 174 EXPORT GINT0_IRQHandler [WEAK]
bogdanm 0:9b334a45a8ff 175 EXPORT GINT1_IRQHandler [WEAK]
bogdanm 0:9b334a45a8ff 176 EXPORT I2C1_IRQHandler [WEAK]
bogdanm 0:9b334a45a8ff 177 EXPORT USART1_4_IRQHandler [WEAK]
bogdanm 0:9b334a45a8ff 178 EXPORT USART2_3_IRQHandler [WEAK]
bogdanm 0:9b334a45a8ff 179 EXPORT SCT0_1_IRQHandler [WEAK]
bogdanm 0:9b334a45a8ff 180 EXPORT SSP1_IRQHandler [WEAK]
bogdanm 0:9b334a45a8ff 181 EXPORT I2C0_IRQHandler [WEAK]
bogdanm 0:9b334a45a8ff 182 EXPORT CT16B0_IRQHandler [WEAK]
bogdanm 0:9b334a45a8ff 183 EXPORT CT16B1_IRQHandler [WEAK]
bogdanm 0:9b334a45a8ff 184 EXPORT CT32B0_IRQHandler [WEAK]
bogdanm 0:9b334a45a8ff 185 EXPORT CT32B1_IRQHandler [WEAK]
bogdanm 0:9b334a45a8ff 186 EXPORT SSP0_IRQHandler [WEAK]
bogdanm 0:9b334a45a8ff 187 EXPORT USART0_IRQHandler [WEAK]
bogdanm 0:9b334a45a8ff 188 EXPORT USB_IRQHandler [WEAK]
bogdanm 0:9b334a45a8ff 189 EXPORT USB_FIQ_IRQHandler [WEAK]
bogdanm 0:9b334a45a8ff 190 EXPORT ADC_A_IRQHandler [WEAK]
bogdanm 0:9b334a45a8ff 191 EXPORT RTC_IRQHandler [WEAK]
bogdanm 0:9b334a45a8ff 192 EXPORT BOD_WDT_IRQHandler [WEAK]
bogdanm 0:9b334a45a8ff 193 EXPORT FLASH_IRQHandler [WEAK]
bogdanm 0:9b334a45a8ff 194 EXPORT DMA_IRQHandler [WEAK]
bogdanm 0:9b334a45a8ff 195 EXPORT ADC_B_IRQHandler [WEAK]
bogdanm 0:9b334a45a8ff 196 EXPORT USBWAKEUP_IRQHandler [WEAK]
bogdanm 0:9b334a45a8ff 197
bogdanm 0:9b334a45a8ff 198 PIN_INT0_IRQHandler
bogdanm 0:9b334a45a8ff 199 PIN_INT1_IRQHandler
bogdanm 0:9b334a45a8ff 200 PIN_INT2_IRQHandler
bogdanm 0:9b334a45a8ff 201 PIN_INT3_IRQHandler
bogdanm 0:9b334a45a8ff 202 PIN_INT4_IRQHandler
bogdanm 0:9b334a45a8ff 203 PIN_INT5_IRQHandler
bogdanm 0:9b334a45a8ff 204 PIN_INT6_IRQHandler
bogdanm 0:9b334a45a8ff 205 PIN_INT7_IRQHandler
bogdanm 0:9b334a45a8ff 206 GINT0_IRQHandler
bogdanm 0:9b334a45a8ff 207 GINT1_IRQHandler
bogdanm 0:9b334a45a8ff 208 I2C1_IRQHandler
bogdanm 0:9b334a45a8ff 209 USART1_4_IRQHandler
bogdanm 0:9b334a45a8ff 210 USART2_3_IRQHandler
bogdanm 0:9b334a45a8ff 211 SCT0_1_IRQHandler
bogdanm 0:9b334a45a8ff 212 SSP1_IRQHandler
bogdanm 0:9b334a45a8ff 213 I2C0_IRQHandler
bogdanm 0:9b334a45a8ff 214 CT16B0_IRQHandler
bogdanm 0:9b334a45a8ff 215 CT16B1_IRQHandler
bogdanm 0:9b334a45a8ff 216 CT32B0_IRQHandler
bogdanm 0:9b334a45a8ff 217 CT32B1_IRQHandler
bogdanm 0:9b334a45a8ff 218 SSP0_IRQHandler
bogdanm 0:9b334a45a8ff 219 USART0_IRQHandler
bogdanm 0:9b334a45a8ff 220 USB_IRQHandler
bogdanm 0:9b334a45a8ff 221 USB_FIQ_IRQHandler
bogdanm 0:9b334a45a8ff 222 ADC_A_IRQHandler
bogdanm 0:9b334a45a8ff 223 RTC_IRQHandler
bogdanm 0:9b334a45a8ff 224 BOD_WDT_IRQHandler
bogdanm 0:9b334a45a8ff 225 FLASH_IRQHandler
bogdanm 0:9b334a45a8ff 226 DMA_IRQHandler
bogdanm 0:9b334a45a8ff 227 ADC_B_IRQHandler
bogdanm 0:9b334a45a8ff 228 USBWAKEUP_IRQHandler
bogdanm 0:9b334a45a8ff 229
bogdanm 0:9b334a45a8ff 230 B .
bogdanm 0:9b334a45a8ff 231
bogdanm 0:9b334a45a8ff 232 ENDP
bogdanm 0:9b334a45a8ff 233
bogdanm 0:9b334a45a8ff 234
bogdanm 0:9b334a45a8ff 235 ALIGN
bogdanm 0:9b334a45a8ff 236
bogdanm 0:9b334a45a8ff 237
bogdanm 0:9b334a45a8ff 238 ; User Initial Stack & Heap
bogdanm 0:9b334a45a8ff 239
bogdanm 0:9b334a45a8ff 240 EXPORT __initial_sp
bogdanm 0:9b334a45a8ff 241 EXPORT __heap_base
bogdanm 0:9b334a45a8ff 242 EXPORT __heap_limit
bogdanm 0:9b334a45a8ff 243
bogdanm 0:9b334a45a8ff 244 END