Subversion Repositories AFRtranscoder

Rev

Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
2 mjames 1
;******************** (C) COPYRIGHT 2017 STMicroelectronics ********************
2
;* File Name          : startup_stm32f103xg.s
3
;* Author             : MCD Application Team
4
;* Description        : STM32F103xG Performances Line Devices vector table for EWARM 
5
;*                      toolchain.
6
;*                      This module performs:
7
;*                      - Set the initial SP
8
;*                      - Set the initial PC == __iar_program_start,
9
;*                      - Set the vector table entries with the exceptions ISR address,
10
;*                      After Reset the Cortex-M3 processor is in Thread mode,
11
;*                      priority is Privileged, and the Stack is set to Main.
12
;********************************************************************************
13
;*
14
;* Copyright (c) 2017-2021 STMicroelectronics.
15
;* All rights reserved.
16
;*
17
;* This software is licensed under terms that can be found in the LICENSE file
18
;* in the root directory of this software component.
19
;* If no LICENSE file comes with this software, it is provided AS-IS.
20
;
21
;*******************************************************************************
22
;
23
;
24
; The modules in this file are included in the libraries, and may be replaced
25
; by any user-defined modules that define the PUBLIC symbol _program_start or
26
; a user defined start symbol.
27
; To override the cstartup defined in the library, simply add your modified
28
; version to the workbench project.
29
;
30
; The vector table is normally located at address 0.
31
; When debugging in RAM, it can be located in RAM, aligned to at least 2^6.
32
; The name "__vector_table" has special meaning for C-SPY:
33
; it is where the SP start value is found, and the NVIC vector
34
; table register (VTOR) is initialized to this address if != 0.
35
;
36
; Cortex-M version
37
;     
38
 
39
    MODULE  ?cstartup
40
 
41
        ;; Forward declaration of sections.
42
        SECTION CSTACK:DATA:NOROOT(3)
43
 
44
        SECTION .intvec:CODE:NOROOT(2)
45
 
46
        EXTERN  __iar_program_start
47
        EXTERN  SystemInit        
48
        PUBLIC  __vector_table
49
 
50
        DATA
51
 
52
__vector_table
53
        DCD     sfe(CSTACK)
54
        DCD     Reset_Handler             ; Reset Handler
55
        DCD     NMI_Handler               ; NMI Handler
56
        DCD     HardFault_Handler         ; Hard Fault Handler
57
        DCD     MemManage_Handler         ; MPU Fault Handler
58
        DCD     BusFault_Handler          ; Bus Fault Handler
59
        DCD     UsageFault_Handler        ; Usage Fault Handler
60
        DCD     0                         ; Reserved
61
        DCD     0                         ; Reserved
62
        DCD     0                         ; Reserved
63
        DCD     0                         ; Reserved
64
        DCD     SVC_Handler               ; SVCall Handler
65
        DCD     DebugMon_Handler          ; Debug Monitor Handler
66
        DCD     0                         ; Reserved
67
        DCD     PendSV_Handler            ; PendSV Handler
68
        DCD     SysTick_Handler           ; SysTick Handler
69
 
70
         ; External Interrupts
71
        DCD     WWDG_IRQHandler               ; Window Watchdog
72
        DCD     PVD_IRQHandler                ; PVD through EXTI Line detect
73
        DCD     TAMPER_IRQHandler             ; Tamper
74
        DCD     RTC_IRQHandler                ; RTC
75
        DCD     FLASH_IRQHandler              ; Flash
76
        DCD     RCC_IRQHandler                ; RCC
77
        DCD     EXTI0_IRQHandler              ; EXTI Line 0
78
        DCD     EXTI1_IRQHandler              ; EXTI Line 1
79
        DCD     EXTI2_IRQHandler              ; EXTI Line 2
80
        DCD     EXTI3_IRQHandler              ; EXTI Line 3
81
        DCD     EXTI4_IRQHandler              ; EXTI Line 4
82
        DCD     DMA1_Channel1_IRQHandler      ; DMA1 Channel 1
