我试图了解如何在基于powerpc mpc8313处理器的主板上完成uboot的移植。在此过程中,我遇到了名为uboot.lds的文件,链接器脚本文件。
我需要了解这个文件。我的意思是提到的内容的重要性以及在uboot包中定义实际地址的位置。
例如;在SECTIONS中,我可以找到以下信息的重要性:
/* 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, 维杰
答案 0 :(得分:15)
要移植u-boot,可以从cpu目录而不是board目录中使用u-boot.lds。换句话说,可能不需要移植此文件。但是,如果有,那么这里有一个概述。
您可以在LD documentation中找到大量信息。
通常,LD脚本允许您执行的操作是覆盖GCC工具链在运行时将内容放入内存的默认位置。编译应用程序时,将处理源代码并创建包含机器代码的目标代码文件。在链接期间,各种目标文件被组合成一个文件,例如ELF可执行文件,并且在文件上放置一个标题,告诉操作系统每个目标文件应该放在内存中,以便在需要时找到它(全局,函数)电话等。)
如果要将代码放在一个您不能指望编译器/链接器猜测的特定位置,则需要自定义脚本。这样做有很多原因,我将尝试列出。
除此之外,它还可以在链接时方便地访问内存指针。例如,__ init_begin被定义为具有编译为* .text.init的任何代码的内存地址的符号。现在,您可以通过将程序计数器设置为__init_begin的值来调用该内存,而无需配置完整的C环境。
编译器文档+ u-boot Makefiles应该解释编译器如何以及何时生成每种类型的目标文件(例如.txt,.data,.bss,.fini,.ctors等)