aboutsummaryrefslogtreecommitdiff
path: root/libpsn00b/ldscripts
diff options
context:
space:
mode:
authorspicyjpeg <88942473+spicyjpeg@users.noreply.github.com>2021-08-17 11:36:56 +0000
committerspicyjpeg <88942473+spicyjpeg@users.noreply.github.com>2021-08-17 11:36:56 +0000
commit89751f29467b359339a8c8b57c218cc3328bae43 (patch)
treef92eeff576fea528e6a5c5a984207aac9e0d2b8c /libpsn00b/ldscripts
parent5f5461879c73720359e87fa41cbfe8c452f5155e (diff)
downloadpsn00bsdk-89751f29467b359339a8c8b57c218cc3328bae43.tar.gz
Rewritten all Makefiles, set up proper GCC options, added iso.xml to template
Diffstat (limited to 'libpsn00b/ldscripts')
-rw-r--r--libpsn00b/ldscripts/dll.ld122
-rw-r--r--libpsn00b/ldscripts/exe.ld114
2 files changed, 236 insertions, 0 deletions
diff --git a/libpsn00b/ldscripts/dll.ld b/libpsn00b/ldscripts/dll.ld
new file mode 100644
index 0000000..59cbb53
--- /dev/null
+++ b/libpsn00b/ldscripts/dll.ld
@@ -0,0 +1,122 @@
+/*
+ * PSn00bSDK linker script for dynamically-loaded libraries
+ * (C) 2021 spicyjpeg - MPL licensed
+ *
+ * This script is similar to the one for executables. The main differences are
+ * the header at the beginning of the file, the .sdata/.sbss sections being
+ * replaced by the global offset table (GOT) and .bss being merged with .data.
+ */
+
+OUTPUT_FORMAT(elf32-littlemips)
+/*ENTRY(_start)
+STARTUP(start.o)*/
+
+MEMORY {
+ /* Code is position-independent, so we just set zero as address */
+ RELOC_RAM (rwx) : ORIGIN = 0x00000000, LENGTH = 1M
+}
+
+SECTIONS {
+ /*
+ * DLL "header", containing the following sections:
+ *
+ * .dynamic: key-value pairs describing various section offsets, flags and
+ * other stuff
+ * .dynsym: dynamic symbol table, listing all functions to relocate as well
+ * as exported symbols
+ * .hash: pre-generated hash table to quickly look up symbol table
+ * entries by their names
+ * .dynstr: string blob referenced by symbol table entries
+ */
+
+ .dynamic : { *(.dynamic) } > RELOC_RAM
+ .dynsym : { *(.dynsym) } > RELOC_RAM
+ .hash : { *(.hash) } > RELOC_RAM
+ .dynstr : { *(.dynstr) } > RELOC_RAM
+
+ /* Text section, i.e. code and constants */
+
+ .text : ALIGN(16) {
+ __text_start = .;
+
+ *(.text .text.* .gnu.linkonce.t.*)
+ *(.plt .MIPS.stubs)
+ } > RELOC_RAM
+ .rodata : {
+ *(.rodata .rodata.* .gnu.linkonce.r.*)
+ } > RELOC_RAM
+
+ /* Global constructor and destructor arrays (length-prefixed) */
+
+ /*
+ * https://sourceware.org/binutils/docs/ld/Output-Section-Keywords.html
+ * https://gcc.gnu.org/bugzilla/show_bug.cgi?id=46770
+ */
+ .ctors : ALIGN(16) {
+ __CTOR_LIST__ = .;
+
+ LONG(((__CTOR_END__ - __CTOR_LIST__) / 4) - 2)
+ KEEP(*(SORT(.ctors.*)))
+ KEEP(*(.ctors))
+ LONG(0)
+
+ __CTOR_END__ = .;
+ } > RELOC_RAM
+ .dtors : ALIGN(16) {
+ __DTOR_LIST__ = .;
+
+ LONG(((__DTOR_END__ - __DTOR_LIST__) / 4) - 2)
+ KEEP(*(SORT(.dtors.*)))
+ KEEP(*(.dtors))
+ LONG(0)
+
+ __DTOR_END__ = .;
+ } > RELOC_RAM
+
+ /* Data and BSS sections, i.e. variables */
+
+ .data : {
+ *(.data .data.* .gnu.linkonce.d.*)
+
+ /*
+ * Merge the .bss section into the .data section, so uninitialized
+ * variables are treated as if they were initialized and preallocated.
+ * This makes DLLs unnecessarily larger (BSS values shouldn't be stored
+ * as they are always zero) but greatly simplifies the dynamic linker,
+ * as we don't have to worry about managing .bss separately from the
+ * main DLL blob.
+ */
+ __bss_start = .;
+
+ *(.bss .bss.* .gnu.linkonce.b.*)
+ *(COMMON)
+
+ . = ALIGN((. != 0) ? 4 : 1);
+ } > RELOC_RAM
+
+ /*
+ * Set _gp to point to the beginning of the GOT plus 0x7ff0, so anything
+ * within the GOT can be accessed using the $gp register as base plus a
+ * signed 16-bit immediate. Note that $gp is set to _gp in all exported
+ * functions (GCC adds the relevant code automatically).
+ */
+ HIDDEN(_gp = ALIGN(16) + 0x7ff0);
+
+ .got : {
+ *(.got)
+ } > RELOC_RAM
+
+ _end = .;
+
+ /* Dummy section */
+
+ .dummy (NOLOAD) : {
+ KEEP(*(.dummy))
+ } > RELOC_RAM
+
+ /* Remove anything flagged as link-time optimized */
+
+ /DISCARD/ : {
+ *(.gnu.lto_*)
+ }
+}
diff --git a/libpsn00b/ldscripts/exe.ld b/libpsn00b/ldscripts/exe.ld
new file mode 100644
index 0000000..3033636
--- /dev/null
+++ b/libpsn00b/ldscripts/exe.ld
@@ -0,0 +1,114 @@
+/*
+ * PSn00bSDK linker script for executables
+ * (C) 2021 spicyjpeg - MPL licensed
+ *
+ * GP-relative addressing (i.e. placing small variables in a 64 KB block and
+ * using $gp to reference them) is fully supported; the block is made up of
+ * sections .sdata and .sbss. Note that GP-relative addressing is not
+ * compatible with dynamic linking, as DLLs require GP to be unused.
+ */
+
+OUTPUT_FORMAT(elf32-littlemips)
+ENTRY(_start)
+/*STARTUP(start.o)*/
+
+MEMORY {
+ /* Mapped into KSEG0 */
+ KERNEL_RAM (rwx) : ORIGIN = 0x80000000, LENGTH = 0x010000
+ APP_RAM (rwx) : ORIGIN = 0x80010000, LENGTH = 0x1f0000
+}
+
+SECTIONS {
+ /* Text section, i.e. code and constants */
+
+ .text : {
+ __text_start = .;
+
+ *(.text .text.* .gnu.linkonce.t.*)
+ *(.plt .MIPS.stubs)
+ } > APP_RAM
+ .rodata : {
+ *(.rodata .rodata.* .gnu.linkonce.r.*)
+ } > APP_RAM
+
+ /* Global constructor and destructor arrays (length-prefixed) */
+
+ /*
+ * TODO: replace this crap with .init_array and .fini_array, which are the
+ * "modern" way of doing it without reversed arrays and weird length
+ * prefixes. That would require even more patching though.
+ *
+ * https://sourceware.org/binutils/docs/ld/Output-Section-Keywords.html
+ * https://gcc.gnu.org/bugzilla/show_bug.cgi?id=46770
+ */
+ .ctors : ALIGN(16) {
+ __CTOR_LIST__ = .;
+
+ LONG(((__CTOR_END__ - __CTOR_LIST__) / 4) - 2)
+ KEEP(*(SORT(.ctors.*)))
+ KEEP(*(.ctors))
+ LONG(0)
+
+ __CTOR_END__ = .;
+ } > APP_RAM
+ .dtors : ALIGN(16) {
+ __DTOR_LIST__ = .;
+
+ LONG(((__DTOR_END__ - __DTOR_LIST__) / 4) - 2)
+ KEEP(*(SORT(.dtors.*)))
+ KEEP(*(.dtors))
+ LONG(0)
+
+ __DTOR_END__ = .;
+ } > APP_RAM
+
+ /* Data sections, i.e. variables with default values */
+
+ .data : {
+ *(.data .data.* .gnu.linkonce.d.*)
+ } > APP_RAM
+
+ /*
+ * Set _gp to point to the beginning of .sdata plus 0x7ff0, so anything
+ * within .sdata (and .sbss) can be accessed using the $gp register as
+ * base plus a signed 16-bit immediate. Note that $gp is set to _gp on
+ * boot by _start() in the SDK.
+ */
+ HIDDEN(_gp = ALIGN(16) + 0x7ff0);
+
+ .sdata : {
+ *(.sdata .sdata.* .gnu.linkonce.s.*)
+ } > APP_RAM
+
+ /* BSS sections, i.e. uninitialized variables */
+
+ __bss_start = .;
+
+ .sbss (NOLOAD) : {
+ *(.sbss .sbss.* .gnu.linkonce.sb.*)
+ *(.scommon)
+ } > APP_RAM
+ .bss (NOLOAD) : {
+ *(.bss .bss.* .gnu.linkonce.b.*)
+ *(COMMON)
+
+ /*
+ * This crap was in the stock GCC linker script.
+ */
+ . = ALIGN((. != 0) ? 4 : 1);
+ } > APP_RAM
+
+ _end = .;
+
+ /* Dummy section */
+
+ .dummy (NOLOAD) : {
+ KEEP(*(.dummy))
+ } > APP_RAM
+
+ /* Remove anything flagged as link-time optimized */
+
+ /DISCARD/ : {
+ *(.gnu.lto_*)
+ }
+}