[技术问答] MCU在运行到main()之前都干了什么

[复制链接]
4679|34
 楼主| energyplants 发表于 2016-1-11 20:02 | 显示全部楼层 |阅读模式
很多ARM工程师想当然的以为,自己开发的应用程序,用AK100Pro仿真器下载进入调试,MCU的PC指针必定停留在main()函数的入口。但实际上,在运行到main()前,MCU还做了很多事情。这里以一个LPC1700的Keil工程为例说明。

  MCU上电复位后,通常会从一个固定的地址开始启动,比如ARM7复位后的入口地址为0x00000000;或者类似Cortex-M内核从中断向量表中取出入口地址,中断向量表的地址必须是固定的。

  LPC1700为Cortex-M3内核,所以启动时会从中断向量表(地址0x00000000)处取出入口地址和堆栈指针,分别加载到PC和SP中。

  入口地址处通常放的是芯片相关的启动代码。这部分代码要完成很多芯片初始化的动作,由于与特定型号芯片相关,所以不能随随便便地就用到别的型号芯片上。通常我们会使用官方提供的例程,然后以此为基础进行必要的修改。以下是LPC1700的初始化代码,所有硬件相关的初始化操作放在了SystemInit()函数中。


    SystemInit()完成的功能可以有:设置看门狗、外部存储器接口、内核时钟等等。当然,这些代码有些是可以放到后面的main()函数中完成,但有些则必须放在运行到__main之前完成。

  芯片初始化完成后,接下来是执行C运行环境的初始化。C环境的初始化主要包含两点:

  按照分散加载文件的配置,将相应的数据段和代码段拷贝到相关位置,将ZI段清零。通过这个功能可以将C代码中未指定初始化值的全局变量和静态变量对应的内存清零,然后将指定初始化的全局变量和静态变量对应的内存初始化。另外,如果有通过分散加载文件设置代码存储在Flash中,然后自动搬运到RAM中运行(该功能将在后续**中细讲),也会在该阶段完成这个自动搬运工作。

  之后是初始化C库,完成后才跳转到main()。

  以下是LPC1700工程的一段初始化代码,不同的工程配置,反汇编出来的结果略有不同。 所以说,在main()运行前,MCU其实已经做了很多工作了。如果程序下载没有出现问题,但是就是跑不到main(),有可能不是仿真器的问题。是否会是main()之前的初始化操作异常?
捉虫天师 发表于 2016-1-11 20:13 | 显示全部楼层
MCU会做一些初始化的工作,然后才转到main。
捉虫天师 发表于 2016-1-11 20:14 | 显示全部楼层
一般这些初始化操作在一个叫.s的文件里写这。.s是start的意思。
john_lee 发表于 2016-1-11 20:24 | 显示全部楼层
捉虫天师 发表于 2016-1-11 20:14
一般这些初始化操作在一个叫.s的文件里写这。.s是start的意思。

多读点书再来回帖
捉虫天师 发表于 2016-1-11 20:44 | 显示全部楼层
john_lee 发表于 2016-1-11 20:24
多读点书再来回帖