83
        DCD     DMA1_Channel2_IRQHandler      ; DMA1 Channel 2
84
        DCD     DMA1_Channel3_IRQHandler      ; DMA1 Channel 3
85
        DCD     DMA1_Channel4_IRQHandler      ; DMA1 Channel 4
86
        DCD     DMA1_Channel5_IRQHandler      ; DMA1 Channel 5
87
        DCD     DMA1_Channel6_IRQHandler      ; DMA1 Channel 6
88
        DCD     DMA1_Channel7_IRQHandler      ; DMA1 Channel 7
89
        DCD     ADC1_2_IRQHandler             ; ADC1 & ADC2
90
        DCD     USB_HP_CAN1_TX_IRQHandler     ; USB High Priority or CAN1 TX
91
        DCD     USB_LP_CAN1_RX0_IRQHandler    ; USB Low  Priority or CAN1 RX0
92
        DCD     CAN1_RX1_IRQHandler           ; CAN1 RX1
93
        DCD     CAN1_SCE_IRQHandler           ; CAN1 SCE
94
        DCD     EXTI9_5_IRQHandler            ; EXTI Line 9..5
95
        DCD     TIM1_BRK_TIM9_IRQHandler      ; TIM1 Break and TIM9
96
        DCD     TIM1_UP_TIM10_IRQHandler      ; TIM1 Update and TIM10
97
        DCD     TIM1_TRG_COM_TIM11_IRQHandler ; TIM1 Trigger and Commutation and TIM11
98
        DCD     TIM1_CC_IRQHandler            ; TIM1 Capture Compare
99
        DCD     TIM2_IRQHandler               ; TIM2
100
        DCD     TIM3_IRQHandler               ; TIM3
101
        DCD     TIM4_IRQHandler               ; TIM4
102
        DCD     I2C1_EV_IRQHandler            ; I2C1 Event
103
        DCD     I2C1_ER_IRQHandler            ; I2C1 Error
104
        DCD     I2C2_EV_IRQHandler            ; I2C2 Event
105
        DCD     I2C2_ER_IRQHandler            ; I2C2 Error
106
        DCD     SPI1_IRQHandler               ; SPI1
107
        DCD     SPI2_IRQHandler               ; SPI2
108
        DCD     USART1_IRQHandler             ; USART1
109
        DCD     USART2_IRQHandler             ; USART2
110
        DCD     USART3_IRQHandler             ; USART3
111
        DCD     EXTI15_10_IRQHandler          ; EXTI Line 15..10
112
        DCD     RTC_Alarm_IRQHandler           ; RTC Alarm through EXTI Line
113
        DCD     USBWakeUp_IRQHandler          ; USB Wakeup from suspend
114
        DCD     TIM8_BRK_TIM12_IRQHandler     ; TIM8 Break and TIM12
115
        DCD     TIM8_UP_TIM13_IRQHandler      ; TIM8 Update and TIM13
116
        DCD     TIM8_TRG_COM_TIM14_IRQHandler ; TIM8 Trigger and Commutation and TIM14
117
        DCD     TIM8_CC_IRQHandler            ; TIM8 Capture Compare
118
        DCD     ADC3_IRQHandler               ; ADC3
119
        DCD     FSMC_IRQHandler               ; FSMC
120
        DCD     SDIO_IRQHandler               ; SDIO
121
        DCD     TIM5_IRQHandler               ; TIM5
122
        DCD     SPI3_IRQHandler               ; SPI3
123
        DCD     UART4_IRQHandler              ; UART4
124
        DCD     UART5_IRQHandler              ; UART5
125
        DCD     TIM6_IRQHandler               ; TIM6
126
        DCD     TIM7_IRQHandler               ; TIM7
127
        DCD     DMA2_Channel1_IRQHandler      ; DMA2 Channel1
128
        DCD     DMA2_Channel2_IRQHandler      ; DMA2 Channel2
129
        DCD     DMA2_Channel3_IRQHandler      ; DMA2 Channel3
130
        DCD     DMA2_Channel4_5_IRQHandler    ; DMA2 Channel4 & Channel5
