[STM32F1] :STM32启动件详细解析(V3.5.0) 以:startup_stm32f10x_hd.s为例

[复制链接]
834|0
 楼主| 大苏牙 发表于 2015-9-29 22:20 | 显示全部楼层 |阅读模式


  1. 我用的是IAR,这个貌似是MDK的,不过很有用,大家可以看一下

  2. ;* 文件名          : startup_stm32f10x_hd.s
  3. ;* 库版本           : V3.5.0
  4. ;* 说明:             此文件为STM32F10x高密度设备的MDK工具链的启动文件
  5. ;* 该模块执行以下操作:
  6. ;* -设置初始堆栈指针(SP)
  7. ;* -设置初始程序计数器(PC)为复位向量,并在执行main函数前初始化系统时钟
  8. ;* -设置向量表入口为异常事件的入口地址
  9. ;* -复位之后处理器为线程模式,优先级为特权级,堆栈设置为MSP主堆栈
  10. ;*

  11. Stack_Size      EQU     0x00000200  ;定义堆栈的大小

  12. ;AREA 命令指示汇编器汇编一个新的代码段或数据段。
  13. ;段是独立的、指定的、不可见的代码或数据块,它们由链接器处理.
  14. ;段是独立的、命名的、不可分割的代码或数据序列。一个代码段是生成一个应用程序的最低要求

  15. ;默认情况下,ELF 段在四字节边界上对齐。expression 可以拥有 0 到 31 的任何整数。
  16. ;段在 2expression 字节边界上对齐
  17.                 AREA    STACK, NOINIT, READWRITE, ALIGN=3  ;堆栈段,未初始化,允许读写,8字节边界对齐
  18. ; 说明: Cortex-M3的指令地址要求是字边界对齐(4字节);但是代码段是8字节边界对齐的

  19. Stack_Mem       SPACE   Stack_Size ;分配堆栈空间,把首地址赋给Stack_Mem
  20. __initial_sp ;初始化堆栈指针,指向堆栈顶.

  21. ; 此处有个一个问题讨论,关于栈顶在RAM中所处位置问题,很多初学者一直以为是编译器特意放在HEAP段之后是有意为之,并且认为这样可以利用heap未分配空间来防止未知的栈溢出问题
  22. ; 这种理解是错误的,链接器并不会为栈的位置做特殊的处理,而且这样做也并不会利用heap段,在此文件的最后对堆栈的初始化代码中可以看出他们是两个互相独立的数据区。此处出现的现
  23. ; 象是因为MDK按数据段的字母顺序链接数据段的地址的,所以此处造成了堆的地址在栈的前面的假象,不要窃以为是有某种特殊的约定。
  24.                                                 
  25. ; Heap Configuration
  26. ;     Heap Size (in Bytes) <0x0-0xFFFFFFFF:8>

  27. Heap_Size       EQU     0x00000200  ;定义堆的大小

  28.                 AREA    HEAP, NOINIT, READWRITE, ALIGN=3 ;堆段,未初始化,允许读写,堆数据段8字节边界对齐
  29. __heap_base
  30. Heap_Mem        SPACE   Heap_Size  ;分配堆空间
  31. __heap_limit    ;与__heap_base配合限制堆的大小

  32.                 PRESERVE8  ; 命令指定当前文件保持栈的八字节对齐
  33.                 THUMB      ; 指令集,THUMB 必须位于使用新语法的任何Thumb代码之前

  34. ; EXPORT 命令声明一个符号,可由链接器用于解释各个目标和库文件中的符号引用,相当于声明了一个全局变量。 GLOBAL 于 EXPORT相同。
  35. ; 以下为向量表,在复位时被映射到FLASH的0地址
  36.                 AREA    RESET, DATA, READONLY ;复位段,只包含数据,只读
  37.                 EXPORT  __Vectors             ;标号输出,中断向量表开始
  38.                 EXPORT  __Vectors_End         ;中断向量表结束
  39.                 EXPORT  __Vectors_Size        ;中断向量表大小
  40.                
  41. ; DCD 命令分配一个或多个字的存储器,在四个字节的边界上对齐,并定义存储器的运行时初值。
  42. __Vectors       DCD     __initial_sp               ; Top of Stack 栈顶指针,被放在向量表的开始,FLASH的0地址,复位后首先装载栈顶指针
  43.                 DCD     Reset_Handler              ; Reset Handler 复位异常,装载完栈顶后,第一个执行的,并且不返回。
  44.                 DCD     NMI_Handler                ; NMI Handler    不可屏蔽中断
  45.                 DCD     HardFault_Handler          ; Hard Fault Handler 硬件错误中断
  46.                 DCD     MemManage_Handler          ; MPU Fault Handler 内存管理错误中断
  47.                 DCD     BusFault_Handler           ; Bus Fault Handler  总线错误中断,一般发生在数据访问异常,比如fsmc访问不当
  48.                 DCD     UsageFault_Handler         ; Usage Fault Handler 用法错误中断,一般是预取值,或者位置指令,数据处理等错误
  49.                 DCD     0                          ; Reserved
  50.                 DCD     0                          ; Reserved
  51.                 DCD     0                          ; Reserved
  52.                 DCD     0                          ; Reserved
  53.                 DCD     SVC_Handler                ; SVCall Handler  系统调用异常,主要是为了调用操作系统内核服务
  54.                 DCD     DebugMon_Handler           ; Debug Monitor Handler 调试监视异常
  55.                 DCD     0                          ; Reserved
  56.                 ;DCD     PendSV_Handler             ; PendSV Handler    挂起异常,此处可以看见用作了uCOS-II的上下文切换异常,这是被推荐使用的,因为Cortex-M3会在异常发生时自动保存R0-R3,
  57.                                           ; R12,R13(堆栈指针SP),R14(链接地址,也叫返回地址LR,在异常返回时使用),R15(程序计数器PC,为当前应用程序+4)和中断完成时自动回复,
  58.                                           ;我们只需保存R4-R11,大大减少了中断响应和上下文切换的时间。
  59.           ;说明:此处涉及到一个中断保存寄存器问题:因为在所有的运行模式下,未分组寄存器都指向同一个物理寄存器,他们未被系统用作特殊的用途,因此,在中断或者异常处理进行模式转换
  60.           ;         时,由于不同模式(此处为"线程"和"特权")均使用相同的物理寄存器,可能会造成寄存器中数据的破坏。这也是常说的"关键代码段"和"l临界区"保护的原因。
  61.                 ;DCD     SysTick_Handler            ; SysTick Handler  滴答定时器,为操作系统内核时钟
  62.                 DCD     OS_CPU_PendSVHandler
  63.                 DCD     OS_CPU_SysTickHandler

  64.                 ; External Interrupts                    以下为外部中断向量表
  65.                 DCD     WWDG_IRQHandler            ; Window Watchdog
  66.                 DCD     PVD_IRQHandler             ; PVD through EXTI Line detect
  67.                 DCD     TAMPER_IRQHandler          ; Tamper
  68.                 DCD     RTC_IRQHandler             ; RTC
  69.                 DCD     FLASH_IRQHandler           ; Flash
  70.                 DCD     RCC_IRQHandler             ; RCC
  71.                 DCD     EXTI0_IRQHandler           ; EXTI Line 0
  72.                 DCD     EXTI1_IRQHandler           ; EXTI Line 1
  73.                 DCD     EXTI2_IRQHandler           ; EXTI Line 2
  74.                 DCD     EXTI3_IRQHandler           ; EXTI Line 3
  75.                 DCD     EXTI4_IRQHandler           ; EXTI Line 4
  76.                 DCD     DMA1_Channel1_IRQHandler   ; DMA1 Channel 1
  77.                 DCD     DMA1_Channel2_IRQHandler   ; DMA1 Channel 2
  78.                 DCD     DMA1_Channel3_IRQHandler   ; DMA1 Channel 3
  79.                 DCD     DMA1_Channel4_IRQHandler   ; DMA1 Channel 4
  80.                 DCD     DMA1_Channel5_IRQHandler   ; DMA1 Channel 5
  81.                 DCD     DMA1_Channel6_IRQHandler   ; DMA1 Channel 6
  82.                 DCD     DMA1_Channel7_IRQHandler   ; DMA1 Channel 7
  83.                 DCD     ADC1_2_IRQHandler          ; ADC1 & ADC2
  84.                 DCD     USB_HP_CAN1_TX_IRQHandler  ; USB High Priority or CAN1 TX
  85.                 DCD     USB_LP_CAN1_RX0_IRQHandler ; USB Low  Priority or CAN1 RX0
  86.                 DCD     CAN1_RX1_IRQHandler        ; CAN1 RX1
  87.                 DCD     CAN1_SCE_IRQHandler        ; CAN1 SCE
  88.                 DCD     EXTI9_5_IRQHandler         ; EXTI Line 9..5
  89.                 DCD     TIM1_BRK_IRQHandler        ; TIM1 Break
  90.                 DCD     TIM1_UP_IRQHandler         ; TIM1 Update
  91.                 DCD     TIM1_TRG_COM_IRQHandler    ; TIM1 Trigger and Commutation
  92.                 DCD     TIM1_CC_IRQHandler         ; TIM1 Capture Compare
  93.                 DCD     TIM2_IRQHandler            ; TIM2
  94.                 DCD     TIM3_IRQHandler            ; TIM3
  95.                 DCD     TIM4_IRQHandler            ; TIM4
  96.                 DCD     I2C1_EV_IRQHandler         ; I2C1 Event
  97.                 DCD     I2C1_ER_IRQHandler         ; I2C1 Error
  98.                 DCD     I2C2_EV_IRQHandler         ; I2C2 Event
  99.                 DCD     I2C2_ER_IRQHandler         ; I2C2 Error
  100.                 DCD     SPI1_IRQHandler            ; SPI1
  101.                 DCD     SPI2_IRQHandler            ; SPI2
  102.                 DCD     USART1_IRQHandler          ; USART1
  103.                 DCD     USART2_IRQHandler          ; USART2
  104.                 DCD     USART3_IRQHandler          ; USART3
  105.                 DCD     EXTI15_10_IRQHandler       ; EXTI Line 15..10
  106.                 DCD     RTCAlarm_IRQHandler        ; RTC Alarm through EXTI Line
  107.                 DCD     USBWakeUp_IRQHandler       ; USB Wakeup from suspend
  108.                 DCD     TIM8_BRK_IRQHandler        ; TIM8 Break
  109.                 DCD     TIM8_UP_IRQHandler         ; TIM8 Update
  110.                 DCD     TIM8_TRG_COM_IRQHandler    ; TIM8 Trigger and Commutation
  111.                 DCD     TIM8_CC_IRQHandler         ; TIM8 Capture Compare
  112.                 DCD     ADC3_IRQHandler            ; ADC3
  113.                 DCD     FSMC_IRQHandler            ; FSMC
  114.                 DCD     SDIO_IRQHandler            ; SDIO
  115.                 DCD     TIM5_IRQHandler            ; TIM5
  116.                 DCD     SPI3_IRQHandler            ; SPI3
  117.                 DCD     UART4_IRQHandler           ; UART4
  118.                 DCD     UART5_IRQHandler           ; UART5
  119.                 DCD     TIM6_IRQHandler            ; TIM6
  120.                 DCD     TIM7_IRQHandler            ; TIM7
  121.                 DCD     DMA2_Channel1_IRQHandler   ; DMA2 Channel1
  122.                 DCD     DMA2_Channel2_IRQHandler   ; DMA2 Channel2
  123.                 DCD     DMA2_Channel3_IRQHandler   ; DMA2 Channel3
  124.                 DCD     DMA2_Channel4_5_IRQHandler ; DMA2 Channel4 & Channel5
  125. __Vectors_End   ;向量表结束标志

  126. __Vectors_Size  EQU  __Vectors_End - __Vectors ;计算向量表地址空间大小

  127. ;|.text|  用于表示由 C 编译程序产生的代码段,或用于以某种方式与 C 库关联的代码段。
  128.                 AREA    |.text|, CODE, READONLY   ;定义C编译器源代码的代码段,只读
  129.                
  130. ; Reset handler
  131. Reset_Handler   PROC
  132.                 EXPORT  Reset_Handler             [WEAK]  ;此处[WEAK]表示弱定义,优先执行其他文件的定义
  133.                 IMPORT  __main
  134.                 IMPORT  SystemInit
  135.                 LDR     R0, =SystemInit   ; 装载寄存器指令
  136.                 BLX     R0    ; 带链接的跳转,切换指令集         
  137.                 LDR     R0, =__main
  138.                 BX      R0    ; 切换指令集,main函数不返回
  139.                 ENDP
  140.                
  141. ; Dummy Exception Handlers (infinite loops which can be modified)

  142. NMI_Handler     PROC
  143.                 EXPORT  NMI_Handler                [WEAK]
  144.                 B       .
  145.                 ENDP
  146. HardFault_Handler\
  147.                 PROC
  148.                 EXPORT  HardFault_Handler          [WEAK]
  149.                 B       .
  150.                 ENDP
  151. MemManage_Handler\
  152.                 PROC
  153.                 EXPORT  MemManage_Handler          [WEAK]
  154.                 B       .
  155.                 ENDP
  156. BusFault_Handler\
  157.                 PROC
  158.                 EXPORT  BusFault_Handler           [WEAK]
  159.                 B       .
  160.                 ENDP
  161. UsageFault_Handler\
  162.                 PROC
  163.                 EXPORT  UsageFault_Handler         [WEAK]
  164.                 B       .
  165.                 ENDP
  166. SVC_Handler     PROC
  167.                 EXPORT  SVC_Handler                [WEAK]
  168.                 B       .
  169.                 ENDP
  170. DebugMon_Handler\
  171.                 PROC
  172.                 EXPORT  DebugMon_Handler           [WEAK]
  173.                 B       .
  174.                 ENDP
  175. OS_CPU_PendSVHandler  PROC
  176.                 EXPORT  OS_CPU_PendSVHandler       [WEAK]
  177.                 B       .
  178.                 ENDP
  179. OS_CPU_SysTickHandler PROC
  180.                 EXPORT  OS_CPU_SysTickHandler            [WEAK]
  181.                 B       .
  182.                 ENDP

  183. Default_Handler PROC
  184.                 ; 输出异常向量表标号,方便外部实现异常的具体功能 , [WEAK] 是弱定义的意思,如果外部定义了,优先执行外部定义,否则下面的函数定义
  185.                 EXPORT  WWDG_IRQHandler            [WEAK]
  186.                 EXPORT  PVD_IRQHandler             [WEAK]
  187.                 EXPORT  TAMPER_IRQHandler          [WEAK]
  188.                 EXPORT  RTC_IRQHandler             [WEAK]
  189.                 EXPORT  FLASH_IRQHandler           [WEAK]
  190.                 EXPORT  RCC_IRQHandler             [WEAK]
  191.                 EXPORT  EXTI0_IRQHandler           [WEAK]
  192.                 EXPORT  EXTI1_IRQHandler           [WEAK]
  193.                 EXPORT  EXTI2_IRQHandler           [WEAK]
  194.                 EXPORT  EXTI3_IRQHandler           [WEAK]
  195.                 EXPORT  EXTI4_IRQHandler           [WEAK]
  196.                 EXPORT  DMA1_Channel1_IRQHandler   [WEAK]
  197.                 EXPORT  DMA1_Channel2_IRQHandler   [WEAK]
  198.                 EXPORT  DMA1_Channel3_IRQHandler   [WEAK]
  199.                 EXPORT  DMA1_Channel4_IRQHandler   [WEAK]
  200.                 EXPORT  DMA1_Channel5_IRQHandler   [WEAK]
  201.                 EXPORT  DMA1_Channel6_IRQHandler   [WEAK]
  202.                 EXPORT  DMA1_Channel7_IRQHandler   [WEAK]
  203.                 EXPORT  ADC1_2_IRQHandler          [WEAK]
  204.                 EXPORT  USB_HP_CAN1_TX_IRQHandler  [WEAK]
  205.                 EXPORT  USB_LP_CAN1_RX0_IRQHandler [WEAK]
  206.                 EXPORT  CAN1_RX1_IRQHandler        [WEAK]
  207.                 EXPORT  CAN1_SCE_IRQHandler        [WEAK]
  208.                 EXPORT  EXTI9_5_IRQHandler         [WEAK]
  209.                 EXPORT  TIM1_BRK_IRQHandler        [WEAK]
  210.                 EXPORT  TIM1_UP_IRQHandler         [WEAK]
  211.                 EXPORT  TIM1_TRG_COM_IRQHandler    [WEAK]
  212.                 EXPORT  TIM1_CC_IRQHandler         [WEAK]
  213.                 EXPORT  TIM2_IRQHandler            [WEAK]
  214.                 EXPORT  TIM3_IRQHandler            [WEAK]
  215.                 EXPORT  TIM4_IRQHandler            [WEAK]
  216.                 EXPORT  I2C1_EV_IRQHandler         [WEAK]
  217.                 EXPORT  I2C1_ER_IRQHandler         [WEAK]
  218.                 EXPORT  I2C2_EV_IRQHandler         [WEAK]
  219.                 EXPORT  I2C2_ER_IRQHandler         [WEAK]
  220.                 EXPORT  SPI1_IRQHandler            [WEAK]
  221.                 EXPORT  SPI2_IRQHandler            [WEAK]
  222.                 EXPORT  USART1_IRQHandler          [WEAK]
  223.                 EXPORT  USART2_IRQHandler          [WEAK]
  224.                 EXPORT  USART3_IRQHandler          [WEAK]
  225.                 EXPORT  EXTI15_10_IRQHandler       [WEAK]
  226.                 EXPORT  RTCAlarm_IRQHandler        [WEAK]
  227.                 EXPORT  USBWakeUp_IRQHandler       [WEAK]
  228.                 EXPORT  TIM8_BRK_IRQHandler        [WEAK]
  229.                 EXPORT  TIM8_UP_IRQHandler         [WEAK]
  230.                 EXPORT  TIM8_TRG_COM_IRQHandler    [WEAK]
  231.                 EXPORT  TIM8_CC_IRQHandler         [WEAK]
  232.                 EXPORT  ADC3_IRQHandler            [WEAK]
  233.                 EXPORT  FSMC_IRQHandler            [WEAK]
  234.                 EXPORT  SDIO_IRQHandler            [WEAK]
  235.                 EXPORT  TIM5_IRQHandler            [WEAK]
  236.                 EXPORT  SPI3_IRQHandler            [WEAK]
  237.                 EXPORT  UART4_IRQHandler           [WEAK]
  238.                 EXPORT  UART5_IRQHandler           [WEAK]
  239.                 EXPORT  TIM6_IRQHandler            [WEAK]
  240.                 EXPORT  TIM7_IRQHandler            [WEAK]
  241.                 EXPORT  DMA2_Channel1_IRQHandler   [WEAK]
  242.                 EXPORT  DMA2_Channel2_IRQHandler   [WEAK]
  243.                 EXPORT  DMA2_Channel3_IRQHandler   [WEAK]
  244.                 EXPORT  DMA2_Channel4_5_IRQHandler [WEAK]
  245. ; 如下只是定义一个空函数
  246. WWDG_IRQHandler
  247. PVD_IRQHandler
  248. TAMPER_IRQHandler
  249. RTC_IRQHandler
  250. FLASH_IRQHandler
  251. RCC_IRQHandler
  252. EXTI0_IRQHandler
  253. EXTI1_IRQHandler
  254. EXTI2_IRQHandler
  255. EXTI3_IRQHandler
  256. EXTI4_IRQHandler
  257. DMA1_Channel1_IRQHandler
  258. DMA1_Channel2_IRQHandler
  259. DMA1_Channel3_IRQHandler
  260. DMA1_Channel4_IRQHandler
  261. DMA1_Channel5_IRQHandler
  262. DMA1_Channel6_IRQHandler
  263. DMA1_Channel7_IRQHandler
  264. ADC1_2_IRQHandler
  265. USB_HP_CAN1_TX_IRQHandler
  266. USB_LP_CAN1_RX0_IRQHandler
  267. CAN1_RX1_IRQHandler
  268. CAN1_SCE_IRQHandler
  269. EXTI9_5_IRQHandler
  270. TIM1_BRK_IRQHandler
  271. TIM1_UP_IRQHandler
  272. TIM1_TRG_COM_IRQHandler
  273. TIM1_CC_IRQHandler
  274. TIM2_IRQHandler
  275. TIM3_IRQHandler
  276. TIM4_IRQHandler
  277. I2C1_EV_IRQHandler
  278. I2C1_ER_IRQHandler
  279. I2C2_EV_IRQHandler
  280. I2C2_ER_IRQHandler
  281. SPI1_IRQHandler
  282. SPI2_IRQHandler
  283. USART1_IRQHandler
  284. USART2_IRQHandler
  285. USART3_IRQHandler
  286. EXTI15_10_IRQHandler
  287. RTCAlarm_IRQHandler
  288. USBWakeUp_IRQHandler
  289. TIM8_BRK_IRQHandler
  290. TIM8_UP_IRQHandler
  291. TIM8_TRG_COM_IRQHandler
  292. TIM8_CC_IRQHandler
  293. ADC3_IRQHandler
  294. FSMC_IRQHandler
  295. SDIO_IRQHandler
  296. TIM5_IRQHandler
  297. SPI3_IRQHandler
  298. UART4_IRQHandler
  299. UART5_IRQHandler
  300. TIM6_IRQHandler
  301. TIM7_IRQHandler
  302. DMA2_Channel1_IRQHandler
  303. DMA2_Channel2_IRQHandler
  304. DMA2_Channel3_IRQHandler
  305. DMA2_Channel4_5_IRQHandler
  306.                 B       .

  307.                 ENDP

  308.                 ALIGN ; 默认是字对齐方式,也说明了代码是4字节对齐的

  309. ;*******************************************************************************
  310. ; User Stack and Heap initialization
  311. ;*******************************************************************************
  312.                  IF      :DEF:__MICROLIB ;如果勾选了
  313.                
  314.                  EXPORT  __initial_sp
  315.                  EXPORT  __heap_base
  316.                  EXPORT  __heap_limit
  317.                
  318.                  ELSE
  319.                
  320.                  IMPORT  __use_two_region_memory  ; 两区堆栈空间,堆和栈有各自的空间地址
  321.                  EXPORT  __user_initial_stackheap
  322.                
  323. __user_initial_stackheap
  324. ; 此处是初始化两区的堆栈空间,堆是从由低到高的增长,栈是由高向低生长的,两个是互相独立的数据段,并不能交叉使用。

  325.                  LDR     R0, =  Heap_Mem
  326.                  LDR     R1, = (Stack_Mem + Stack_Size)
  327.                  LDR     R2, = (Heap_Mem +  Heap_Size)
  328.                  LDR     R3, = Stack_Mem
  329.                  BX      LR

  330.                  ALIGN

  331.                  ENDIF

  332.                  END  ; END 命令指示汇编器,已到达一个源文件的末尾。

  333. ;******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE*****


您需要登录后才可以回帖 登录 | 注册

本版积分规则

27

主题

278

帖子

4

粉丝
快速回复 在线客服 返回列表 返回顶部