startup_stm32f10x_md.s
我觉得我没说错啊,?哪儿错了,如上文件。
  1. ;******************** (C) COPYRIGHT 2011 STMicroelectronics ********************
  2. ;* File Name          : startup_stm32f10x_md.s
  3. ;* Author             : MCD Application Team
  4. ;* Version            : V3.5.0
  5. ;* Date               : 11-March-2011
  6. ;* Description        : STM32F10x Medium Density Devices vector table for MDK-ARM
  7. ;*                      toolchain.  
  8. ;*                      This module performs:
  9. ;*                      - Set the initial SP
  10. ;*                      - Set the initial PC == Reset_Handler
  11. ;*                      - Set the vector table entries with the exceptions ISR address
  12. ;*                      - Configure the clock system
  13. ;*                      - Branches to __main in the C library (which eventually
  14. ;*                        calls main()).
  15. ;*                      After Reset the CortexM3 processor is in Thread mode,
  16. ;*                      priority is Privileged, and the Stack is set to Main.
  17. ;* <<< Use Configuration Wizard in Context Menu >>>   
  18. ;*******************************************************************************
  19. ; THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
  20. ; WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE TIME.
  21. ; AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY DIRECT,
  22. ; INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING FROM THE
  23. ; CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE CODING
  24. ; INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
  25. ;*******************************************************************************

  26. ; Amount of memory (in bytes) allocated for Stack
  27. ; Tailor this value to your application needs
  28. ; <h> Stack Configuration
  29. ;   <o> Stack Size (in Bytes) <0x0-0xFFFFFFFF:8>
  30. ; </h>

  31. Stack_Size      EQU     0x00000400

  32.                 AREA    STACK, NOINIT, READWRITE, ALIGN=3
  33. Stack_Mem       SPACE   Stack_Size
  34. __initial_sp


  35. ; <h> Heap Configuration
  36. ;   <o>  Heap Size (in Bytes) <0x0-0xFFFFFFFF:8>
  37. ; </h>

  38. Heap_Size       EQU     0x00000200

  39.                 AREA    HEAP, NOINIT, READWRITE, ALIGN=3
  40. __heap_base
  41. Heap_Mem        SPACE   Heap_Size
  42. __heap_limit

  43.                 PRESERVE8
  44.                 THUMB


  45. ; Vector Table Mapped to Address 0 at Reset
  46.                 AREA    RESET, DATA, READONLY
  47.                 EXPORT  __Vectors
  48.                 EXPORT  __Vectors_End
  49.                 EXPORT  __Vectors_Size

  50. __Vectors       DCD     __initial_sp               ; Top of Stack
  51.                 DCD     Reset_Handler              ; Reset Handler
  52.                 DCD     NMI_Handler                ; NMI Handler
  53.                 DCD     HardFault_Handler          ; Hard Fault Handler
  54.                 DCD     MemManage_Handler          ; MPU Fault Handler
  55.                 DCD     BusFault_Handler           ; Bus Fault Handler
  56.                 DCD     UsageFault_Handler         ; Usage Fault Handler
  57.                 DCD     0                          ; Reserved
  58.                 DCD     0                          ; Reserved
  59.                 DCD     0                          ; Reserved
  60.                 DCD     0                          ; Reserved
  61.                 DCD     SVC_Handler                ; SVCall Handler
  62.                 DCD     DebugMon_Handler           ; Debug Monitor Handler
  63.                 DCD     0                          ; Reserved
  64.                 DCD     PendSV_Handler             ; PendSV Handler
  65.                 DCD     SysTick_Handler            ; SysTick Handler

  66.                 ; External Interrupts
  67.                 DCD     WWDG_IRQHandler            ; Window Watchdog
  68.                 DCD     PVD_IRQHandler             ; PVD through EXTI Line detect
  69.                 DCD     TAMPER_IRQHandler          ; Tamper
  70.                 DCD     RTC_IRQHandler             ; RTC
  71.                 DCD     FLASH_IRQHandler           ; Flash
  72.                 DCD     RCC_IRQHandler             ; RCC
  73.                 DCD     EXTI0_IRQHandler           ; EXTI Line 0
  74.                 DCD     EXTI1_IRQHandler           ; EXTI Line 1
  75.                 DCD     EXTI2_IRQHandler           ; EXTI Line 2
  76.                 DCD     EXTI3_IRQHandler           ; EXTI Line 3
  77.                 DCD     EXTI4_IRQHandler           ; EXTI Line 4
  78.                 DCD     DMA1_Channel1_IRQHandler   ; DMA1 Channel 1
  79.                 DCD     DMA1_Channel2_IRQHandler   ; DMA1 Channel 2
  80.                 DCD     DMA1_Channel3_IRQHandler   ; DMA1 Channel 3
  81.                 DCD     DMA1_Channel4_IRQHandler   ; DMA1 Channel 4
  82.                 DCD     DMA1_Channel5_IRQHandler   ; DMA1 Channel 5
  83.                 DCD     DMA1_Channel6_IRQHandler   ; DMA1 Channel 6
  84.                 DCD     DMA1_Channel7_IRQHandler   ; DMA1 Channel 7
  85.                 DCD     ADC1_2_IRQHandler          ; ADC1_2
  86.                 DCD     USB_HP_CAN1_TX_IRQHandler  ; USB High Priority or CAN1 TX
  87.                 DCD     USB_LP_CAN1_RX0_IRQHandler ; USB Low  Priority or CAN1 RX0
  88.                 DCD     CAN1_RX1_IRQHandler        ; CAN1 RX1
  89.                 DCD     CAN1_SCE_IRQHandler        ; CAN1 SCE
  90.                 DCD     EXTI9_5_IRQHandler         ; EXTI Line 9..5
  91.                 DCD     TIM1_BRK_IRQHandler        ; TIM1 Break
  92.                 DCD     TIM1_UP_IRQHandler         ; TIM1 Update
  93.                 DCD     TIM1_TRG_COM_IRQHandler    ; TIM1 Trigger and Commutation
  94.                 DCD     TIM1_CC_IRQHandler         ; TIM1 Capture Compare
  95.                 DCD     TIM2_IRQHandler            ; TIM2
  96.                 DCD     TIM3_IRQHandler            ; TIM3
  97.                 DCD     TIM4_IRQHandler            ; TIM4
  98.                 DCD     I2C1_EV_IRQHandler         ; I2C1 Event
  99.                 DCD     I2C1_ER_IRQHandler         ; I2C1 Error
  100.                 DCD     I2C2_EV_IRQHandler         ; I2C2 Event
  101.                 DCD     I2C2_ER_IRQHandler         ; I2C2 Error
  102.                 DCD     SPI1_IRQHandler            ; SPI1
  103.                 DCD     SPI2_IRQHandler            ; SPI2
  104.                 DCD     USART1_IRQHandler          ; USART1
  105.                 DCD     USART2_IRQHandler          ; USART2
  106.                 DCD     USART3_IRQHandler          ; USART3
  107.                 DCD     EXTI15_10_IRQHandler       ; EXTI Line 15..10
  108.                 DCD     RTCAlarm_IRQHandler        ; RTC Alarm through EXTI Line
  109.                 DCD     USBWakeUp_IRQHandler       ; USB Wakeup from suspend
  110. __Vectors_End

  111. __Vectors_Size  EQU  __Vectors_End - __Vectors

  112.                 AREA    |.text|, CODE, READONLY

  113. ; Reset handler
  114. Reset_Handler    PROC
  115.                  EXPORT  Reset_Handler             [WEAK]
  116.      IMPORT  __main
  117.      IMPORT  SystemInit
  118.                  LDR     R0, =SystemInit
  119.                  BLX     R0
  120.                  LDR     R0, =__main
  121.                  BX      R0
  122.                  ENDP

  123. ; Dummy Exception Handlers (infinite loops which can be modified)

  124. NMI_Handler     PROC
  125.                 EXPORT  NMI_Handler                [WEAK]
  126.                 B       .
  127.                 ENDP
  128. HardFault_Handler\
  129.                 PROC
  130.                 EXPORT  HardFault_Handler          [WEAK]
  131.                 B       .
  132.                 ENDP
  133. MemManage_Handler\
  134.                 PROC
  135.                 EXPORT  MemManage_Handler          [WEAK]
  136.                 B       .
  137.                 ENDP
  138. BusFault_Handler\
  139.                 PROC
  140.                 EXPORT  BusFault_Handler           [WEAK]
  141.                 B       .
  142.                 ENDP
  143. UsageFault_Handler\
  144.                 PROC
  145.                 EXPORT  UsageFault_Handler         [WEAK]
  146.                 B       .
  147.                 ENDP
  148. SVC_Handler     PROC
  149.                 EXPORT  SVC_Handler                [WEAK]
  150.                 B       .
  151.                 ENDP
  152. DebugMon_Handler\
  153.                 PROC
  154.                 EXPORT  DebugMon_Handler           [WEAK]
  155.                 B       .
  156.                 ENDP
  157. PendSV_Handler  PROC
  158.                 EXPORT  PendSV_Handler             [WEAK]
  159.                 B       .
  160.                 ENDP
  161. SysTick_Handler PROC
  162.                 EXPORT  SysTick_Handler            [WEAK]
  163.                 B       .
  164.                 ENDP

  165. Default_Handler PROC

  166.                 EXPORT  WWDG_IRQHandler            [WEAK]
  167.                 EXPORT  PVD_IRQHandler             [WEAK]
  168.                 EXPORT  TAMPER_IRQHandler          [WEAK]
  169.                 EXPORT  RTC_IRQHandler             [WEAK]
  170.                 EXPORT  FLASH_IRQHandler           [WEAK]
  171.                 EXPORT  RCC_IRQHandler             [WEAK]
  172.                 EXPORT  EXTI0_IRQHandler           [WEAK]
  173.                 EXPORT  EXTI1_IRQHandler           [WEAK]
  174.                 EXPORT  EXTI2_IRQHandler           [WEAK]
  175.                 EXPORT  EXTI3_IRQHandler           [WEAK]
  176.                 EXPORT  EXTI4_IRQHandler           [WEAK]
  177.                 EXPORT  DMA1_Channel1_IRQHandler   [WEAK]
  178.                 EXPORT  DMA1_Channel2_IRQHandler   [WEAK]
  179.                 EXPORT  DMA1_Channel3_IRQHandler   [WEAK]
  180.                 EXPORT  DMA1_Channel4_IRQHandler   [WEAK]
  181.                 EXPORT  DMA1_Channel5_IRQHandler   [WEAK]
  182.                 EXPORT  DMA1_Channel6_IRQHandler   [WEAK]
  183.                 EXPORT  DMA1_Channel7_IRQHandler   [WEAK]
  184.                 EXPORT  ADC1_2_IRQHandler          [WEAK]
  185.                 EXPORT  USB_HP_CAN1_TX_IRQHandler  [WEAK]
  186.                 EXPORT  USB_LP_CAN1_RX0_IRQHandler [WEAK]
  187.                 EXPORT  CAN1_RX1_IRQHandler        [WEAK]
  188.                 EXPORT  CAN1_SCE_IRQHandler        [WEAK]
  189.                 EXPORT  EXTI9_5_IRQHandler         [WEAK]
  190.                 EXPORT  TIM1_BRK_IRQHandler        [WEAK]
  191.                 EXPORT  TIM1_UP_IRQHandler         [WEAK]
  192.                 EXPORT  TIM1_TRG_COM_IRQHandler    [WEAK]
  193.                 EXPORT  TIM1_CC_IRQHandler         [WEAK]
  194.                 EXPORT  TIM2_IRQHandler            [WEAK]
  195.                 EXPORT  TIM3_IRQHandler            [WEAK]
  196.                 EXPORT  TIM4_IRQHandler            [WEAK]
  197.                 EXPORT  I2C1_EV_IRQHandler         [WEAK]
  198.                 EXPORT  I2C1_ER_IRQHandler         [WEAK]
  199.                 EXPORT  I2C2_EV_IRQHandler         [WEAK]
  200.                 EXPORT  I2C2_ER_IRQHandler         [WEAK]
  201.                 EXPORT  SPI1_IRQHandler            [WEAK]
  202.                 EXPORT  SPI2_IRQHandler            [WEAK]
  203.                 EXPORT  USART1_IRQHandler          [WEAK]
  204.                 EXPORT  USART2_IRQHandler          [WEAK]
  205.                 EXPORT  USART3_IRQHandler          [WEAK]
  206.                 EXPORT  EXTI15_10_IRQHandler       [WEAK]
  207.                 EXPORT  RTCAlarm_IRQHandler        [WEAK]
  208.                 EXPORT  USBWakeUp_IRQHandler       [WEAK]

  209. WWDG_IRQHandler
  210. PVD_IRQHandler
  211. TAMPER_IRQHandler
  212. RTC_IRQHandler
  213. FLASH_IRQHandler
  214. RCC_IRQHandler
  215. EXTI0_IRQHandler
  216. EXTI1_IRQHandler
  217. EXTI2_IRQHandler
  218. EXTI3_IRQHandler
  219. EXTI4_IRQHandler
  220. DMA1_Channel1_IRQHandler
  221. DMA1_Channel2_IRQHandler
  222. DMA1_Channel3_IRQHandler
  223. DMA1_Channel4_IRQHandler
  224. DMA1_Channel5_IRQHandler
  225. DMA1_Channel6_IRQHandler
  226. DMA1_Channel7_IRQHandler
  227. ADC1_2_IRQHandler
  228. USB_HP_CAN1_TX_IRQHandler
  229. USB_LP_CAN1_RX0_IRQHandler
  230. CAN1_RX1_IRQHandler
  231. CAN1_SCE_IRQHandler
  232. EXTI9_5_IRQHandler
  233. TIM1_BRK_IRQHandler
  234. TIM1_UP_IRQHandler
  235. TIM1_TRG_COM_IRQHandler
  236. TIM1_CC_IRQHandler
  237. TIM2_IRQHandler
  238. TIM3_IRQHandler
  239. TIM4_IRQHandler
  240. I2C1_EV_IRQHandler
  241. I2C1_ER_IRQHandler
  242. I2C2_EV_IRQHandler
  243. I2C2_ER_IRQHandler
  244. SPI1_IRQHandler
  245. SPI2_IRQHandler
  246. USART1_IRQHandler
  247. USART2_IRQHandler
  248. USART3_IRQHandler
  249. EXTI15_10_IRQHandler
  250. RTCAlarm_IRQHandler
  251. USBWakeUp_IRQHandler

  252.                 B       .

  253.                 ENDP

  254.                 ALIGN

  255. ;*******************************************************************************
  256. ; User Stack and Heap initialization
  257. ;*******************************************************************************
  258.                  IF      :DEF:__MICROLIB           
  259.                
  260.                  EXPORT  __initial_sp
  261.                  EXPORT  __heap_base
  262.                  EXPORT  __heap_limit
  263.                
  264.                  ELSE
  265.                
  266.                  IMPORT  __use_two_region_memory
  267.                  EXPORT  __user_initial_stackheap
  268.                  
  269. __user_initial_stackheap

  270.                  LDR     R0, =  Heap_Mem
  271.                  LDR     R1, =(Stack_Mem + Stack_Size)
  272.                  LDR     R2, = (Heap_Mem +  Heap_Size)
  273.                  LDR     R3, = Stack_Mem
  274.                  BX      LR

  275.                  ALIGN

  276.                  ENDIF

  277.                  END

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


