]> git.gir.st - tmk_keyboard.git/blob - tool/mbed/mbed-sdk/libraries/mbed/targets/cmsis/TARGET_STM/TARGET_STM32F3/TARGET_NUCLEO_F302R8/TOOLCHAIN_IAR/startup_stm32f302x8.s
Squashed 'tmk_core/' changes from 7967731..b9e0ea0
[tmk_keyboard.git] / tool / mbed / mbed-sdk / libraries / mbed / targets / cmsis / TARGET_STM / TARGET_STM32F3 / TARGET_NUCLEO_F302R8 / TOOLCHAIN_IAR / startup_stm32f302x8.s
1 ;/******************** (C) COPYRIGHT 2014 STMicroelectronics ********************
2 ;* File Name : startup_stm32f302x8.s
3 ;* Author : MCD Application Team
4 ;* Version : V2.1.0
5 ;* Date : 12-Sept-2014
6 ;* Description : STM32F302x6/STM32F302x8 devices vector table for EWARM toolchain.
7 ;* This module performs:
8 ;* - Set the initial SP
9 ;* - Set the initial PC == _iar_program_start,
10 ;* - Set the vector table entries with the exceptions ISR
11 ;* address.
12 ;* - Branches to main in the C library (which eventually
13 ;* calls main()).
14 ;* After Reset the Cortex-M4 processor is in Thread mode,
15 ;* priority is Privileged, and the Stack is set to Main.
16 ;********************************************************************************
17 ;*
18 ;* <h2><center>&copy; COPYRIGHT(c) 2014 STMicroelectronics</center></h2>
19 ;*
20 ;* Redistribution and use in source and binary forms, with or without modification,
21 ;* are permitted provided that the following conditions are met:
22 ;* 1. Redistributions of source code must retain the above copyright notice,
23 ;* this list of conditions and the following disclaimer.
24 ;* 2. Redistributions in binary form must reproduce the above copyright notice,
25 ;* this list of conditions and the following disclaimer in the documentation
26 ;* and/or other materials provided with the distribution.
27 ;* 3. Neither the name of STMicroelectronics nor the names of its contributors
28 ;* may be used to endorse or promote products derived from this software
29 ;* without specific prior written permission.
30 ;*
31 ;* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
32 ;* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
33 ;* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
34 ;* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
35 ;* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
36 ;* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
37 ;* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
38 ;* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
39 ;* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
40 ;* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
41 ;*
42 ;*******************************************************************************
43 ;
44 ;
45 ; The modules in this file are included in the libraries, and may be replaced
46 ; by any user-defined modules that define the PUBLIC symbol _program_start or
47 ; a user defined start symbol.
48 ; To override the cstartup defined in the library, simply add your modified
49 ; version to the workbench project.
50 ;
51 ; The vector table is normally located at address 0.
52 ; When debugging in RAM, it can be located in RAM, aligned to at least 2^6.
53 ; The name "__vector_table" has special meaning for C-SPY:
54 ; it is where the SP start value is found, and the NVIC vector
55 ; table register (VTOR) is initialized to this address if != 0.
56 ;
57 ; Cortex-M version
58 ;
59
60 MODULE ?cstartup
61
62 ;; Forward declaration of sections.
63 SECTION CSTACK:DATA:NOROOT(3)
64
65 SECTION .intvec:CODE:NOROOT(2)
66
67 EXTERN __iar_program_start
68 EXTERN SystemInit
69 PUBLIC __vector_table
70
71 DATA
72 __vector_table
73 DCD sfe(CSTACK)
74 DCD Reset_Handler ; Reset Handler
75
76 DCD NMI_Handler ; NMI Handler
77 DCD HardFault_Handler ; Hard Fault Handler
78 DCD MemManage_Handler ; MPU Fault Handler
79 DCD BusFault_Handler ; Bus Fault Handler
80 DCD UsageFault_Handler ; Usage Fault Handler
81 DCD 0 ; Reserved
82 DCD 0 ; Reserved
83 DCD 0 ; Reserved
84 DCD 0 ; Reserved
85 DCD SVC_Handler ; SVCall Handler
86 DCD DebugMon_Handler ; Debug Monitor Handler
87 DCD 0 ; Reserved
88 DCD PendSV_Handler ; PendSV Handler
89 DCD SysTick_Handler ; SysTick Handler
90
91 ; External Interrupts
92 DCD WWDG_IRQHandler ; Window WatchDog
93 DCD PVD_IRQHandler ; PVD through EXTI Line detection
94 DCD TAMP_STAMP_IRQHandler ; Tamper and TimeStamps through the EXTI line
95 DCD RTC_WKUP_IRQHandler ; RTC Wakeup through the EXTI line
96 DCD FLASH_IRQHandler ; FLASH
97 DCD RCC_IRQHandler ; RCC
98 DCD EXTI0_IRQHandler ; EXTI Line0
99 DCD EXTI1_IRQHandler ; EXTI Line1
100 DCD EXTI2_TSC_IRQHandler ; EXTI Line2 and Touch Sense controller
101 DCD EXTI3_IRQHandler ; EXTI Line3
102 DCD EXTI4_IRQHandler ; EXTI Line4
103 DCD DMA1_Channel1_IRQHandler ; DMA1 Channel 1
104 DCD DMA1_Channel2_IRQHandler ; DMA1 Channel 2
105 DCD DMA1_Channel3_IRQHandler ; DMA1 Channel 3
106 DCD DMA1_Channel4_IRQHandler ; DMA1 Channel 4
107 DCD DMA1_Channel5_IRQHandler ; DMA1 Channel 5
108 DCD DMA1_Channel6_IRQHandler ; DMA1 Channel 6
109 DCD DMA1_Channel7_IRQHandler ; DMA1 Channel 7
110 DCD ADC1_IRQHandler ; ADC1
111 DCD USB_HP_CAN_TX_IRQHandler ; USB Device High Priority or CAN TX
112 DCD USB_LP_CAN_RX0_IRQHandler ; USB Device Low Priority or CAN RX0
113 DCD CAN_RX1_IRQHandler ; CAN RX1
114 DCD CAN_SCE_IRQHandler ; CAN SCE
115 DCD EXTI9_5_IRQHandler ; External Line[9:5]s
116 DCD TIM1_BRK_TIM15_IRQHandler ; TIM1 Break and TIM15
117 DCD TIM1_UP_TIM16_IRQHandler ; TIM1 Update and TIM16
118 DCD TIM1_TRG_COM_TIM17_IRQHandler ; TIM1 Trigger and Commutation and TIM17
119 DCD TIM1_CC_IRQHandler ; TIM1 Capture Compare
120 DCD TIM2_IRQHandler ; TIM2
121 DCD 0 ; Reserved
122 DCD 0 ; Reserved
123 DCD I2C1_EV_IRQHandler ; I2C1 Event
124 DCD I2C1_ER_IRQHandler ; I2C1 Error
125 DCD I2C2_EV_IRQHandler ; I2C2 Event
126 DCD I2C2_ER_IRQHandler ; I2C2 Error
127 DCD 0 ; Reserved
128 DCD SPI2_IRQHandler ; SPI2
129 DCD USART1_IRQHandler ; USART1
130 DCD USART2_IRQHandler ; USART2
131 DCD USART3_IRQHandler ; USART3
132 DCD EXTI15_10_IRQHandler ; External Line[15:10]s
133 DCD RTC_Alarm_IRQHandler ; RTC Alarm (A and B) through EXTI Line
134 DCD USBWakeUp_IRQHandler ; USB Wakeup through EXTI line
135 DCD 0 ; Reserved
136 DCD 0 ; Reserved
137 DCD 0 ; Reserved
138 DCD 0 ; Reserved
139 DCD 0 ; Reserved
140 DCD 0 ; Reserved
141 DCD 0 ; Reserved
142 DCD 0 ; Reserved
143 DCD SPI3_IRQHandler ; SPI3
144 DCD 0 ; Reserved
145 DCD 0 ; Reserved
146 DCD TIM6_DAC_IRQHandler ; TIM6 and DAC1 underrun errors
147 DCD 0 ; Reserved
148 DCD 0 ; Reserved
149 DCD 0 ; Reserved
150 DCD 0 ; Reserved
151 DCD 0 ; Reserved
152 DCD 0 ; Reserved
153 DCD 0 ; Reserved
154 DCD 0 ; Reserved
155 DCD 0 ; Reserved
156 DCD COMP2_IRQHandler ; COMP2
157 DCD COMP4_6_IRQHandler ; COMP4 and COMP6
158 DCD 0 ; Reserved
159 DCD 0 ; Reserved
160 DCD 0 ; Reserved
161 DCD 0 ; Reserved
162 DCD 0 ; Reserved
163 DCD 0 ; Reserved
164 DCD I2C3_EV_IRQHandler ; I2C3 Event
165 DCD I2C3_ER_IRQHandler ; I2C3 Error
166 DCD USB_HP_IRQHandler ; USB High Priority remap
167 DCD USB_LP_IRQHandler ; USB Low Priority remap
168 DCD USBWakeUp_RMP_IRQHandler ; USB Wakeup remap through EXTI
169 DCD 0 ; Reserved
170 DCD 0 ; Reserved
171 DCD 0 ; Reserved
172 DCD 0 ; Reserved
173 DCD FPU_IRQHandler ; FPU
174
175 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
176 ;;
177 ;; Default interrupt handlers.
178 ;;
179 THUMB
180 PUBWEAK Reset_Handler
181 SECTION .text:CODE:NOROOT:REORDER(2)
182 Reset_Handler
183
184 LDR R0, =SystemInit
185 BLX R0
186 LDR R0, =__iar_program_start
187 BX R0
188
189 PUBWEAK NMI_Handler
190 SECTION .text:CODE:NOROOT:REORDER(1)
191 NMI_Handler
192 B NMI_Handler
193
194 PUBWEAK HardFault_Handler
195 SECTION .text:CODE:NOROOT:REORDER(1)
196 HardFault_Handler
197 B HardFault_Handler
198
199 PUBWEAK MemManage_Handler
200 SECTION .text:CODE:NOROOT:REORDER(1)
201 MemManage_Handler
202 B MemManage_Handler
203
204 PUBWEAK BusFault_Handler
205 SECTION .text:CODE:NOROOT:REORDER(1)
206 BusFault_Handler
207 B BusFault_Handler
208
209 PUBWEAK UsageFault_Handler
210 SECTION .text:CODE:NOROOT:REORDER(1)
211 UsageFault_Handler
212 B UsageFault_Handler
213
214 PUBWEAK SVC_Handler
215 SECTION .text:CODE:NOROOT:REORDER(1)
216 SVC_Handler
217 B SVC_Handler
218
219 PUBWEAK DebugMon_Handler
220 SECTION .text:CODE:NOROOT:REORDER(1)
221 DebugMon_Handler
222 B DebugMon_Handler
223
224 PUBWEAK PendSV_Handler
225 SECTION .text:CODE:NOROOT:REORDER(1)
226 PendSV_Handler
227 B PendSV_Handler
228
229 PUBWEAK SysTick_Handler
230 SECTION .text:CODE:NOROOT:REORDER(1)
231 SysTick_Handler
232 B SysTick_Handler
233
234 PUBWEAK WWDG_IRQHandler
235 SECTION .text:CODE:NOROOT:REORDER(1)
236 WWDG_IRQHandler
237 B WWDG_IRQHandler
238
239 PUBWEAK PVD_IRQHandler
240 SECTION .text:CODE:NOROOT:REORDER(1)
241 PVD_IRQHandler
242 B PVD_IRQHandler
243
244 PUBWEAK TAMP_STAMP_IRQHandler
245 SECTION .text:CODE:NOROOT:REORDER(1)
246 TAMP_STAMP_IRQHandler
247 B TAMP_STAMP_IRQHandler
248
249 PUBWEAK RTC_WKUP_IRQHandler
250 SECTION .text:CODE:NOROOT:REORDER(1)
251 RTC_WKUP_IRQHandler
252 B RTC_WKUP_IRQHandler
253
254 PUBWEAK FLASH_IRQHandler
255 SECTION .text:CODE:NOROOT:REORDER(1)
256 FLASH_IRQHandler
257 B FLASH_IRQHandler
258
259 PUBWEAK RCC_IRQHandler
260 SECTION .text:CODE:NOROOT:REORDER(1)
261 RCC_IRQHandler
262 B RCC_IRQHandler
263
264 PUBWEAK EXTI0_IRQHandler
265 SECTION .text:CODE:NOROOT:REORDER(1)
266 EXTI0_IRQHandler
267 B EXTI0_IRQHandler
268
269 PUBWEAK EXTI1_IRQHandler
270 SECTION .text:CODE:NOROOT:REORDER(1)
271 EXTI1_IRQHandler
272 B EXTI1_IRQHandler
273
274 PUBWEAK EXTI2_TSC_IRQHandler
275 SECTION .text:CODE:NOROOT:REORDER(1)
276 EXTI2_TSC_IRQHandler
277 B EXTI2_TSC_IRQHandler
278
279 PUBWEAK EXTI3_IRQHandler
280 SECTION .text:CODE:NOROOT:REORDER(1)
281 EXTI3_IRQHandler
282 B EXTI3_IRQHandler
283
284 PUBWEAK EXTI4_IRQHandler
285 SECTION .text:CODE:NOROOT:REORDER(1)
286 EXTI4_IRQHandler
287 B EXTI4_IRQHandler
288
289 PUBWEAK DMA1_Channel1_IRQHandler
290 SECTION .text:CODE:NOROOT:REORDER(1)
291 DMA1_Channel1_IRQHandler
292 B DMA1_Channel1_IRQHandler
293
294 PUBWEAK DMA1_Channel2_IRQHandler
295 SECTION .text:CODE:NOROOT:REORDER(1)
296 DMA1_Channel2_IRQHandler
297 B DMA1_Channel2_IRQHandler
298
299 PUBWEAK DMA1_Channel3_IRQHandler
300 SECTION .text:CODE:NOROOT:REORDER(1)
301 DMA1_Channel3_IRQHandler
302 B DMA1_Channel3_IRQHandler
303
304 PUBWEAK DMA1_Channel4_IRQHandler
305 SECTION .text:CODE:NOROOT:REORDER(1)
306 DMA1_Channel4_IRQHandler
307 B DMA1_Channel4_IRQHandler
308
309 PUBWEAK DMA1_Channel5_IRQHandler
310 SECTION .text:CODE:NOROOT:REORDER(1)
311 DMA1_Channel5_IRQHandler
312 B DMA1_Channel5_IRQHandler
313
314 PUBWEAK DMA1_Channel6_IRQHandler
315 SECTION .text:CODE:NOROOT:REORDER(1)
316 DMA1_Channel6_IRQHandler
317 B DMA1_Channel6_IRQHandler
318
319 PUBWEAK DMA1_Channel7_IRQHandler
320 SECTION .text:CODE:NOROOT:REORDER(1)
321 DMA1_Channel7_IRQHandler
322 B DMA1_Channel7_IRQHandler
323
324 PUBWEAK ADC1_IRQHandler
325 SECTION .text:CODE:NOROOT:REORDER(1)
326 ADC1_IRQHandler
327 B ADC1_IRQHandler
328
329 PUBWEAK USB_HP_CAN_TX_IRQHandler
330 SECTION .text:CODE:NOROOT:REORDER(1)
331 USB_HP_CAN_TX_IRQHandler
332 B USB_HP_CAN_TX_IRQHandler
333
334 PUBWEAK USB_LP_CAN_RX0_IRQHandler
335 SECTION .text:CODE:NOROOT:REORDER(1)
336 USB_LP_CAN_RX0_IRQHandler
337 B USB_LP_CAN_RX0_IRQHandler
338
339 PUBWEAK CAN_RX1_IRQHandler
340 SECTION .text:CODE:NOROOT:REORDER(1)
341 CAN_RX1_IRQHandler
342 B CAN_RX1_IRQHandler
343
344 PUBWEAK CAN_SCE_IRQHandler
345 SECTION .text:CODE:NOROOT:REORDER(1)
346 CAN_SCE_IRQHandler
347 B CAN_SCE_IRQHandler
348
349 PUBWEAK EXTI9_5_IRQHandler
350 SECTION .text:CODE:NOROOT:REORDER(1)
351 EXTI9_5_IRQHandler
352 B EXTI9_5_IRQHandler
353
354 PUBWEAK TIM1_BRK_TIM15_IRQHandler
355 SECTION .text:CODE:NOROOT:REORDER(1)
356 TIM1_BRK_TIM15_IRQHandler
357 B TIM1_BRK_TIM15_IRQHandler
358
359 PUBWEAK TIM1_UP_TIM16_IRQHandler
360 SECTION .text:CODE:NOROOT:REORDER(1)
361 TIM1_UP_TIM16_IRQHandler
362 B TIM1_UP_TIM16_IRQHandler
363
364 PUBWEAK TIM1_TRG_COM_TIM17_IRQHandler
365 SECTION .text:CODE:NOROOT:REORDER(1)
366 TIM1_TRG_COM_TIM17_IRQHandler
367 B TIM1_TRG_COM_TIM17_IRQHandler
368
369 PUBWEAK TIM1_CC_IRQHandler
370 SECTION .text:CODE:NOROOT:REORDER(1)
371 TIM1_CC_IRQHandler
372 B TIM1_CC_IRQHandler
373
374 PUBWEAK TIM2_IRQHandler
375 SECTION .text:CODE:NOROOT:REORDER(1)
376 TIM2_IRQHandler
377 B TIM2_IRQHandler
378
379 PUBWEAK I2C1_EV_IRQHandler
380 SECTION .text:CODE:NOROOT:REORDER(1)
381 I2C1_EV_IRQHandler
382 B I2C1_EV_IRQHandler
383
384 PUBWEAK I2C1_ER_IRQHandler
385 SECTION .text:CODE:NOROOT:REORDER(1)
386 I2C1_ER_IRQHandler
387 B I2C1_ER_IRQHandler
388
389 PUBWEAK I2C2_EV_IRQHandler
390 SECTION .text:CODE:NOROOT:REORDER(1)
391 I2C2_EV_IRQHandler
392 B I2C2_EV_IRQHandler
393
394 PUBWEAK I2C2_ER_IRQHandler
395 SECTION .text:CODE:NOROOT:REORDER(1)
396 I2C2_ER_IRQHandler
397 B I2C2_ER_IRQHandler
398
399 PUBWEAK SPI2_IRQHandler
400 SECTION .text:CODE:NOROOT:REORDER(1)
401 SPI2_IRQHandler
402 B SPI2_IRQHandler
403
404 PUBWEAK USART1_IRQHandler
405 SECTION .text:CODE:NOROOT:REORDER(1)
406 USART1_IRQHandler
407 B USART1_IRQHandler
408
409 PUBWEAK USART2_IRQHandler
410 SECTION .text:CODE:NOROOT:REORDER(1)
411 USART2_IRQHandler
412 B USART2_IRQHandler
413
414 PUBWEAK USART3_IRQHandler
415 SECTION .text:CODE:NOROOT:REORDER(1)
416 USART3_IRQHandler
417 B USART3_IRQHandler
418
419 PUBWEAK EXTI15_10_IRQHandler
420 SECTION .text:CODE:NOROOT:REORDER(1)
421 EXTI15_10_IRQHandler
422 B EXTI15_10_IRQHandler
423
424 PUBWEAK RTC_Alarm_IRQHandler
425 SECTION .text:CODE:NOROOT:REORDER(1)
426 RTC_Alarm_IRQHandler
427 B RTC_Alarm_IRQHandler
428
429 PUBWEAK USBWakeUp_IRQHandler
430 SECTION .text:CODE:NOROOT:REORDER(1)
431 USBWakeUp_IRQHandler
432 B USBWakeUp_IRQHandler
433
434 PUBWEAK SPI3_IRQHandler
435 SECTION .text:CODE:NOROOT:REORDER(1)
436 SPI3_IRQHandler
437 B SPI3_IRQHandler
438
439 PUBWEAK TIM6_DAC_IRQHandler
440 SECTION .text:CODE:NOROOT:REORDER(1)
441 TIM6_DAC_IRQHandler
442 B TIM6_DAC_IRQHandler
443
444 PUBWEAK COMP2_IRQHandler
445 SECTION .text:CODE:NOROOT:REORDER(1)
446 COMP2_IRQHandler
447 B COMP2_IRQHandler
448
449 PUBWEAK COMP4_6_IRQHandler
450 SECTION .text:CODE:NOROOT:REORDER(1)
451 COMP4_6_IRQHandler
452 B COMP4_6_IRQHandler
453
454 PUBWEAK I2C3_EV_IRQHandler
455 SECTION .text:CODE:NOROOT:REORDER(1)
456 I2C3_EV_IRQHandler
457 B I2C3_EV_IRQHandler
458
459 PUBWEAK I2C3_ER_IRQHandler
460 SECTION .text:CODE:NOROOT:REORDER(1)
461 I2C3_ER_IRQHandler
462 B I2C3_ER_IRQHandler
463
464 PUBWEAK USB_HP_IRQHandler
465 SECTION .text:CODE:NOROOT:REORDER(1)
466 USB_HP_IRQHandler
467 B USB_HP_IRQHandler
468
469 PUBWEAK USB_LP_IRQHandler
470 SECTION .text:CODE:NOROOT:REORDER(1)
471 USB_LP_IRQHandler
472 B USB_LP_IRQHandler
473
474 PUBWEAK USBWakeUp_RMP_IRQHandler
475 SECTION .text:CODE:NOROOT:REORDER(1)
476 USBWakeUp_RMP_IRQHandler
477 B USBWakeUp_RMP_IRQHandler
478
479 PUBWEAK FPU_IRQHandler
480 SECTION .text:CODE:NOROOT:REORDER(1)
481 FPU_IRQHandler
482 B FPU_IRQHandler
483
484 END
485 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/
Imprint / Impressum