参考自: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。
编译时就可以看到下面这样的动作信息:<