newlib/libgloss/pru/ldscripts/pruelf-sim.x
Dimitar Dimitrov 0c7734673a Initial PRU port for libgloss and newlib
Signed-off-by: Dimitar Dimitrov <dimitar@dinux.eu>
2019-10-31 14:47:19 -04:00

201 lines
5.7 KiB
Plaintext

/* WARNING: automatically generated from the default pru-ld script! */
/* Default linker script, for normal executables */
OUTPUT_FORMAT("elf32-pru","elf32-pru","elf32-pru")
OUTPUT_ARCH(pru)
MEMORY
{
imem (x) : ORIGIN = 0x20000000, LENGTH = 256K
dmem (rw!x) : ORIGIN = 0x0, LENGTH = 65536K
}
__HEAP_SIZE = DEFINED(__HEAP_SIZE) ? __HEAP_SIZE : 32 * 1024 * 1024 ;
__STACK_SIZE = DEFINED(__STACK_SIZE) ? __STACK_SIZE : 1024 * 1024 ;
PROVIDE (_stack_top = ORIGIN(dmem) + LENGTH(dmem));
ENTRY (_start)
SECTIONS
{
/* Read-only sections, merged into text segment: */
.hash : { *(.hash) }
.dynsym : { *(.dynsym) }
.dynstr : { *(.dynstr) }
.gnu.version : { *(.gnu.version) }
.gnu.version_d : { *(.gnu.version_d) }
.gnu.version_r : { *(.gnu.version_r) }
.rel.init : { *(.rel.init) }
.rela.init : { *(.rela.init) }
.rel.text :
{
*(.rel.text)
*(.rel.text.*)
*(.rel.text:*)
*(.rel.gnu.linkonce.t*)
}
.rela.text :
{
*(.rela.text)
*(.rela.text.*)
*(.rela.text:*)
*(.rela.gnu.linkonce.t*)
}
.rel.fini : { *(.rel.fini) }
.rela.fini : { *(.rela.fini) }
.rel.rodata :
{
*(.rel.rodata)
*(.rel.rodata.*)
*(.rel.rodata:*)
*(.rel.gnu.linkonce.r*)
}
.rela.rodata :
{
*(.rela.rodata)
*(.rela.rodata.*)
*(.rela.rodata:*)
*(.rela.gnu.linkonce.r*)
}
.rel.data :
{
*(.rel.data)
*(.rel.data.*)
*(.rel.data:*)
*(.rel.gnu.linkonce.d*)
}
.rela.data :
{
*(.rela.data)
*(.rela.data.*)
*(.rela.data:*)
*(.rela.gnu.linkonce.d*)
}
.rel.init_array : { *(.rel.init_array) }
.rela.init_array : { *(.rela.init_array) }
.rel.fini_array : { *(.rel.fini_array) }
.rela.fini_array : { *(.rela.fini_array) }
.rel.got : { *(.rel.got) }
.rela.got : { *(.rela.got) }
.rel.bss : { *(.rel.bss) }
.rela.bss : { *(.rela.bss) }
.rel.plt : { *(.rel.plt) }
.rela.plt : { *(.rela.plt) }
/* Internal text space. */
.text :
{
_text_start = . ;
. = ALIGN(4);
*(.init0) /* Start here after reset. */
KEEP (*(.init0))
. = ALIGN(4);
*(.text)
. = ALIGN(4);
*(.text.*)
. = ALIGN(4);
*(.text:*)
. = ALIGN(4);
*(.gnu.linkonce.t*)
. = ALIGN(4);
_text_end = . ;
} > imem
.data :
{
/* Optional variable that user is prepared to have NULL address. */
*(.data.atzero*)
/* CRT is prepared for constructor/destructor table to have
a "valid" NULL address. */
__init_array_start = . ;
KEEP (*(SORT_BY_INIT_PRIORITY(.init_array.*)))
KEEP (*(.init_array))
__init_array_end = . ;
__fini_array_start = . ;
KEEP (*(SORT_BY_INIT_PRIORITY(.fini_array.*)))
KEEP (*(.fini_array))
__fini_array_end = . ;
/* DATA memory starts at address 0. So to avoid placing a valid static
variable at the invalid NULL address, we introduce the .data.atzero
section. If CRT can make some use of it - great. Otherwise skip a
word. In all cases .data/.bss sections must start at non-zero. */
. += (. == 0 ? 4 : 0);
PROVIDE (_data_start = .) ;
*(.data)
*(.data*)
*(.data:*)
*(.rodata) /* We need to include .rodata here if gcc is used. */
*(.rodata.*) /* with -fdata-sections. */
*(.rodata:*)
*(.gnu.linkonce.d*)
*(.gnu.linkonce.r*)
. = ALIGN(4);
PROVIDE (_data_end = .) ;
} > dmem
.resource_table :
{
KEEP (*(.resource_table))
} > dmem
.bss :
{
PROVIDE (_bss_start = .) ;
*(.bss)
*(.bss.*)
*(.bss:*)
*(.gnu.linkonce.b*)
*(COMMON)
PROVIDE (_bss_end = .) ;
} > dmem
/* Global data not cleared after reset. */
.noinit :
{
PROVIDE (_noinit_start = .) ;
*(.noinit)
PROVIDE (_noinit_end = .) ;
PROVIDE (_heap_start = .) ;
. += __HEAP_SIZE ;
/* Stack is not here really. It will be put at the end of DMEM.
But we take into account its size here, in order to allow
for MEMORY overflow checking during link time. */
. += __STACK_SIZE ;
} > dmem
/* Stabs debugging sections. */
.stab 0 : { *(.stab) }
.stabstr 0 : { *(.stabstr) }
.stab.excl 0 : { *(.stab.excl) }
.stab.exclstr 0 : { *(.stab.exclstr) }
.stab.index 0 : { *(.stab.index) }
.stab.indexstr 0 : { *(.stab.indexstr) }
.comment 0 : { *(.comment) }
.note.gnu.build-id : { *(.note.gnu.build-id) }
/* DWARF debug sections.
Symbols in the DWARF debugging sections are relative to the beginning
of the section so we begin them at 0. */
/* DWARF 1 */
.debug 0 : { *(.debug) }
.line 0 : { *(.line) }
/* GNU DWARF 1 extensions */
.debug_srcinfo 0 : { *(.debug_srcinfo) }
.debug_sfnames 0 : { *(.debug_sfnames) }
/* DWARF 1.1 and DWARF 2 */
.debug_aranges 0 : { *(.debug_aranges) }
.debug_pubnames 0 : { *(.debug_pubnames) }
/* DWARF 2 */
.debug_info 0 : { *(.debug_info .gnu.linkonce.wi.*) }
.debug_abbrev 0 : { *(.debug_abbrev) }
.debug_line 0 : { *(.debug_line .debug_line.* .debug_line_end) }
.debug_frame 0 : { *(.debug_frame) }
.debug_str 0 : { *(.debug_str) }
.debug_loc 0 : { *(.debug_loc) }
.debug_macinfo 0 : { *(.debug_macinfo) }
/* SGI/MIPS DWARF 2 extensions */
.debug_weaknames 0 : { *(.debug_weaknames) }
.debug_funcnames 0 : { *(.debug_funcnames) }
.debug_typenames 0 : { *(.debug_typenames) }
.debug_varnames 0 : { *(.debug_varnames) }
/* DWARF 3 */
.debug_pubtypes 0 : { *(.debug_pubtypes) }
.debug_ranges 0 : { *(.debug_ranges) }
/* DWARF Extension. */
.debug_macro 0 : { *(.debug_macro) }
.debug_addr 0 : { *(.debug_addr) }
}