startup_stm32f10x_hd.s 13.2 KB
Newer Older
1
/**
wuyangyong's avatar
wuyangyong 已提交
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29
  ******************************************************************************
  * @file      startup_stm32f10x_hd.s
  * @author    MCD Application Team
  * @version   V3.1.2
  * @date      09/28/2009
  * @brief     STM32F10x High Density Devices vector table for RIDE7 toolchain. 
  *            This module performs:
  *                - Set the initial SP
  *                - Set the initial PC == Reset_Handler,
  *                - Set the vector table entries with the exceptions ISR address,
  *                - Configure external SRAM mounted on STM3210E-EVAL board
  *                  to be used as data memory (optional, to be enabled by user)
  *                - Branches to main in the C library (which eventually
  *                  calls main()).
  *            After Reset the Cortex-M3 processor is in Thread mode,
  *            priority is Privileged, and the Stack is set to Main.
  ******************************************************************************
  * @copy
  *
  * THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
  * WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
  * TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
  * DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
  * FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
  * CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
  *
  * <h2><center>&copy; COPYRIGHT 2009 STMicroelectronics</center></h2>
  */  
30 31
    
    .syntax unified
wuyangyong's avatar
wuyangyong 已提交
32 33 34
  .cpu cortex-m3
  .fpu softvfp
  .thumb
35

wuyangyong's avatar
wuyangyong 已提交
36 37 38
.global  g_pfnVectors
.global  SystemInit_ExtMemCtl_Dummy
.global  Default_Handler
39 40 41

/* start address for the initialization values of the .data section. 
defined in linker script */
wuyangyong's avatar
wuyangyong 已提交
42
.word  _sidata
43
/* start address for the .data section. defined in linker script */  
wuyangyong's avatar
wuyangyong 已提交
44
.word  _sdata
45
/* end address for the .data section. defined in linker script */
wuyangyong's avatar
wuyangyong 已提交
46
.word  _edata
47
/* start address for the .bss section. defined in linker script */
wuyangyong's avatar
wuyangyong 已提交
48
.word  _sbss
49
/* end address for the .bss section. defined in linker script */
wuyangyong's avatar
wuyangyong 已提交
50
.word  _ebss
51 52 53 54 55 56 57 58 59 60 61 62 63
/* stack used for SystemInit_ExtMemCtl; always internal RAM used */

.equ  Initial_spTop,  0x20000400 
.equ  BootRAM,        0xF1E0F85F
/**
 * @brief  This is the code that gets called when the processor first
 *          starts execution following a reset event. Only the absolutely
 *          necessary set is performed, after which the application
 *          supplied main() routine is called. 
 * @param  None
 * @retval : None
*/

wuyangyong's avatar
wuyangyong 已提交
64 65 66 67
    .section  .text.Reset_Handler
  .weak  Reset_Handler
  .type  Reset_Handler, %function
Reset_Handler:  
68 69 70

/* FSMC Bank1 NOR/SRAM3 is used for the STM3210E-EVAL, if another Bank is 
  required, then adjust the Register Addresses */
wuyangyong's avatar
wuyangyong 已提交
71
  bl  SystemInit_ExtMemCtl
72 73 74 75
/* restore original stack pointer */  
  LDR r0, =_estack
  MSR msp, r0
/* Copy the data segment initializers from flash to SRAM */  
wuyangyong's avatar
wuyangyong 已提交
76 77
  movs  r1, #0
  b  LoopCopyDataInit
78 79

CopyDataInit:
wuyangyong's avatar
wuyangyong 已提交
80 81 82 83
  ldr  r3, =_sidata
  ldr  r3, [r3, r1]
  str  r3, [r0, r1]
  adds  r1, r1, #4
84 85
    
LoopCopyDataInit:
wuyangyong's avatar
wuyangyong 已提交
86 87 88 89 90 91 92
  ldr  r0, =_sdata
  ldr  r3, =_edata
  adds  r2, r0, r1
  cmp  r2, r3
  bcc  CopyDataInit
  ldr  r2, =_sbss
  b  LoopFillZerobss
