Subversion Repositories DashDisplay

Rev

Go to most recent revision | Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
2 mjames 1
;******************** (C) COPYRIGHT 2015 STMicroelectronics ********************
2
;* File Name          : startup_stm32f100xb.s
3
;* Author             : MCD Application Team
4
;* Version            : V4.0.1
5
;* Date               : 31-July-2015
6
;* Description        : STM32F100xB Devices vector table for MDK-ARM toolchain. 
7
;*                      This module performs:
8
;*                      - Set the initial SP
9
;*                      - Set the initial PC == Reset_Handler
10
;*                      - Set the vector table entries with the exceptions ISR address
11
;*                      - Configure the clock system
12
;*                      - Branches to __main in the C library (which eventually
13
;*                        calls main()).
14
;*                      After Reset the Cortex-M3 processor is in Thread mode,
15
;*                      priority is Privileged, and the Stack is set to Main.
16
;********************************************************************************
17
;*
18
;* COPYRIGHT(c) 2015 STMicroelectronics
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
; Amount of memory (in bytes) allocated for Stack
45
; Tailor this value to your application needs
46
; <h> Stack Configuration
47
;   <o> Stack Size (in Bytes) <0x0-0xFFFFFFFF:8>
48
; </h>
49
 
50
Stack_Size      EQU     0x00000400
51
 
52
                AREA    STACK, NOINIT, READWRITE, ALIGN=3
53
Stack_Mem       SPACE   Stack_Size
54
__initial_sp
55
 
56
 
57
; <h> Heap Configuration
58
;   <o>  Heap Size (in Bytes) <0x0-0xFFFFFFFF:8>
59
; </h>
60
 
61
Heap_Size       EQU     0x00000200
62
 
63
                AREA    HEAP, NOINIT, READWRITE, ALIGN=3
64
__heap_base
65
Heap_Mem        SPACE   Heap_Size
66
__heap_limit
67
 
68
                PRESERVE8
69
                THUMB
70
 
71
 
72
; Vector Table Mapped to Address 0 at Reset
73
                AREA    RESET, DATA, READONLY
74
                EXPORT  __Vectors
75
                EXPORT  __Vectors_End
76
                EXPORT  __Vectors_Size
77
 
78
__Vectors       DCD     __initial_sp                    ; Top of Stack
79
                DCD     Reset_Handler                   ; Reset Handler
80
                DCD     NMI_Handler                     ; NMI Handler
81
                DCD     HardFault_Handler               ; Hard Fault Handler
82
                DCD     MemManage_Handler               ; MPU Fault Handler
83
                DCD     BusFault_Handler                ; Bus Fault Handler
84
                DCD     UsageFault_Handler              ; Usage Fault Handler
85
                DCD     0                               ; Reserved
86
                DCD     0                               ; Reserved
87
                DCD     0                               ; Reserved
88
                DCD     0                               ; Reserved
89
                DCD     SVC_Handler                     ; SVCall Handler
90
                DCD     DebugMon_Handler                ; Debug Monitor Handler
91
                DCD     0                               ; Reserved
92
                DCD     PendSV_Handler                  ; PendSV Handler
93
                DCD     SysTick_Handler                 ; SysTick Handler
94
 
95
                ; External Interrupts
96
                DCD     WWDG_IRQHandler                 ; Window Watchdog
97
                DCD     PVD_IRQHandler                  ; PVD through EXTI Line detect
98
                DCD     TAMPER_IRQHandler               ; Tamper
99
                DCD     RTC_IRQHandler                  ; RTC
100
                DCD     FLASH_IRQHandler                ; Flash
101
                DCD     RCC_IRQHandler                  ; RCC
102
                DCD     EXTI0_IRQHandler                ; EXTI Line 0
103
                DCD     EXTI1_IRQHandler                ; EXTI Line 1
104
                DCD     EXTI2_IRQHandler                ; EXTI Line 2
105
                DCD     EXTI3_IRQHandler                ; EXTI Line 3
106
                DCD     EXTI4_IRQHandler                ; EXTI Line 4
107
                DCD     DMA1_Channel1_IRQHandler        ; DMA1 Channel 1
108
                DCD     DMA1_Channel2_IRQHandler        ; DMA1 Channel 2
109
                DCD     DMA1_Channel3_IRQHandler        ; DMA1 Channel 3
110
                DCD     DMA1_Channel4_IRQHandler        ; DMA1 Channel 4
111
                DCD     DMA1_Channel5_IRQHandler        ; DMA1 Channel 5
112
                DCD     DMA1_Channel6_IRQHandler        ; DMA1 Channel 6
113
                DCD     DMA1_Channel7_IRQHandler        ; DMA1 Channel 7
114
                DCD     ADC1_IRQHandler                 ; ADC1
115
                DCD     0                               ; Reserved
116
                DCD     0                               ; Reserved
117
                DCD     0                               ; Reserved
118
                DCD     0                               ; Reserved
119
                DCD     EXTI9_5_IRQHandler              ; EXTI Line 9..5
