1 ;
******************** (C
) COPYRIGHT
2017 STMicroelectronics
********************
2 ;
* File Name
: startup_stm32f103xg.s
3 ;
* Author
: MCD Application Team
5 ;
* Date
: 31-March-
2017
6 ;
* Description
: STM32F103xG Performances Line Devices vector table for EWARM
8 ;
* This module performs
:
9 ;
* - Set the initial SP
10 ;
* - Set the initial PC
== __iar_program_start
,
11 ;
* - Set the vector table entries with the exceptions ISR address
,
12 ;
* After Reset the Cortex-M3 processor is in Thread mode
,
13 ;
* priority is Privileged
, and the Stack is set to Main.
14 ;
********************************************************************************
16 ;
* <h2
><center
>© COPYRIGHT
(c
) 2017 STMicroelectronics
</center
></h2
>
18 ;
* Redistribution
and use in source
and binary forms
, with
or without modification
,
19 ;
* are permitted provided that the following conditions are met
:
20 ;
* 1. Redistributions of source code must retain the above copyright notice,
21 ;
* this list of conditions
and the following disclaimer.
22 ;
* 2. Redistributions in binary form must reproduce the above copyright notice,
23 ;
* this list of conditions
and the following disclaimer in the documentation
24 ;
* and/or other materials provided with the distribution.
25 ;
* 3. Neither the name of STMicroelectronics nor the names of its contributors
26 ;
* may
be used to endorse
or promote products derived from this software
27 ;
* without specific prior written permission.
29 ;
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS
AND CONTRIBUTORS
"AS IS"
30 ;
* AND ANY EXPRESS
OR IMPLIED WARRANTIES
, INCLUDING
, BUT
NOT LIMITED TO
, THE
31 ;
* IMPLIED WARRANTIES OF MERCHANTABILITY
AND FITNESS FOR
A PARTICULAR PURPOSE ARE
32 ;
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER
OR CONTRIBUTORS
BE LIABLE
33 ;
* FOR ANY DIRECT
, INDIRECT
, INCIDENTAL
, SPECIAL
, EXEMPLARY
, OR CONSEQUENTIAL
34 ;
* DAMAGES
(INCLUDING
, BUT
NOT LIMITED TO
, PROCUREMENT OF SUBSTITUTE GOODS
OR
35 ;
* SERVICES; LOSS OF USE
, DATA
, OR PROFITS;
OR BUSINESS INTERRUPTION
) HOWEVER
36 ;
* CAUSED
AND ON ANY THEORY OF LIABILITY
, WHETHER IN CONTRACT
, STRICT LIABILITY
,
37 ;
* OR TORT
(INCLUDING NEGLIGENCE
OR OTHERWISE
) ARISING IN ANY WAY OUT OF THE USE
38 ;
* OF THIS SOFTWARE
, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
40 ;
*******************************************************************************
43 ; The modules in this file are included in the libraries
, and may
be replaced
44 ; by any user-defined modules that define the PUBLIC symbol _program_start
or
45 ;
a user defined start symbol.
46 ; To override the cstartup defined in the library
, simply
add your modified
47 ; version to the workbench project.
49 ; The vector table is normally located at address
0.
50 ; When debugging in RAM
, it can
be located in RAM
, aligned to at least
2^
6.
51 ; The name
"__vector_table" has special meaning for C-SPY
:
52 ; it is where the SP start value is found
, and the NVIC vector
53 ; table register
(VTOR
) is initialized to this address if
!= 0.
60 ;; Forward declaration of sections.
61 SECTION CSTACK
:DATA
:NOROOT
(3)
63 SECTION
.intvec:CODE:NOROOT(2)
65 EXTERN __iar_program_start
73 DCD Reset_Handler ; Reset Handler
74 DCD NMI_Handler ; NMI Handler
75 DCD HardFault_Handler ; Hard Fault Handler
76 DCD MemManage_Handler ; MPU Fault Handler
77 DCD BusFault_Handler ; Bus Fault Handler
78 DCD UsageFault_Handler ; Usage Fault Handler
83 DCD SVC_Handler ; SVCall Handler
84 DCD DebugMon_Handler ; Debug Monitor Handler
86 DCD PendSV_Handler ; PendSV Handler
87 DCD SysTick_Handler ; SysTick Handler
90 DCD WWDG_IRQHandler ; Window Watchdog
91 DCD PVD_IRQHandler ; PVD through EXTI Line detect
92 DCD TAMPER_IRQHandler ; Tamper
93 DCD RTC_IRQHandler ; RTC
94 DCD FLASH_IRQHandler ; Flash
95 DCD RCC_IRQHandler ; RCC
96 DCD EXTI0_IRQHandler ; EXTI Line
0
97 DCD EXTI1_IRQHandler ; EXTI Line
1
98 DCD EXTI2_IRQHandler ; EXTI Line
2
99 DCD EXTI3_IRQHandler ; EXTI Line
3
100 DCD EXTI4_IRQHandler ; EXTI Line
4
101 DCD DMA1_Channel1_IRQHandler ; DMA1 Channel
1
102 DCD DMA1_Channel2_IRQHandler ; DMA1 Channel
2
103 DCD DMA1_Channel3_IRQHandler ; DMA1 Channel
3
104 DCD DMA1_Channel4_IRQHandler ; DMA1 Channel
4
105 DCD DMA1_Channel5_IRQHandler ; DMA1 Channel
5
106 DCD DMA1_Channel6_IRQHandler ; DMA1 Channel
6
107 DCD DMA1_Channel7_IRQHandler ; DMA1 Channel
7
108 DCD ADC1_2_IRQHandler ; ADC1
& ADC2
109 DCD USB_HP_CAN1_TX_IRQHandler ; USB High Priority
or CAN1 TX
110 DCD USB_LP_CAN1_RX0_IRQHandler ; USB Low Priority
or CAN1 RX0
111 DCD CAN1_RX1_IRQHandler ; CAN1 RX1
112 DCD CAN1_SCE_IRQHandler ; CAN1 SCE
113 DCD EXTI9_5_IRQHandler ; EXTI Line
9..5
114 DCD TIM1_BRK_TIM9_IRQHandler ; TIM1 Break
and TIM9
115 DCD TIM1_UP_TIM10_IRQHandler ; TIM1 Update
and TIM10
116 DCD TIM1_TRG_COM_TIM11_IRQHandler ; TIM1 Trigger
and Commutation
and TIM11
117 DCD TIM1_CC_IRQHandler ; TIM1 Capture Compare
118 DCD TIM2_IRQHandler ; TIM2
119 DCD TIM3_IRQHandler ; TIM3
120 DCD TIM4_IRQHandler ; TIM4
121 DCD I2C1_EV_IRQHandler ; I2C1 Event
122 DCD I2C1_ER_IRQHandler ; I2C1 Error
123 DCD I2C2_EV_IRQHandler ; I2C2 Event
124 DCD I2C2_ER_IRQHandler ; I2C2 Error
125 DCD SPI1_IRQHandler ; SPI1
126 DCD SPI2_IRQHandler ; SPI2
127 DCD USART1_IRQHandler ; USART1
128 DCD USART2_IRQHandler ; USART2
129 DCD USART3_IRQHandler ; USART3
130 DCD EXTI15_10_IRQHandler ; EXTI Line
15..10
131 DCD RTC_Alarm_IRQHandler ; RTC Alarm through EXTI Line
132 DCD USBWakeUp_IRQHandler ; USB Wakeup from suspend
133 DCD TIM8_BRK_TIM12_IRQHandler ; TIM8 Break
and TIM12
134 DCD TIM8_UP_TIM13_IRQHandler ; TIM8 Update
and TIM13
135 DCD TIM8_TRG_COM_TIM14_IRQHandler ; TIM8 Trigger
and Commutation
and TIM14
136 DCD TIM8_CC_IRQHandler ; TIM8 Capture Compare
137 DCD ADC3_IRQHandler ; ADC3
138 DCD FSMC_IRQHandler ; FSMC
139 DCD SDIO_IRQHandler ; SDIO
140 DCD TIM5_IRQHandler ; TIM5
141 DCD SPI3_IRQHandler ; SPI3
142 DCD UART4_IRQHandler ; UART4
143 DCD UART5_IRQHandler ; UART5
144 DCD TIM6_IRQHandler ; TIM6
145 DCD TIM7_IRQHandler ; TIM7
146 DCD DMA2_Channel1_IRQHandler ; DMA2 Channel1
147 DCD DMA2_Channel2_IRQHandler ; DMA2 Channel2
148 DCD DMA2_Channel3_IRQHandler ; DMA2 Channel3
149 DCD DMA2_Channel4_5_IRQHandler ; DMA2 Channel4
& Channel5
150 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
152 ;; Default interrupt handlers.
156 PUBWEAK Reset_Handler
157 SECTION
.text:CODE:REORDER:NOROOT(2)
161 LDR
R0, =__iar_program_start
165 SECTION
.text:CODE:REORDER:NOROOT(1)
169 PUBWEAK HardFault_Handler
170 SECTION
.text:CODE:REORDER:NOROOT(1)
174 PUBWEAK MemManage_Handler
175 SECTION
.text:CODE:REORDER:NOROOT(1)
179 PUBWEAK BusFault_Handler
180 SECTION
.text:CODE:REORDER:NOROOT(1)
184 PUBWEAK UsageFault_Handler
185 SECTION
.text:CODE:REORDER:NOROOT(1)
190 SECTION
.text:CODE:REORDER:NOROOT(1)
194 PUBWEAK DebugMon_Handler
195 SECTION
.text:CODE:REORDER:NOROOT(1)
199 PUBWEAK PendSV_Handler
200 SECTION
.text:CODE:REORDER:NOROOT(1)
204 PUBWEAK SysTick_Handler
205 SECTION
.text:CODE:REORDER:NOROOT(1)
209 PUBWEAK WWDG_IRQHandler
210 SECTION
.text:CODE:REORDER:NOROOT(1)
214 PUBWEAK PVD_IRQHandler
215 SECTION
.text:CODE:REORDER:NOROOT(1)
219 PUBWEAK TAMPER_IRQHandler
220 SECTION
.text:CODE:REORDER:NOROOT(1)
224 PUBWEAK RTC_IRQHandler
225 SECTION
.text:CODE:REORDER:NOROOT(1)
229 PUBWEAK FLASH_IRQHandler
230 SECTION
.text:CODE:REORDER:NOROOT(1)
234 PUBWEAK RCC_IRQHandler
235 SECTION
.text:CODE:REORDER:NOROOT(1)
239 PUBWEAK EXTI0_IRQHandler
240 SECTION
.text:CODE:REORDER:NOROOT(1)
244 PUBWEAK EXTI1_IRQHandler
245 SECTION
.text:CODE:REORDER:NOROOT(1)
249 PUBWEAK EXTI2_IRQHandler
250 SECTION
.text:CODE:REORDER:NOROOT(1)
254 PUBWEAK EXTI3_IRQHandler
255 SECTION
.text:CODE:REORDER:NOROOT(1)
259 PUBWEAK EXTI4_IRQHandler
260 SECTION
.text:CODE:REORDER:NOROOT(1)
264 PUBWEAK DMA1_Channel1_IRQHandler
265 SECTION
.text:CODE:REORDER:NOROOT(1)
266 DMA1_Channel1_IRQHandler
267 B DMA1_Channel1_IRQHandler
269 PUBWEAK DMA1_Channel2_IRQHandler
270 SECTION
.text:CODE:REORDER:NOROOT(1)
271 DMA1_Channel2_IRQHandler
272 B DMA1_Channel2_IRQHandler
274 PUBWEAK DMA1_Channel3_IRQHandler
275 SECTION
.text:CODE:REORDER:NOROOT(1)
276 DMA1_Channel3_IRQHandler
277 B DMA1_Channel3_IRQHandler
279 PUBWEAK DMA1_Channel4_IRQHandler
280 SECTION
.text:CODE:REORDER:NOROOT(1)
281 DMA1_Channel4_IRQHandler
282 B DMA1_Channel4_IRQHandler
284 PUBWEAK DMA1_Channel5_IRQHandler
285 SECTION
.text:CODE:REORDER:NOROOT(1)
286 DMA1_Channel5_IRQHandler
287 B DMA1_Channel5_IRQHandler
289 PUBWEAK DMA1_Channel6_IRQHandler
290 SECTION
.text:CODE:REORDER:NOROOT(1)
291 DMA1_Channel6_IRQHandler
292 B DMA1_Channel6_IRQHandler
294 PUBWEAK DMA1_Channel7_IRQHandler
295 SECTION
.text:CODE:REORDER:NOROOT(1)
296 DMA1_Channel7_IRQHandler
297 B DMA1_Channel7_IRQHandler
299 PUBWEAK ADC1_2_IRQHandler
300 SECTION
.text:CODE:REORDER:NOROOT(1)
304 PUBWEAK USB_HP_CAN1_TX_IRQHandler
305 SECTION
.text:CODE:REORDER:NOROOT(1)
306 USB_HP_CAN1_TX_IRQHandler
307 B USB_HP_CAN1_TX_IRQHandler
309 PUBWEAK USB_LP_CAN1_RX0_IRQHandler
310 SECTION
.text:CODE:REORDER:NOROOT(1)
311 USB_LP_CAN1_RX0_IRQHandler
312 B USB_LP_CAN1_RX0_IRQHandler
314 PUBWEAK CAN1_RX1_IRQHandler
315 SECTION
.text:CODE:REORDER:NOROOT(1)
317 B CAN1_RX1_IRQHandler
319 PUBWEAK CAN1_SCE_IRQHandler
320 SECTION
.text:CODE:REORDER:NOROOT(1)
322 B CAN1_SCE_IRQHandler
324 PUBWEAK EXTI9_5_IRQHandler
325 SECTION
.text:CODE:REORDER:NOROOT(1)
329 PUBWEAK TIM1_BRK_TIM9_IRQHandler
330 SECTION
.text:CODE:REORDER:NOROOT(1)
331 TIM1_BRK_TIM9_IRQHandler
332 B TIM1_BRK_TIM9_IRQHandler
334 PUBWEAK TIM1_UP_TIM10_IRQHandler
335 SECTION
.text:CODE:REORDER:NOROOT(1)
336 TIM1_UP_TIM10_IRQHandler
337 B TIM1_UP_TIM10_IRQHandler
339 PUBWEAK TIM1_TRG_COM_TIM11_IRQHandler
340 SECTION
.text:CODE:REORDER:NOROOT(1)
341 TIM1_TRG_COM_TIM11_IRQHandler
342 B TIM1_TRG_COM_TIM11_IRQHandler
344 PUBWEAK TIM1_CC_IRQHandler
345 SECTION
.text:CODE:REORDER:NOROOT(1)
349 PUBWEAK TIM2_IRQHandler
350 SECTION
.text:CODE:REORDER:NOROOT(1)
354 PUBWEAK TIM3_IRQHandler
355 SECTION
.text:CODE:REORDER:NOROOT(1)
359 PUBWEAK TIM4_IRQHandler
360 SECTION
.text:CODE:REORDER:NOROOT(1)
364 PUBWEAK I2C1_EV_IRQHandler
365 SECTION
.text:CODE:REORDER:NOROOT(1)
369 PUBWEAK I2C1_ER_IRQHandler
370 SECTION
.text:CODE:REORDER:NOROOT(1)
374 PUBWEAK I2C2_EV_IRQHandler
375 SECTION
.text:CODE:REORDER:NOROOT(1)
379 PUBWEAK I2C2_ER_IRQHandler
380 SECTION
.text:CODE:REORDER:NOROOT(1)
384 PUBWEAK SPI1_IRQHandler
385 SECTION
.text:CODE:REORDER:NOROOT(1)
389 PUBWEAK SPI2_IRQHandler
390 SECTION
.text:CODE:REORDER:NOROOT(1)
394 PUBWEAK USART1_IRQHandler
395 SECTION
.text:CODE:REORDER:NOROOT(1)
399 PUBWEAK USART2_IRQHandler
400 SECTION
.text:CODE:REORDER:NOROOT(1)
404 PUBWEAK USART3_IRQHandler
405 SECTION
.text:CODE:REORDER:NOROOT(1)
409 PUBWEAK EXTI15_10_IRQHandler
410 SECTION
.text:CODE:REORDER:NOROOT(1)
412 B EXTI15_10_IRQHandler
414 PUBWEAK RTC_Alarm_IRQHandler
415 SECTION
.text:CODE:REORDER:NOROOT(1)
417 B RTC_Alarm_IRQHandler
419 PUBWEAK USBWakeUp_IRQHandler
420 SECTION
.text:CODE:REORDER:NOROOT(1)
422 B USBWakeUp_IRQHandler
424 PUBWEAK TIM8_BRK_TIM12_IRQHandler
425 SECTION
.text:CODE:REORDER:NOROOT(1)
426 TIM8_BRK_TIM12_IRQHandler
427 B TIM8_BRK_TIM12_IRQHandler
429 PUBWEAK TIM8_UP_TIM13_IRQHandler
430 SECTION
.text:CODE:REORDER:NOROOT(1)
431 TIM8_UP_TIM13_IRQHandler
432 B TIM8_UP_TIM13_IRQHandler
434 PUBWEAK TIM8_TRG_COM_TIM14_IRQHandler
435 SECTION
.text:CODE:REORDER:NOROOT(1)
436 TIM8_TRG_COM_TIM14_IRQHandler
437 B TIM8_TRG_COM_TIM14_IRQHandler
439 PUBWEAK TIM8_CC_IRQHandler
440 SECTION
.text:CODE:REORDER:NOROOT(1)
444 PUBWEAK ADC3_IRQHandler
445 SECTION
.text:CODE:REORDER:NOROOT(1)
449 PUBWEAK FSMC_IRQHandler
450 SECTION
.text:CODE:REORDER:NOROOT(1)
454 PUBWEAK SDIO_IRQHandler
455 SECTION
.text:CODE:REORDER:NOROOT(1)
459 PUBWEAK TIM5_IRQHandler
460 SECTION
.text:CODE:REORDER:NOROOT(1)
464 PUBWEAK SPI3_IRQHandler
465 SECTION
.text:CODE:REORDER:NOROOT(1)
469 PUBWEAK UART4_IRQHandler
470 SECTION
.text:CODE:REORDER:NOROOT(1)
474 PUBWEAK UART5_IRQHandler
475 SECTION
.text:CODE:REORDER:NOROOT(1)
479 PUBWEAK TIM6_IRQHandler
480 SECTION
.text:CODE:REORDER:NOROOT(1)
484 PUBWEAK TIM7_IRQHandler
485 SECTION
.text:CODE:REORDER:NOROOT(1)
489 PUBWEAK DMA2_Channel1_IRQHandler
490 SECTION
.text:CODE:REORDER:NOROOT(1)
491 DMA2_Channel1_IRQHandler
492 B DMA2_Channel1_IRQHandler
494 PUBWEAK DMA2_Channel2_IRQHandler
495 SECTION
.text:CODE:REORDER:NOROOT(1)
496 DMA2_Channel2_IRQHandler
497 B DMA2_Channel2_IRQHandler
499 PUBWEAK DMA2_Channel3_IRQHandler
500 SECTION
.text:CODE:REORDER:NOROOT(1)
501 DMA2_Channel3_IRQHandler
502 B DMA2_Channel3_IRQHandler
504 PUBWEAK DMA2_Channel4_5_IRQHandler
505 SECTION
.text:CODE:REORDER:NOROOT(1)
506 DMA2_Channel4_5_IRQHandler
507 B DMA2_Channel4_5_IRQHandler
512 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/