93 94
/* Zero fill the bss segment. */  
FillZerobss:
wuyangyong's avatar
wuyangyong 已提交
95 96
  movs  r3, #0
  str  r3, [r2], #4
97 98
    
LoopFillZerobss:
wuyangyong's avatar
wuyangyong 已提交
99 100 101
  ldr  r3, = _ebss
  cmp  r2, r3
  bcc  FillZerobss
102
/* Call the application's entry point.*/
wuyangyong's avatar
wuyangyong 已提交
103 104 105
  bl  main
  bx  lr    
.size  Reset_Handler, .-Reset_Handler
106 107 108 109 110 111

/**
 * @brief  Dummy SystemInit_ExtMemCtl function 
 * @param  None     
 * @retval : None       
*/
wuyangyong's avatar
wuyangyong 已提交
112
  .section  .text.SystemInit_ExtMemCtl_Dummy,"ax",%progbits
113
SystemInit_ExtMemCtl_Dummy:
wuyangyong's avatar
wuyangyong 已提交
114 115
  bx  lr
  .size  SystemInit_ExtMemCtl_Dummy, .-SystemInit_ExtMemCtl_Dummy
116 117 118 119 120 121 122 123 124

/**
 * @brief  This is the code that gets called when the processor receives an 
 *         unexpected interrupt.  This simply enters an infinite loop, preserving
 *         the system state for examination by a debugger.
 *
 * @param  None     
 * @retval : None       
*/
wuyangyong's avatar
wuyangyong 已提交
125
    .section  .text.Default_Handler,"ax",%progbits
126 127
Default_Handler:
Infinite_Loop:
wuyangyong's avatar
wuyangyong 已提交
128 129
  b  Infinite_Loop
  .size  Default_Handler, .-Default_Handler
130 131 132 133 134 135 136
/******************************************************************************
*
* The minimal vector table for a Cortex M3.  Note that the proper constructs
* must be placed on this to ensure that it ends up at physical address
* 0x0000.0000.
*
******************************************************************************/    
wuyangyong's avatar
wuyangyong 已提交
137 138 139
   .section  .isr_vector,"a",%progbits
  .type  g_pfnVectors, %object
  .size  g_pfnVectors, .-g_pfnVectors
