wut/share/wut.ld
2018-05-23 15:36:35 +01:00

146 lines
2.9 KiB
Plaintext

OUTPUT_FORMAT("elf32-powerpc")
OUTPUT_ARCH(powerpc:common)
MEMORY {
relmem (rw) : ORIGIN = 0x00000000, LENGTH = 32M
codemem (rwx) : ORIGIN = 0x02000000, LENGTH = 224M
datamem (rw) : ORIGIN = 0x10000000, LENGTH = 800M
loadmem (rwx) : ORIGIN = 0xC0000000, LENGTH = 128M
}
EXTERN(main)
ENTRY(main)
SECTIONS
{
. = ORIGIN(codemem);
.syscall ALIGN(32) : {
*(.syscall .syscall.*)
} > codemem
.text ALIGN(32) : {
*(.text .text.*)
*(.init)
*(.fini)
} > codemem
. = ORIGIN(datamem);
.rodata ALIGN(32) : {
*(.rodata .rodata.*)
*(.ctors)
*(.dtors)
*(.init_array)
*(.fini_array)
*(.jcr)
*(.gcc_except_table .gcc_except_table.*)
*(.eh_frame_hdr)
*(.eh_frame)
*(.got)
*(.got1)
*(.got2)
*(.tm_clone_table)
} > datamem
.data ALIGN(32) : {
*(.data .data.*)
. = ALIGN(32);
__sdata_start = .;
*(.sdata .sdata.*)
__sdata_end = .;
. = ALIGN(32);
__sdata2_start = .;
*(.sdata2 .sdata2.*)
__sdata2_end = .;
} > datamem
__bss_start = .;
.bss ALIGN(64) : {
*(.bss .bss.*)
. = ALIGN(64);
__sbss_start = .;
*(.sbss .sbss.*)
__sbss_end = .;
. = ALIGN(64);
__sbss2_start = .;
*(.sbss2 .sbss2.*)
__sbss2_end = .;
}
__bss_end = .;
. = ORIGIN(relmem);
.rela.text ALIGN(4) : {
*(.rela.text .rela.text.*)
*(.rela.init)
*(.rela.fini)
} > relmem
.rela.data ALIGN(4) : {
*(.rela.data .rela.data.*)
*(.rela.sdata)
*(.rela.sdata2)
*(.rela.init_array)
*(.rela.fini_array)
*(.rela.gcc_except_table .rela.gcc_except_table.*)
*(.rela.eh_frame)
*(.rela.got2)
} > relmem
.rela.rodata ALIGN(4) : {
*(.rela.rodata .rela.rodata.*)
} > relmem
. = ORIGIN(loadmem);
.fimport_coreinit ALIGN(16) : {
*(.fimport_coreinit)
} > loadmem
.fimport_gx2 ALIGN(16) : {
*(.fimport_gx2)
} > loadmem
.fimport_nn_ac ALIGN(16) : {
*(.fimport_nn_ac)
} > loadmem
.fimport_nsysnet ALIGN(16) : {
*(.fimport_nsysnet)
} > loadmem
.fimport_proc_ui ALIGN(16) : {
*(.fimport_proc_ui)
} > loadmem
.fimport_sndcore2 ALIGN(16) : {
*(.fimport_sndcore2)
} > loadmem
.fimport_sysapp ALIGN(16) : {
*(.fimport_sysapp)
} > loadmem
.fimport_vpad ALIGN(16) : {
*(.fimport_vpad)
} > loadmem
.symtab ALIGN(4) : {
*(.symtab)
} > loadmem
.strtab ALIGN(1) : {
*(.strtab)
} > loadmem
.shstrtab ALIGN(1) : {
*(.shstrtab)
} > loadmem
__SDATA_START__ = __sdata_start;
__SBSS_END__ = __sbss_end;
__SDATA2_START__ = __sdata2_start;
__SBSS2_END__ = __sbss2_end;
_SDA_BASE_ = __sbss_end;
_SDA2_BASE_ = __sdata2_start + ((__sbss2_end - __sdata2_start) / 2);
/DISCARD/ : {
*(.comment)
*(.fixup)
*(.gnu.attributes)
*(.abs)
}
}