131
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
132
;;
133
;; Default interrupt handlers.
134
;;
135
        THUMB
136
 
137
        PUBWEAK Reset_Handler
138
        SECTION .text:CODE:REORDER:NOROOT(2)
139
Reset_Handler
140
        LDR     R0, =SystemInit
141
        BLX     R0
142
        LDR     R0, =__iar_program_start
143
        BX      R0
144
 
145
        PUBWEAK NMI_Handler
146
        SECTION .text:CODE:REORDER:NOROOT(1)
147
NMI_Handler
148
        B NMI_Handler
149
 
150
        PUBWEAK HardFault_Handler
151
        SECTION .text:CODE:REORDER:NOROOT(1)
152
HardFault_Handler
153
        B HardFault_Handler
154
 
155
        PUBWEAK MemManage_Handler
156
        SECTION .text:CODE:REORDER:NOROOT(1)
157
MemManage_Handler
158
        B MemManage_Handler
159
 
160
        PUBWEAK BusFault_Handler
161
        SECTION .text:CODE:REORDER:NOROOT(1)
162
BusFault_Handler
163
        B BusFault_Handler
164
 
165
        PUBWEAK UsageFault_Handler
166
        SECTION .text:CODE:REORDER:NOROOT(1)
167
UsageFault_Handler
168
        B UsageFault_Handler
169
 
170
        PUBWEAK SVC_Handler
171
        SECTION .text:CODE:REORDER:NOROOT(1)
172
SVC_Handler
173
        B SVC_Handler
174
 
175
        PUBWEAK DebugMon_Handler
176
        SECTION .text:CODE:REORDER:NOROOT(1)
177
DebugMon_Handler
178
        B DebugMon_Handler
179
 
180
        PUBWEAK PendSV_Handler
181
        SECTION .text:CODE:REORDER:NOROOT(1)
182
PendSV_Handler
183
        B PendSV_Handler
184
 
185
        PUBWEAK SysTick_Handler
186
        SECTION .text:CODE:REORDER:NOROOT(1)
187
SysTick_Handler
188
        B SysTick_Handler
189
 
190
        PUBWEAK WWDG_IRQHandler
191
        SECTION .text:CODE:REORDER:NOROOT(1)
192
WWDG_IRQHandler
193
        B WWDG_IRQHandler
194
 
195
        PUBWEAK PVD_IRQHandler
196
        SECTION .text:CODE:REORDER:NOROOT(1)
197
PVD_IRQHandler
198
        B PVD_IRQHandler
199
 
200
        PUBWEAK TAMPER_IRQHandler
201
        SECTION .text:CODE:REORDER:NOROOT(1)
202
TAMPER_IRQHandler
203
        B TAMPER_IRQHandler
204
 
205
        PUBWEAK RTC_IRQHandler
206
        SECTION .text:CODE:REORDER:NOROOT(1)
207
RTC_IRQHandler
208
        B RTC_IRQHandler
209
 
210
        PUBWEAK FLASH_IRQHandler
211
        SECTION .text:CODE:REORDER:NOROOT(1)
212
FLASH_IRQHandler
213
        B FLASH_IRQHandler
214
 
215
        PUBWEAK RCC_IRQHandler
216
        SECTION .text:CODE:REORDER:NOROOT(1)
217
RCC_IRQHandler
218
        B RCC_IRQHandler
219
 
220
        PUBWEAK EXTI0_IRQHandler
221
        SECTION .text:CODE:REORDER:NOROOT(1)
222
EXTI0_IRQHandler
223
        B EXTI0_IRQHandler
224
 
225
        PUBWEAK EXTI1_IRQHandler
226
        SECTION .text:CODE:REORDER:NOROOT(1)
227
EXTI1_IRQHandler
228
        B EXTI1_IRQHandler
229
 
230
        PUBWEAK EXTI2_IRQHandler
231
        SECTION .text:CODE:REORDER:NOROOT(1)
232
EXTI2_IRQHandler
233
        B EXTI2_IRQHandler
234
 