140 141 142
    
    
g_pfnVectors:
wuyangyong's avatar
wuyangyong 已提交
143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263
  .word  Initial_spTop
  .word  Reset_Handler
  .word  NMI_Handler
  .word  HardFault_Handler
  .word  MemManage_Handler
  .word  BusFault_Handler
  .word  UsageFault_Handler
  .word  0
  .word  0
  .word  0
  .word  0
  .word  SVC_Handler
  .word  DebugMon_Handler
  .word  0
  .word  PendSV_Handler
  .word  SysTick_Handler
  .word  WWDG_IRQHandler
  .word  PVD_IRQHandler
  .word  TAMPER_IRQHandler
  .word  RTC_IRQHandler
  .word  FLASH_IRQHandler
  .word  RCC_IRQHandler
  .word  EXTI0_IRQHandler
  .word  EXTI1_IRQHandler
  .word  EXTI2_IRQHandler
  .word  EXTI3_IRQHandler
  .word  EXTI4_IRQHandler
  .word  DMA1_Channel1_IRQHandler
  .word  DMA1_Channel2_IRQHandler
  .word  DMA1_Channel3_IRQHandler
  .word  DMA1_Channel4_IRQHandler
  .word  DMA1_Channel5_IRQHandler
  .word  DMA1_Channel6_IRQHandler
  .word  DMA1_Channel7_IRQHandler
  .word  ADC1_2_IRQHandler
  .word  USB_HP_CAN1_TX_IRQHandler
  .word  USB_LP_CAN1_RX0_IRQHandler
  .word  CAN1_RX1_IRQHandler
  .word  CAN1_SCE_IRQHandler
  .word  EXTI9_5_IRQHandler
  .word  TIM1_BRK_IRQHandler
  .word  TIM1_UP_IRQHandler
  .word  TIM1_TRG_COM_IRQHandler
  .word  TIM1_CC_IRQHandler
  .word  TIM2_IRQHandler
  .word  TIM3_IRQHandler
  .word  TIM4_IRQHandler
  .word  I2C1_EV_IRQHandler
  .word  I2C1_ER_IRQHandler
  .word  I2C2_EV_IRQHandler
  .word  I2C2_ER_IRQHandler
  .word  SPI1_IRQHandler
  .word  SPI2_IRQHandler
  .word  USART1_IRQHandler
  .word  USART2_IRQHandler
  .word  USART3_IRQHandler
  .word  EXTI15_10_IRQHandler
  .word  RTCAlarm_IRQHandler
  .word  USBWakeUp_IRQHandler
  .word  TIM8_BRK_IRQHandler
  .word  TIM8_UP_IRQHandler
  .word  TIM8_TRG_COM_IRQHandler
  .word  TIM8_CC_IRQHandler
  .word  ADC3_IRQHandler
  .word  FSMC_IRQHandler
  .word  SDIO_IRQHandler
  .word  TIM5_IRQHandler
  .word  SPI3_IRQHandler
  .word  UART4_IRQHandler
  .word  UART5_IRQHandler
  .word  TIM6_IRQHandler
  .word  TIM7_IRQHandler
  .word  DMA2_Channel1_IRQHandler
  .word  DMA2_Channel2_IRQHandler
  .word  DMA2_Channel3_IRQHandler
  .word  DMA2_Channel4_5_IRQHandler
  .word  0
  .word  0
  .word  0
  .word  0
  .word  0
  .word  0
  .word  0
  .word  0
  .word  0
  .word  0
  .word  0
  .word  0
  .word  0
  .word  0
  .word  0
  .word  0
  .word  0
  .word  0
  .word  0
  .word  0
  .word  0
  .word  0
  .word  0
  .word  0
  .word  0
  .word  0
  .word  0
  .word  0
  .word  0
  .word  0
  .word  0
  .word  0
  .word  0
  .word  0
  .word  0
  .word  0
  .word  0
  .word  0
  .word  0
  .word  0
  .word  0
  .word  0
  .word  0
  .word  0
  .word  BootRAM       /* @0x1E0. This is for boot in RAM mode for 
264 265 266 267 268 269 270 271 272 273
                         STM32F10x High Density devices. */
   
/*******************************************************************************
*
* Provide weak aliases for each Exception handler to the Default_Handler. 
* As they are weak aliases, any function with the same name will override 
* this definition.
*
*******************************************************************************/
    
wuyangyong's avatar
wuyangyong 已提交
274 275 276 277 278 279 280 281 282 283 284
  .weak  NMI_Handler
  .thumb_set NMI_Handler,Default_Handler
  
  .weak  HardFault_Handler
  .thumb_set HardFault_Handler,Default_Handler
  
  .weak  MemManage_Handler
  .thumb_set MemManage_Handler,Default_Handler
  
  .weak  BusFault_Handler
  .thumb_set BusFault_Handler,Default_Handler
285

wuyangyong's avatar
wuyangyong 已提交
286 287
  .weak  UsageFault_Handler
  .thumb_set UsageFault_Handler,Default_Handler
288

wuyangyong's avatar
wuyangyong 已提交
289 290
  .weak  SVC_Handler
  .thumb_set SVC_Handler,Default_Handler
291

wuyangyong's avatar
wuyangyong 已提交
292 293
  .weak  DebugMon_Handler
  .thumb_set DebugMon_Handler,Default_Handler
294

wuyangyong's avatar
wuyangyong 已提交
295 296
  .weak  PendSV_Handler
  .thumb_set PendSV_Handler,Default_Handler
297