120
                DCD     TIM1_BRK_TIM15_IRQHandler       ; TIM1 Break and TIM15
121
                DCD     TIM1_UP_TIM16_IRQHandler        ; TIM1 Update and TIM16
122
                DCD     TIM1_TRG_COM_TIM17_IRQHandler   ; TIM1 Trigger and Commutation and TIM17
123
                DCD     TIM1_CC_IRQHandler              ; TIM1 Capture Compare
124
                DCD     TIM2_IRQHandler                 ; TIM2
125
                DCD     TIM3_IRQHandler                 ; TIM3
126
                DCD     TIM4_IRQHandler                 ; TIM4
127
                DCD     I2C1_EV_IRQHandler              ; I2C1 Event
128
                DCD     I2C1_ER_IRQHandler              ; I2C1 Error
129
                DCD     I2C2_EV_IRQHandler              ; I2C2 Event
130
                DCD     I2C2_ER_IRQHandler              ; I2C2 Error
131
                DCD     SPI1_IRQHandler                 ; SPI1
132
                DCD     SPI2_IRQHandler                 ; SPI2
133
                DCD     USART1_IRQHandler               ; USART1
134
                DCD     USART2_IRQHandler               ; USART2
135
                DCD     USART3_IRQHandler               ; USART3
136
                DCD     EXTI15_10_IRQHandler            ; EXTI Line 15..10
137
                DCD     RTC_Alarm_IRQHandler             ; RTC Alarm through EXTI Line
138
                DCD     CEC_IRQHandler                  ; HDMI-CEC
139
                DCD     0                               ; Reserved
140
                DCD     0                               ; Reserved
141
                DCD     0                               ; Reserved
142
                DCD     0                               ; Reserved 
143
                DCD     0                               ; Reserved
144
                DCD     0                               ; Reserved
145
                DCD     0                               ; Reserved
146
                DCD     0                               ; Reserved 
147
                DCD     0                               ; Reserved
148
                DCD     0                               ; Reserved
149
                DCD     0                               ; Reserved
150
                DCD     TIM6_DAC_IRQHandler             ; TIM6 and DAC underrun
151
                DCD     TIM7_IRQHandler                 ; TIM7
152
__Vectors_End
153
 
154
__Vectors_Size  EQU  __Vectors_End - __Vectors
155
 
156
                AREA    |.text|, CODE, READONLY
157
 
158
; Reset handler
159
Reset_Handler    PROC
160
                 EXPORT  Reset_Handler             [WEAK]
161
     IMPORT  __main
162
     IMPORT  SystemInit
163
                 LDR     R0, =SystemInit
164
                 BLX     R0
165
                 LDR     R0, =__main
166
                 BX      R0
167
                 ENDP
168
 
169
; Dummy Exception Handlers (infinite loops which can be modified)
170
 
171
NMI_Handler     PROC
172
                EXPORT  NMI_Handler                      [WEAK]
173
                B       .
174
                ENDP
175
HardFault_Handler\
176
                PROC
177
                EXPORT  HardFault_Handler                [WEAK]
178
                B       .
179
                ENDP
180
MemManage_Handler\
181
                PROC
182
                EXPORT  MemManage_Handler                [WEAK]
183
                B       .
184
                ENDP
185
BusFault_Handler\
186
                PROC
187
                EXPORT  BusFault_Handler                 [WEAK]
188
                B       .
189
                ENDP
190
UsageFault_Handler\
191
                PROC
192
                EXPORT  UsageFault_Handler               [WEAK]
193
                B       .
194
                ENDP
195
SVC_Handler     PROC
196
                EXPORT  SVC_Handler                      [WEAK]
197
                B       .
198
                ENDP
199
DebugMon_Handler\
200
                PROC
201
                EXPORT  DebugMon_Handler                 [WEAK]
202
                B       .
203
                ENDP
204
PendSV_Handler  PROC
205
                EXPORT  PendSV_Handler                   [WEAK]
206
                B       .
207
                ENDP
208
SysTick_Handler PROC
209
                EXPORT  SysTick_Handler                  [WEAK]
210
                B       .
211
                ENDP
212
 
213
Default_Handler PROC
214
 
215
                EXPORT  WWDG_IRQHandler                  [WEAK]
216
                EXPORT  PVD_IRQHandler                   [WEAK]
217
                EXPORT  TAMPER_IRQHandler                [WEAK]
218
                EXPORT  RTC_IRQHandler                   [WEAK]
219
                EXPORT  FLASH_IRQHandler                 [WEAK]
220
                EXPORT  RCC_IRQHandler                   [WEAK]
221
                EXPORT  EXTI0_IRQHandler                 [WEAK]
222
                EXPORT  EXTI1_IRQHandler                 [WEAK]
223
                EXPORT  EXTI2_IRQHandler                 [WEAK]
224
                EXPORT  EXTI3_IRQHandler                 [WEAK]
225
                EXPORT  EXTI4_IRQHandler                 [WEAK]