235
        PUBWEAK EXTI3_IRQHandler
236
        SECTION .text:CODE:REORDER:NOROOT(1)
237
EXTI3_IRQHandler
238
        B EXTI3_IRQHandler
239
 
240
        PUBWEAK EXTI4_IRQHandler
241
        SECTION .text:CODE:REORDER:NOROOT(1)
242
EXTI4_IRQHandler
243
        B EXTI4_IRQHandler
244
 
245
        PUBWEAK DMA1_Channel1_IRQHandler
246
        SECTION .text:CODE:REORDER:NOROOT(1)
247
DMA1_Channel1_IRQHandler
248
        B DMA1_Channel1_IRQHandler
249
 
250
        PUBWEAK DMA1_Channel2_IRQHandler
251
        SECTION .text:CODE:REORDER:NOROOT(1)
252
DMA1_Channel2_IRQHandler
253
        B DMA1_Channel2_IRQHandler
254
 
255
        PUBWEAK DMA1_Channel3_IRQHandler
256
        SECTION .text:CODE:REORDER:NOROOT(1)
257
DMA1_Channel3_IRQHandler
258
        B DMA1_Channel3_IRQHandler
259
 
260
        PUBWEAK DMA1_Channel4_IRQHandler
261
        SECTION .text:CODE:REORDER:NOROOT(1)
262
DMA1_Channel4_IRQHandler
263
        B DMA1_Channel4_IRQHandler
264
 
265
        PUBWEAK DMA1_Channel5_IRQHandler
266
        SECTION .text:CODE:REORDER:NOROOT(1)
267
DMA1_Channel5_IRQHandler
268
        B DMA1_Channel5_IRQHandler
269
 
270
        PUBWEAK DMA1_Channel6_IRQHandler
271
        SECTION .text:CODE:REORDER:NOROOT(1)
272
DMA1_Channel6_IRQHandler
273
        B DMA1_Channel6_IRQHandler
274
 
275
        PUBWEAK DMA1_Channel7_IRQHandler
276
        SECTION .text:CODE:REORDER:NOROOT(1)
277
DMA1_Channel7_IRQHandler
278
        B DMA1_Channel7_IRQHandler
279
 
280
        PUBWEAK ADC1_2_IRQHandler
281
        SECTION .text:CODE:REORDER:NOROOT(1)
282
ADC1_2_IRQHandler
283
        B ADC1_2_IRQHandler
284
 
285
        PUBWEAK USB_HP_CAN1_TX_IRQHandler
286
        SECTION .text:CODE:REORDER:NOROOT(1)
287
USB_HP_CAN1_TX_IRQHandler
288
        B USB_HP_CAN1_TX_IRQHandler
289
 
290
        PUBWEAK USB_LP_CAN1_RX0_IRQHandler
291
        SECTION .text:CODE:REORDER:NOROOT(1)
292
USB_LP_CAN1_RX0_IRQHandler
293
        B USB_LP_CAN1_RX0_IRQHandler
294
 
295
        PUBWEAK CAN1_RX1_IRQHandler
296
        SECTION .text:CODE:REORDER:NOROOT(1)
297
CAN1_RX1_IRQHandler
298
        B CAN1_RX1_IRQHandler
299
 
300
        PUBWEAK CAN1_SCE_IRQHandler
301
        SECTION .text:CODE:REORDER:NOROOT(1)
302
CAN1_SCE_IRQHandler
303
        B CAN1_SCE_IRQHandler
304
 
305
        PUBWEAK EXTI9_5_IRQHandler
306
        SECTION .text:CODE:REORDER:NOROOT(1)
307
EXTI9_5_IRQHandler
308
        B EXTI9_5_IRQHandler
309
 
310
        PUBWEAK TIM1_BRK_TIM9_IRQHandler
311
        SECTION .text:CODE:REORDER:NOROOT(1)
312
TIM1_BRK_TIM9_IRQHandler
313
        B TIM1_BRK_TIM9_IRQHandler
314
 
315
        PUBWEAK TIM1_UP_TIM10_IRQHandler