捉虫天师 发表于 2016-1-11 20:46 | 显示全部楼层
john_lee 发表于 2016-1-11 20:24
多读点书再来回帖

(which eventually
;*                        calls main()

最终调用main()
请版主说说,哪儿错了。
捉虫天师 发表于 2016-1-11 21:00 | 显示全部楼层
john_lee 发表于 2016-1-11 20:24
多读点书再来回帖

starup.s ,即时启动代码
它是芯片复位进入C语言main函数以前执行的一段初始化程序,主要是为芯片运行提供基本的运行环境,如初始化存储系统、寄存器、PLL和内存重映射,处理异常等
john_lee 发表于 2016-1-11 22:40 | 显示全部楼层
捉虫天师 发表于 2016-1-11 20:14
一般这些初始化操作在一个叫.s的文件里写这。.s是start的意思。

.s 是 start 的意思?
gaoyang9992006 发表于 2016-1-12 01:12 来自手机 | 显示全部楼层
基本上算是吧
zzgzst3 发表于 2016-1-12 08:52 | 显示全部楼层
学习了..
poorhack 发表于 2016-1-12 09:12 | 显示全部楼层
john_lee 发表于 2016-1-11 22:40
.s 是 start 的意思?

.s一般放在startup文件夹下,另外它又是启动文件,所以可能会默认为.s是startup的意思。
.s的具体含义及命名来历,俺还真不清楚,为啥不叫.a .b .c .startup...
还请真高人赐教,万万不可回复“多读点书再来回帖”:P
john_lee 发表于 2016-1-12 09:40 | 显示全部楼层
poorhack 发表于 2016-1-12 09:12
.s一般放在startup文件夹下,另外它又是启动文件,所以可能会默认为.s是startup的意思。
.s的具体含义及 ...

这种问题在网上搜索一下不困难吧?

-----------------------------
.s 是汇编源程序文件(ASSEMBLY source code file)的扩展名(extension file name),最早在 unix 系统使用,按理应该取 ASSEMBLY 的第一个字母,但 .a 的扩展名已经安排给了库文件(Archive library file),所以取了第二个字母 s。
john_lee 发表于 2016-1-12 09:51 | 显示全部楼层
poorhack 发表于 2016-1-12 09:12
.s一般放在startup文件夹下,另外它又是启动文件,所以可能会默认为.s是startup的意思。
.s的具体含义及 ...

另外,一些不知道的东西,自己随便猜测没有问题,但把自己的猜测发表出来而不注明是“猜的”,显然会误导不知道的人,这不是做技术应有的严谨态度。

评论

赞!  发表于 2016-1-12 11:56
lemenade 发表于 2016-1-12 10:45 | 显示全部楼层
好东西还是要跟一下的。收藏了。
steven_fae 发表于 2016-1-12 10:47 | 显示全部楼层
.s好像是汇编后缀,大家都在用C,对汇编不熟也正常吧
tianhaolan 发表于 2016-1-12 11:54 | 显示全部楼层
poorhack 发表于 2016-1-12 09:12
.s一般放在startup文件夹下,另外它又是启动文件,所以可能会默认为.s是startup的意思。
.s的具体含义及 ...

管它啥缩写呢,何必纠结这个,同理:万不可使用多读点书来回帖
dawei360 发表于 2016-1-12 12:41 | 显示全部楼层
去看看启动文件就知道做了什么了!!!!!
秋风式街球 发表于 2016-1-12 15:27 | 显示全部楼层
努力学习
slm342107 发表于 2016-1-12 15:58 | 显示全部楼层
.s是汇编文件  不是start的意思   即使有战友理解有误  楼主应当指出,同理:万不可使用多读点书来回帖
shauew 发表于 2016-1-12 19:31 | 显示全部楼层
捉虫天师 发表于 2016-1-11 20:14
一般这些初始化操作在一个叫.s的文件里写这。.s是start的意思。

.s是asm汇编文件的后缀
虽然这个文件叫做启动文件,但也不能强装start啊
您需要登录后才可以回帖 登录 | 注册

本版积分规则

21

主题

123

帖子

2

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