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