316
        SECTION .text:CODE:REORDER:NOROOT(1)
317
TIM1_UP_TIM10_IRQHandler
318
        B TIM1_UP_TIM10_IRQHandler
319
 
320
        PUBWEAK TIM1_TRG_COM_TIM11_IRQHandler
321
        SECTION .text:CODE:REORDER:NOROOT(1)
322
TIM1_TRG_COM_TIM11_IRQHandler
323
        B TIM1_TRG_COM_TIM11_IRQHandler
324
 
325
        PUBWEAK TIM1_CC_IRQHandler
326
        SECTION .text:CODE:REORDER:NOROOT(1)
327
TIM1_CC_IRQHandler
328
        B TIM1_CC_IRQHandler
329
 
330
        PUBWEAK TIM2_IRQHandler
331
        SECTION .text:CODE:REORDER:NOROOT(1)
332
TIM2_IRQHandler
333
        B TIM2_IRQHandler
334
 
335
        PUBWEAK TIM3_IRQHandler
336
        SECTION .text:CODE:REORDER:NOROOT(1)
337
TIM3_IRQHandler
338
        B TIM3_IRQHandler
339
 
340
        PUBWEAK TIM4_IRQHandler
341
        SECTION .text:CODE:REORDER:NOROOT(1)
342
TIM4_IRQHandler
343
        B TIM4_IRQHandler
344
 
345
        PUBWEAK I2C1_EV_IRQHandler
346
        SECTION .text:CODE:REORDER:NOROOT(1)
347
I2C1_EV_IRQHandler
348
        B I2C1_EV_IRQHandler
349
 
350
        PUBWEAK I2C1_ER_IRQHandler
351
        SECTION .text:CODE:REORDER:NOROOT(1)
352
I2C1_ER_IRQHandler
353
        B I2C1_ER_IRQHandler
354
 
355
        PUBWEAK I2C2_EV_IRQHandler
356
        SECTION .text:CODE:REORDER:NOROOT(1)
357
I2C2_EV_IRQHandler
358
        B I2C2_EV_IRQHandler
359
 
360
        PUBWEAK I2C2_ER_IRQHandler
361
        SECTION .text:CODE:REORDER:NOROOT(1)
362
I2C2_ER_IRQHandler
363
        B I2C2_ER_IRQHandler
364
 
365
        PUBWEAK SPI1_IRQHandler
366
        SECTION .text:CODE:REORDER:NOROOT(1)
367
SPI1_IRQHandler
368
        B SPI1_IRQHandler
369
 
370
        PUBWEAK SPI2_IRQHandler
371
        SECTION .text:CODE:REORDER:NOROOT(1)
372
SPI2_IRQHandler
373
        B SPI2_IRQHandler
374
 
375
        PUBWEAK USART1_IRQHandler
376
        SECTION .text:CODE:REORDER:NOROOT(1)
377
USART1_IRQHandler
378
        B USART1_IRQHandler
379
 
380
        PUBWEAK USART2_IRQHandler
381
        SECTION .text:CODE:REORDER:NOROOT(1)
382
USART2_IRQHandler
383
        B USART2_IRQHandler
384
 
385
        PUBWEAK USART3_IRQHandler
386
        SECTION .text:CODE:REORDER:NOROOT(1)
387
USART3_IRQHandler
388
        B USART3_IRQHandler
389
 
390
        PUBWEAK EXTI15_10_IRQHandler
391
        SECTION .text:CODE:REORDER:NOROOT(1)
392
EXTI15_10_IRQHandler
393
        B EXTI15_10_IRQHandler
394
 
395
        PUBWEAK RTC_Alarm_IRQHandler
396
        SECTION .text:CODE:REORDER:NOROOT(1)
397
RTC_Alarm_IRQHandler
398
        B RTC_Alarm_IRQHandler
399
 
400
        PUBWEAK USBWakeUp_IRQHandler
401
        SECTION .text:CODE:REORDER:NOROOT(1)
402
USBWakeUp_IRQHandler
403
        B USBWakeUp_IRQHandler
