我试图了解如何在基于powerpc mpc8313处理器的板上完成uboot的移植。在此过程中,我遇到了名为uboot.lds的文件(链接描述文件)。
我需要了解这个文件。我的意思是提到的内容的意义以及uboot软件包中定义的实际地址。
例如;在“部分”中,我可以找到以下信息的重要性:
/* Read-only sections, merged into text segment: */
. = + SIZEOF_HEADERS;
.interp : { *(.interp) }
.hash : { *(.hash) }
.dynsym : { *(.dynsym) }
.dynstr : { *(.dynstr) }
.rel.text : { *(.rel.text) }
.rela.text : { *(.rela.text) }
.rel.data : { *(.rel.data) }
.rela.data : { *(.rela.data) }
.rel.rodata : { *(.rel.rodata) }
.rela.rodata : { *(.rela.rodata) }
.rel.got : { *(.rel.got) }
.rela.got : { *(.rela.got) }
.rel.ctors : { *(.rel.ctors) }
.rela.ctors : { *(.rela.ctors) }
.rel.dtors : { *(.rel.dtors) }
.rela.dtors : { *(.rela.dtors) }
.rel.bss : { *(.rel.bss) }
.rela.bss : { *(.rela.bss) }
.rel.plt : { *(.rel.plt) }
.rela.plt : { *(.rela.plt) }
.init : { *(.init) }
.plt : { *(.plt) }
.text :
{
cpu/mpc83xx/start.o (.text)
*(.text)
*(.fixup)
*(.got1)
. = ALIGN(16);
*(.rodata)
*(.rodata1)
*(.rodata.str1.4)
*(.eh_frame)
}
.fini : { *(.fini) } =0
.ctors : { *(.ctors) }
.dtors : { *(.dtors) }
/* Read-write section, merged into data segment: */
. = (. + 0x0FFF) & 0xFFFFF000;
_erotext = .;
PROVIDE (erotext = .);
.reloc :
{
*(.got)
_GOT2_TABLE_ = .;
*(.got2)
_FIXUP_TABLE_ = .;
*(.fixup)
}
__got2_entries = (_FIXUP_TABLE_ - _GOT2_TABLE_) >> 2;
__fixup_entries = (. - _FIXUP_TABLE_) >> 2;
.data :
{
*(.data)
*(.data1)
*(.sdata)
*(.sdata2)
*(.dynamic)
CONSTRUCTORS
}
_edata = .;
PROVIDE (edata = .);
. = .;
__u_boot_cmd_start = .;
.u_boot_cmd : { *(.u_boot_cmd) }
__u_boot_cmd_end = .;
. = .;
__start___ex_table = .;
__ex_table : { *(__ex_table) }
__stop___ex_table = .;
. = ALIGN(4096);
__init_begin = .;
.text.init : { *(.text.init) }
.data.init : { *(.data.init) }
. = ALIGN(4096);
__init_end = .;
__bss_start = .;
.bss :
{
*(.sbss) *(.scommon)
*(.dynbss)
*(.bss)
*(COMMON)
}
_end = . ;
PROVIDE (end = .);
}
在哪里可以找到这些信息,以及如何确定要在lds文件中进行的更改?
请确认或至少给出一些指示以阅读信息,谢谢
Regads,
维杰
最佳答案
要移植u-boot,可以在cpu目录而不是board目录中使用u-boot.lds。换句话说,可能不需要移植此文件。但是,如果有的话,这里是一个概述。
您可以在LD documentation中找到很多信息。
通常,LD脚本允许您执行的操作是覆盖GCC工具链在运行时将其放置在内存中的默认位置。编译应用程序时,将处理源代码并创建包含机器代码的目标代码文件。在链接过程中,各种目标文件被组合成一个文件,例如ELF可执行文件,并且文件头放置在文件中,以告知OS每个目标文件应在内存中的位置,以便在需要时可以找到它(全局变量,电话等)
如果要将代码放置在编译器/链接器无法预期的特定位置,则需要自定义脚本。这样做有很多原因,我将尝试列出。
除此之外,它还可以是在链接时方便地访问内存指针的一种方法。例如,__init_begin被定义为一个符号,该符号具有编译为* .text.init的任何代码的内存地址。现在,您可以通过将程序计数器设置为__init_begin的值来调用该内存,而无需配置完整的C环境。
编译器文档+ u-boot Makefiles应该说明编译器如何以及何时生成每种类型(例如.txt,.data,.bss,.fini,.ctors等)的目标文件。
关于linker - 了解uboot.lds,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/4375908/