打印
[STM32F1]

烧写到目标的flash

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

使用特权

评论回复
板凳
jiahy|  楼主 | 2017-8-27 19:25 | 只看该作者
我没发现相关的代码啊,数据段是怎么搬运到内存之中????

使用特权

评论回复
地板
zhanghqi| | 2017-8-27 19:29 | 只看该作者
这个与运行的机制有关。。

使用特权

评论回复
5
jiahy|  楼主 | 2017-8-27 19:31 | 只看该作者


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

使用特权

评论回复
6
jlyuan| | 2017-8-27 19:33 | 只看该作者
这个不是应用程序完成的,启动代码里应该讲的是这个

使用特权

评论回复
7
yszong| | 2017-8-27 19:35 | 只看该作者

你仿真,看一下汇编,不要直接停止在main函数,在执行main函数前有一段代码,编译器添加的

使用特权

评论回复
8
heweibig| | 2017-8-27 19:37 | 只看该作者
这个需要一段代码做搬运动作。通常这段代码是由编译器提供的。

使用特权

评论回复
9
lizye| | 2017-8-27 19:39 | 只看该作者
以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
jiahy|  楼主 | 2017-8-27 19:41 | 只看该作者
结贴了,多谢大家讨论这么多哈,呵呵

使用特权

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

本版积分规则

862

主题

9861

帖子

4

粉丝