226
                EXPORT  DMA1_Channel1_IRQHandler         [WEAK]
227
                EXPORT  DMA1_Channel2_IRQHandler         [WEAK]
228
                EXPORT  DMA1_Channel3_IRQHandler         [WEAK]
229
                EXPORT  DMA1_Channel4_IRQHandler         [WEAK]
230
                EXPORT  DMA1_Channel5_IRQHandler         [WEAK]
231
                EXPORT  DMA1_Channel6_IRQHandler         [WEAK]
232
                EXPORT  DMA1_Channel7_IRQHandler         [WEAK]
233
                EXPORT  ADC1_IRQHandler                  [WEAK]
234
                EXPORT  EXTI9_5_IRQHandler               [WEAK]
235
                EXPORT  TIM1_BRK_TIM15_IRQHandler        [WEAK]
236
                EXPORT  TIM1_UP_TIM16_IRQHandler         [WEAK]
237
                EXPORT  TIM1_TRG_COM_TIM17_IRQHandler    [WEAK]
238
                EXPORT  TIM1_CC_IRQHandler               [WEAK]
239
                EXPORT  TIM2_IRQHandler                  [WEAK]
240
                EXPORT  TIM3_IRQHandler                  [WEAK]
241
                EXPORT  TIM4_IRQHandler                  [WEAK]
242
                EXPORT  I2C1_EV_IRQHandler               [WEAK]
243
                EXPORT  I2C1_ER_IRQHandler               [WEAK]
244
                EXPORT  I2C2_EV_IRQHandler               [WEAK]
245
                EXPORT  I2C2_ER_IRQHandler               [WEAK]
246
                EXPORT  SPI1_IRQHandler                  [WEAK]
247
                EXPORT  SPI2_IRQHandler                  [WEAK]
248
                EXPORT  USART1_IRQHandler                [WEAK]
249
                EXPORT  USART2_IRQHandler                [WEAK]
250
                EXPORT  USART3_IRQHandler                [WEAK]
251
                EXPORT  EXTI15_10_IRQHandler             [WEAK]
252
                EXPORT  RTC_Alarm_IRQHandler              [WEAK]
253
                EXPORT  CEC_IRQHandler                   [WEAK]
254
                EXPORT  TIM6_DAC_IRQHandler              [WEAK]
255
                EXPORT  TIM7_IRQHandler                  [WEAK]
256
 
257
WWDG_IRQHandler
258
PVD_IRQHandler
259
TAMPER_IRQHandler
260
RTC_IRQHandler
261
FLASH_IRQHandler
262
RCC_IRQHandler
263
EXTI0_IRQHandler
264
EXTI1_IRQHandler
265
EXTI2_IRQHandler
266
EXTI3_IRQHandler
267
EXTI4_IRQHandler
268
DMA1_Channel1_IRQHandler
269
DMA1_Channel2_IRQHandler
270
DMA1_Channel3_IRQHandler
271
DMA1_Channel4_IRQHandler
272
DMA1_Channel5_IRQHandler
273
DMA1_Channel6_IRQHandler
274
DMA1_Channel7_IRQHandler
275
ADC1_IRQHandler
276
EXTI9_5_IRQHandler
277
TIM1_BRK_TIM15_IRQHandler
278
TIM1_UP_TIM16_IRQHandler
279
TIM1_TRG_COM_TIM17_IRQHandler
280
TIM1_CC_IRQHandler
281
TIM2_IRQHandler
282
TIM3_IRQHandler
283
TIM4_IRQHandler
284
I2C1_EV_IRQHandler
285
I2C1_ER_IRQHandler
286
I2C2_EV_IRQHandler
287
I2C2_ER_IRQHandler
288
SPI1_IRQHandler
289
SPI2_IRQHandler
290
USART1_IRQHandler
291
USART2_IRQHandler
292
USART3_IRQHandler
293
EXTI15_10_IRQHandler
294
RTC_Alarm_IRQHandler
295
CEC_IRQHandler
296
TIM6_DAC_IRQHandler
297
TIM7_IRQHandler
298
                B       .
299
 
300
                ENDP
301
 
302
                ALIGN
303
 
304
;*******************************************************************************
305
; User Stack and Heap initialization
306
;*******************************************************************************
307
                 IF      :DEF:__MICROLIB           
308
 
309
                 EXPORT  __initial_sp
310
                 EXPORT  __heap_base
311
                 EXPORT  __heap_limit
312
 
313
                 ELSE
314
 
315
                 IMPORT  __use_two_region_memory
316
                 EXPORT  __user_initial_stackheap
317
 
318
__user_initial_stackheap
319
 
320
                 LDR     R0, =  Heap_Mem
321
                 LDR     R1, =(Stack_Mem + Stack_Size)
322
                 LDR     R2, = (Heap_Mem +  Heap_Size)
323
                 LDR     R3, = Stack_Mem
324
                 BX      LR
325
 
326
                 ALIGN
327
 
328
                 ENDIF
329
 
330
                 END
331
 
332
;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE*****