404
 
405
        PUBWEAK TIM8_BRK_TIM12_IRQHandler
406
        SECTION .text:CODE:REORDER:NOROOT(1)
407
TIM8_BRK_TIM12_IRQHandler
408
        B TIM8_BRK_TIM12_IRQHandler
409
 
410
        PUBWEAK TIM8_UP_TIM13_IRQHandler
411
        SECTION .text:CODE:REORDER:NOROOT(1)
412
TIM8_UP_TIM13_IRQHandler
413
        B TIM8_UP_TIM13_IRQHandler
414
 
415
        PUBWEAK TIM8_TRG_COM_TIM14_IRQHandler
416
        SECTION .text:CODE:REORDER:NOROOT(1)
417
TIM8_TRG_COM_TIM14_IRQHandler
418
        B TIM8_TRG_COM_TIM14_IRQHandler
419
 
420
        PUBWEAK TIM8_CC_IRQHandler
421
        SECTION .text:CODE:REORDER:NOROOT(1)
422
TIM8_CC_IRQHandler
423
        B TIM8_CC_IRQHandler
424
 
425
        PUBWEAK ADC3_IRQHandler
426
        SECTION .text:CODE:REORDER:NOROOT(1)
427
ADC3_IRQHandler
428
        B ADC3_IRQHandler
429
 
430
        PUBWEAK FSMC_IRQHandler
431
        SECTION .text:CODE:REORDER:NOROOT(1)
432
FSMC_IRQHandler
433
        B FSMC_IRQHandler
434
 
435
        PUBWEAK SDIO_IRQHandler
436
        SECTION .text:CODE:REORDER:NOROOT(1)
437
SDIO_IRQHandler
438
        B SDIO_IRQHandler
439
 
440
        PUBWEAK TIM5_IRQHandler
441
        SECTION .text:CODE:REORDER:NOROOT(1)
442
TIM5_IRQHandler
443
        B TIM5_IRQHandler
444
 
445
        PUBWEAK SPI3_IRQHandler
446
        SECTION .text:CODE:REORDER:NOROOT(1)
447
SPI3_IRQHandler
448
        B SPI3_IRQHandler
449
 
450
        PUBWEAK UART4_IRQHandler
451
        SECTION .text:CODE:REORDER:NOROOT(1)
452
UART4_IRQHandler
453
        B UART4_IRQHandler
454
 
455
        PUBWEAK UART5_IRQHandler
456
        SECTION .text:CODE:REORDER:NOROOT(1)
457
UART5_IRQHandler
458
        B UART5_IRQHandler
459
 
460
        PUBWEAK TIM6_IRQHandler
461
        SECTION .text:CODE:REORDER:NOROOT(1)
462
TIM6_IRQHandler
463
        B TIM6_IRQHandler
464
 
465
        PUBWEAK TIM7_IRQHandler
466
        SECTION .text:CODE:REORDER:NOROOT(1)
467
TIM7_IRQHandler
468
        B TIM7_IRQHandler
469
 
470
        PUBWEAK DMA2_Channel1_IRQHandler
471
        SECTION .text:CODE:REORDER:NOROOT(1)
472
DMA2_Channel1_IRQHandler
473
        B DMA2_Channel1_IRQHandler
474
 
475
        PUBWEAK DMA2_Channel2_IRQHandler
476
        SECTION .text:CODE:REORDER:NOROOT(1)
477
DMA2_Channel2_IRQHandler
478
        B DMA2_Channel2_IRQHandler
479
 
480
        PUBWEAK DMA2_Channel3_IRQHandler
481
        SECTION .text:CODE:REORDER:NOROOT(1)
482
DMA2_Channel3_IRQHandler
483
        B DMA2_Channel3_IRQHandler
484
 
485
        PUBWEAK DMA2_Channel4_5_IRQHandler
486
        SECTION .text:CODE:REORDER:NOROOT(1)
487
DMA2_Channel4_5_IRQHandler
488
        B DMA2_Channel4_5_IRQHandler
489
 
490
 
491
        END
492