wuyangyong's avatar
wuyangyong 已提交
298 299
  .weak  SysTick_Handler
  .thumb_set SysTick_Handler,Default_Handler
300

wuyangyong's avatar
wuyangyong 已提交
301 302
  .weak  WWDG_IRQHandler
  .thumb_set WWDG_IRQHandler,Default_Handler
303

wuyangyong's avatar
wuyangyong 已提交
304 305
  .weak  PVD_IRQHandler
  .thumb_set PVD_IRQHandler,Default_Handler
306

wuyangyong's avatar
wuyangyong 已提交
307 308
  .weak  TAMPER_IRQHandler
  .thumb_set TAMPER_IRQHandler,Default_Handler
309

wuyangyong's avatar
wuyangyong 已提交
310 311
  .weak  RTC_IRQHandler
  .thumb_set RTC_IRQHandler,Default_Handler
312

wuyangyong's avatar
wuyangyong 已提交
313 314
  .weak  FLASH_IRQHandler
  .thumb_set FLASH_IRQHandler,Default_Handler
315

wuyangyong's avatar
wuyangyong 已提交
316 317
  .weak  RCC_IRQHandler
  .thumb_set RCC_IRQHandler,Default_Handler
318

wuyangyong's avatar
wuyangyong 已提交
319 320
  .weak  EXTI0_IRQHandler
  .thumb_set EXTI0_IRQHandler,Default_Handler
321

wuyangyong's avatar
wuyangyong 已提交
322 323
  .weak  EXTI1_IRQHandler
  .thumb_set EXTI1_IRQHandler,Default_Handler
324

wuyangyong's avatar
wuyangyong 已提交
325 326
  .weak  EXTI2_IRQHandler
  .thumb_set EXTI2_IRQHandler,Default_Handler
327

wuyangyong's avatar
wuyangyong 已提交
328 329
  .weak  EXTI3_IRQHandler
  .thumb_set EXTI3_IRQHandler,Default_Handler
330

wuyangyong's avatar
wuyangyong 已提交
331 332
  .weak  EXTI4_IRQHandler
  .thumb_set EXTI4_IRQHandler,Default_Handler
333

wuyangyong's avatar
wuyangyong 已提交
334 335
  .weak  DMA1_Channel1_IRQHandler
  .thumb_set DMA1_Channel1_IRQHandler,Default_Handler
336

wuyangyong's avatar
wuyangyong 已提交
337 338
  .weak  DMA1_Channel2_IRQHandler
  .thumb_set DMA1_Channel2_IRQHandler,Default_Handler
339

wuyangyong's avatar
wuyangyong 已提交
340 341
  .weak  DMA1_Channel3_IRQHandler
  .thumb_set DMA1_Channel3_IRQHandler,Default_Handler
342

wuyangyong's avatar
wuyangyong 已提交
343 344
  .weak  DMA1_Channel4_IRQHandler
  .thumb_set DMA1_Channel4_IRQHandler,Default_Handler
345

wuyangyong's avatar
wuyangyong 已提交
346 347
  .weak  DMA1_Channel5_IRQHandler
  .thumb_set DMA1_Channel5_IRQHandler,Default_Handler
348

wuyangyong's avatar
wuyangyong 已提交
349 350
  .weak  DMA1_Channel6_IRQHandler
  .thumb_set DMA1_Channel6_IRQHandler,Default_Handler
351

wuyangyong's avatar
wuyangyong 已提交
352 353
  .weak  DMA1_Channel7_IRQHandler
  .thumb_set DMA1_Channel7_IRQHandler,Default_Handler
354

wuyangyong's avatar
wuyangyong 已提交
355 356
  .weak  ADC1_2_IRQHandler
  .thumb_set ADC1_2_IRQHandler,Default_Handler
357

wuyangyong's avatar
wuyangyong 已提交
358 359
  .weak  USB_HP_CAN1_TX_IRQHandler
  .thumb_set USB_HP_CAN1_TX_IRQHandler,Default_Handler
