初学arm u-boot,总有很多问题。虽然这是一个小问题,但还是想写下来,记录一下,以免以后的的麻烦。
u-boot执行的第一阶段将_armboot_start(也即_start)到_bss_start的代码都移到SDRAM中去了,但是唯独没有移动bss段,为什么呢?
这是因为bss段本质是存放程序中未初始化的全局变量的一块内存区域,根据编译文件可以分析(http://www.360doc.com/content/12/0331/21/8363527_199765130.shtml)bss段在程序中并不占用任何空间,只是一个占位符,不占用执行文件的空间。在稍后进入执行的第二阶段,即C语言完成的阶段时,因为C语言要求的运行条件是要将栈设置好,并且bss段要初始化为0;故而在将所有u-boot代码(除了bss)都搬移到sdram中后,clear_bss标号开始的代码就将_bss_start指定的地址开始的bss段清零了,为下一阶段C的运行创造了条件。所以不用移动bss段总的原因就是它就是占位符,稍后把它全部清零就行了,用不着移动~
另外,要注意,这个_bss_start指定的地址是链接文件中确定的地址(u-boot.lds),是链接时u-boot的bss段的起始地址,这个地址是基于u-boot在链接时确定的u-boot在内存中的加载地址或者运行地址的,这个加载和运行地址在config.mk中确定。具体可以参考我收藏的文章:
故而不用移动bss段到sdram中去了。