打印
[STM32F1]

烧写到目标的flash

[复制链接]
520|10
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
llljh|  楼主 | 2016-8-31 20:52 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
MDK编译环境,目标stm32f103,一般程序编译出来text(ro)段,data段,bss段等都在hex或者bin文件之中,烧写到目标的flash中,可是data段与bss(zi)段是怎么加载到SRAM(内存)中的
沙发
dingy| | 2016-8-31 20:52 | 只看该作者
有相关的代码吧

使用特权

评论回复
板凳
llljh|  楼主 | 2016-8-31 20:52 | 只看该作者

我没发现相关的代码啊,数据段是怎么搬运到内存之中????

使用特权

评论回复
地板
pengf| | 2016-8-31 20:53 | 只看该作者
这个与运行的机制有关。。

使用特权

评论回复
5
llljh|  楼主 | 2016-8-31 20:53 | 只看该作者

能稍微给我讲一下吗?
这编译器自动添加了搬运数据段的代码?

使用特权

评论回复
6
司徒老鹰| | 2016-8-31 20:53 | 只看该作者
这个不是应用程序完成的,启动代码里应该讲的是这个

使用特权

评论回复
7
juventus9554| | 2016-8-31 20:53 | 只看该作者
你仿真,看一下汇编,不要直接停止在main函数,在执行main函数前有一段代码,编译器添加的

使用特权

评论回复
8
chuxh| | 2016-8-31 20:54 | 只看该作者
这个需要一段代码做搬运动作。通常这段代码是由编译器提供的。

使用特权

评论回复
9
zwll| | 2016-8-31 20:54 | 只看该作者
以Keil为例。注意两个引入的符号:SystemInit和__main。SystemInit毫无疑问是C代码中提供的,而__main却在代码中找不到。代码中写的是main。
这种写法就是依赖Keil编译器提供的load代码来搬运。代码流程:
__main --> __scatterload .......
           --> main

Reset_Handler    PROC
                 EXPORT  Reset_Handler             [WEAK]
        IMPORT  SystemInit
        IMPORT  __main

                 LDR     R0, =SystemInit
                 BLX     R0
                 LDR     R0, =__main
                 BX      R0
                 ENDP

实际上,也可以自己写代码做搬运动作。
写法:
                 LDR     R0, =SystemInit
                 BLX     R0
                 ;Write your own load code here
                 LDR     R0, =main
                 BX      R0
                 ENDP


这时就需要了解,在编译完成的Image中,Load View和Execute View的概念。
链接器在链接的时候会生成每个section的符号:Base,Length,Limit之类。load代码需要根据这些符号确定搬运的源地址、目的地址,以及长度。
具体可以查阅Keil帮助的Linker及Scatter file章节。
3.3 Load View and Execution View of an Image
6.4 Image$$ execution region symbols
6.5 Load$$LR$$ load region symbols

使用特权

评论回复
10
llljh|  楼主 | 2016-8-31 20:54 | 只看该作者
结贴了,多谢大家讨论这么多哈,呵呵

使用特权

评论回复
11
Thorald| | 2016-8-31 21:25 | 只看该作者
你仿真,看一下汇编

这个怎么去看

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

855

主题

11301

帖子

6

粉丝