360

wuyangyong's avatar
wuyangyong 已提交
361 362
  .weak  USB_LP_CAN1_RX0_IRQHandler
  .thumb_set USB_LP_CAN1_RX0_IRQHandler,Default_Handler
363

wuyangyong's avatar
wuyangyong 已提交
364 365
  .weak  CAN1_RX1_IRQHandler
  .thumb_set CAN1_RX1_IRQHandler,Default_Handler
366

wuyangyong's avatar
wuyangyong 已提交
367 368
  .weak  CAN1_SCE_IRQHandler
  .thumb_set CAN1_SCE_IRQHandler,Default_Handler
369

wuyangyong's avatar
wuyangyong 已提交
370 371
  .weak  EXTI9_5_IRQHandler
  .thumb_set EXTI9_5_IRQHandler,Default_Handler
372

wuyangyong's avatar
wuyangyong 已提交
373 374
  .weak  TIM1_BRK_IRQHandler
  .thumb_set TIM1_BRK_IRQHandler,Default_Handler
375

wuyangyong's avatar
wuyangyong 已提交
376 377
  .weak  TIM1_UP_IRQHandler
  .thumb_set TIM1_UP_IRQHandler,Default_Handler
378

wuyangyong's avatar
wuyangyong 已提交
379 380
  .weak  TIM1_TRG_COM_IRQHandler
  .thumb_set TIM1_TRG_COM_IRQHandler,Default_Handler
381

wuyangyong's avatar
wuyangyong 已提交
382 383
  .weak  TIM1_CC_IRQHandler
  .thumb_set TIM1_CC_IRQHandler,Default_Handler
384

wuyangyong's avatar
wuyangyong 已提交
385 386
  .weak  TIM2_IRQHandler
  .thumb_set TIM2_IRQHandler,Default_Handler
387

wuyangyong's avatar
wuyangyong 已提交
388 389
  .weak  TIM3_IRQHandler
  .thumb_set TIM3_IRQHandler,Default_Handler
390

wuyangyong's avatar
wuyangyong 已提交
391 392
  .weak  TIM4_IRQHandler
  .thumb_set TIM4_IRQHandler,Default_Handler
393

wuyangyong's avatar
wuyangyong 已提交
394 395
  .weak  I2C1_EV_IRQHandler
  .thumb_set I2C1_EV_IRQHandler,Default_Handler
396

wuyangyong's avatar
wuyangyong 已提交
397 398
  .weak  I2C1_ER_IRQHandler
  .thumb_set I2C1_ER_IRQHandler,Default_Handler
399

wuyangyong's avatar
wuyangyong 已提交
400 401
  .weak  I2C2_EV_IRQHandler
  .thumb_set I2C2_EV_IRQHandler,Default_Handler
402

wuyangyong's avatar
wuyangyong 已提交
403 404
  .weak  I2C2_ER_IRQHandler
  .thumb_set I2C2_ER_IRQHandler,Default_Handler
405

wuyangyong's avatar
wuyangyong 已提交
406 407
  .weak  SPI1_IRQHandler
  .thumb_set SPI1_IRQHandler,Default_Handler
408

wuyangyong's avatar
wuyangyong 已提交
409 410
  .weak  SPI2_IRQHandler
  .thumb_set SPI2_IRQHandler,Default_Handler
411

wuyangyong's avatar
wuyangyong 已提交
412 413
  .weak  USART1_IRQHandler
  .thumb_set USART1_IRQHandler,Default_Handler
414

wuyangyong's avatar
wuyangyong 已提交
415 416
  .weak  USART2_IRQHandler
  .thumb_set USART2_IRQHandler,Default_Handler
417

wuyangyong's avatar
wuyangyong 已提交
418 419
  .weak  USART3_IRQHandler
  .thumb_set USART3_IRQHandler,Default_Handler
420

