U-boot.lds文件分析

1 OUTPUT_FORMAT("elf32-littlearm", "elf32-littlearm", "elf32-littlearm")
2 OUTPUT_ARCH(arm)
3 ENTRY(_start)

lds文件位于board/samsung/smdk6410/u-boot-nand.lds下。

指定elf32-littlearm 格式,即指定输出文件是elf格式,32位ARM指令,小端模式;

紧接着OUTPUT_ARCH(arm) 指定的是输出可执行文件的运行平台为ARM;

ENTRY(_start)指定_start函数为程序的入口, _start 在arch/arm/cpu/arm1176/ start.S 中定义,真正的启 动运行地址段在编译时在 board/samsung/smdk6410/config.mk 中由CONFIG_SYS TEXT_BASE 宏定义,即 TEXT_BASE = 0x57E00000
1 SECTIONS
2 {
3     . = 0x00000000;
4 
5     . = ALIGN(4);

SECTIONS开始定义程序段。

这里的点”.”,是定位器符号(GNU风格的一个典型)。         

把定位器符号置为0x00000000 (若不指定, 则该符号的初始值为0)。         

定系统启动从偏移地址零处开始。注意这只是个代码地址偏移值,真正的起始地址是由编译时指定的

CFLAGS指定的。 

4字节对齐调整,那么ALIGN(0x10) 即16字节对齐后。

1 .text      :
2     {
3       arch/arm/cpu/arm1176/start.o    (.text)
4           board/samsung/smdk6410/libsmdk6410.o  (.text)
5       *(.text)
6     }

.text为段名,这段脚本的意思是将所有输入文件的.text section,以及arch/arm/cpu/arm1176/start.o、board/samsung/smdk6410/libsmdk6410.o合并成一个.text section,该section的地址由定位器符号的值指定(字节对齐后定位器符号的值)。

1 . = ALIGN(4);
2     .rodata : { *(SORT_BY_ALIGNMENT(SORT_BY_NAME(.rodata*))) }

 修改当前定位寄存器,使的下面的.rodata输出节与4bytes对齐,定义.rodata输出节为所有文件的.rodata输入节,*表示通配符,(.rodata*)为所有rodata开头的段。

1 .rel.dyn : {
2         __rel_dyn_start = .;
3         *(.rel*)
4         __rel_dyn_end = .;
5     }

 用于用于动态连接的重定位信息。

1 .dynsym : {
2         __dynsym_start = .;
3         *(.dynsym)
4     }

.dynsym动态符号表,这个表只保存了与动态链接相关的符号, __dynsym_start = . ;这是动态连接符号表的数据结构部分,须与.dynstr联用。

1 .bss __rel_dyn_start (OVERLAY) : {
2         __bss_start = .;
3         *(.bss)
4         . = ALIGN(4);
5         __bss_end__ = .;
6     }

 

 bss,为什么会有__rel_dyn_start(OVERLAY),不知道原因。 

这里说明一点:在没有对位置技术器进行赋值时,位置计数器会动态的增加,比如. = .;这一条语句,此时位置技术器的位置就是从0开始加上代码段,只读数据段,数据段,got段的大小,紧接着之后的位置。

你可能感兴趣的:(Boot)