uboot为什么要重定位/代码拷贝?

参考自:https://www.cnblogs.com/Cqlismy/p/12152400.html
必看。这个老哥写的uboot启动的博客非常棒,感谢。
还有https://blog.csdn.net/luciferful/article/details/9371891
还有正点原子uboot相关内容。

自己总结心得如下:
以前看过的老版本的UBOOT(包括2440和朱老师的S5PV210)是没有这样的,而是遵循裸机规矩:运行地址必须等于链接地址。
可是最近看的imx6ull的uboot中,代码原本已经被内部rom根据SD卡启动时的头部信息给复制到sdram中了,为什么还要再有一次代码搬移呢???而且代码是从链接地址搬移到一个别的地址去了,运行地址就不等于链接地址了,为什么呢?

我们关注两点就行了:目的和实现手法。

目的据说是,把uboot移动到更高地址的内存中去,靠近sdram的顶端,为kernel腾出空间,防止kernel解压覆盖UBOOT。
可是引导内核后uboot不就没用了吗???为什么怕干扰??

怎么实现的呢?
怎么做到运行地址和链接地址不同就仍然可以正常运行??
(而且还是用的位置相关的代码,用到了全局变量等等。)
关键有两点:
一、就在于在使用 ld 进行链接的时候使用选项“-pie”生成位置无关的可执行文件。在文件
arch/arm/config.mk 下有如下代码: LDFLAGS_u-boot += -pie。
编译时就可以看到下面这样的动作信息:<

  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值