wuyangyong's avatar
wuyangyong 已提交
421 422
  .weak  EXTI15_10_IRQHandler
  .thumb_set EXTI15_10_IRQHandler,Default_Handler
423

wuyangyong's avatar
wuyangyong 已提交
424 425
  .weak  RTCAlarm_IRQHandler
  .thumb_set RTCAlarm_IRQHandler,Default_Handler
426

wuyangyong's avatar
wuyangyong 已提交
427 428
  .weak  USBWakeUp_IRQHandler
  .thumb_set USBWakeUp_IRQHandler,Default_Handler
429

wuyangyong's avatar
wuyangyong 已提交
430 431
  .weak  TIM8_BRK_IRQHandler
  .thumb_set TIM8_BRK_IRQHandler,Default_Handler
432

wuyangyong's avatar
wuyangyong 已提交
433 434
  .weak  TIM8_UP_IRQHandler
  .thumb_set TIM8_UP_IRQHandler,Default_Handler
435

wuyangyong's avatar
wuyangyong 已提交
436 437
  .weak  TIM8_TRG_COM_IRQHandler
  .thumb_set TIM8_TRG_COM_IRQHandler,Default_Handler
438

wuyangyong's avatar
wuyangyong 已提交
439 440
  .weak  TIM8_CC_IRQHandler
  .thumb_set TIM8_CC_IRQHandler,Default_Handler
441

wuyangyong's avatar
wuyangyong 已提交
442 443
  .weak  ADC3_IRQHandler
  .thumb_set ADC3_IRQHandler,Default_Handler
444

wuyangyong's avatar
wuyangyong 已提交
445 446
  .weak  FSMC_IRQHandler
  .thumb_set FSMC_IRQHandler,Default_Handler
447

wuyangyong's avatar
wuyangyong 已提交
448 449
  .weak  SDIO_IRQHandler
  .thumb_set SDIO_IRQHandler,Default_Handler
450

wuyangyong's avatar
wuyangyong 已提交
451 452
  .weak  TIM5_IRQHandler
  .thumb_set TIM5_IRQHandler,Default_Handler
453

wuyangyong's avatar
wuyangyong 已提交
454 455
  .weak  SPI3_IRQHandler
  .thumb_set SPI3_IRQHandler,Default_Handler
456

wuyangyong's avatar
wuyangyong 已提交
457 458
  .weak  UART4_IRQHandler
  .thumb_set UART4_IRQHandler,Default_Handler
459

wuyangyong's avatar
wuyangyong 已提交
460 461
  .weak  UART5_IRQHandler
  .thumb_set UART5_IRQHandler,Default_Handler
462

wuyangyong's avatar
wuyangyong 已提交
463 464
  .weak  TIM6_IRQHandler
  .thumb_set TIM6_IRQHandler,Default_Handler
465

wuyangyong's avatar
wuyangyong 已提交
466 467
  .weak  TIM7_IRQHandler
  .thumb_set TIM7_IRQHandler,Default_Handler
468

wuyangyong's avatar
wuyangyong 已提交
469 470
  .weak  DMA2_Channel1_IRQHandler
  .thumb_set DMA2_Channel1_IRQHandler,Default_Handler
471

wuyangyong's avatar
wuyangyong 已提交
472 473
  .weak  DMA2_Channel2_IRQHandler
  .thumb_set DMA2_Channel2_IRQHandler,Default_Handler
474

wuyangyong's avatar
wuyangyong 已提交
475 476
  .weak  DMA2_Channel3_IRQHandler
  .thumb_set DMA2_Channel3_IRQHandler,Default_Handler
477

wuyangyong's avatar
wuyangyong 已提交
478 479
  .weak  DMA2_Channel4_5_IRQHandler
  .thumb_set DMA2_Channel4_5_IRQHandler,Default_Handler
480

wuyangyong's avatar
wuyangyong 已提交
481 482
  .weak  SystemInit_ExtMemCtl
  .thumb_set SystemInit_ExtMemCtl,SystemInit_ExtMemCtl_Dummy
483