aboutsummaryrefslogtreecommitdiff
path: root/ld/scripttempl
diff options
context:
space:
mode:
Diffstat (limited to 'ld/scripttempl')
-rw-r--r--ld/scripttempl/elf.sc73
1 files changed, 60 insertions, 13 deletions
diff --git a/ld/scripttempl/elf.sc b/ld/scripttempl/elf.sc
index 2e75875..a6f9302 100644
--- a/ld/scripttempl/elf.sc
+++ b/ld/scripttempl/elf.sc
@@ -1,36 +1,83 @@
+#
+# Unusual variables checked by this code:
+# NOP - two byte opcode for no-op (defaults to 0)
+# DATA_ADDR - if end-of-text-plus-one-page isn't right for data start
+# OTHER_READONLY_SECTIONS - other than .text .init .ctors .rodata ...
+# (e.g., .PARISC.milli)
+# OTHER_READWRITE_SECTIONS - other than .data .bss .sdata ...
+# (e.g., .PARISC.global)
+# EXECUTABLE_SYMBOLS - symbols that must be defined for an
+# executable (e.g., _DYNAMIC_LINK)
+#
+# When adding sections, do note that the names of some sections are used
+# when specifying the start address of the next.
+#
cat <<EOF
OUTPUT_FORMAT("${OUTPUT_FORMAT}")
OUTPUT_ARCH(${ARCH})
${RELOCATING+${LIB_SEARCH_DIRS}}
-/* Do we need any of these for elf?
- ${RELOCATING+__DYNAMIC = 0;}
- ${STACKZERO+${RELOCATING+${STACKZERO}}}
- ${SHLIB_PATH+${RELOCATING+${SHLIB_PATH}}} */
+${RELOCATING+/* Do we need any of these for elf?
+ __DYNAMIC = 0; ${STACKZERO+${STACKZERO}} ${SHLIB_PATH+${SHLIB_PATH}} */}
+${RELOCATING+${EXECUTABLE_SYMBOLS}}
+${RELOCATING- /* For some reason, the Solaris linker makes bad executables
+ if gld -r is used and the intermediate file has sections starting
+ at non-zero addresses. Could be a Solaris ld bug, could be a GNU ld
+ bug. But for now assigning the zero vmas works. */}
SECTIONS
{
- .text ${RELOCATING+${TEXT_START_ADDR}}:
+ /* Read-only sections, merged into text segment: */
+ .text ${RELOCATING+${TEXT_START_ADDR}} ${RELOCATING-0} :
{
- CREATE_OBJECT_SYMBOLS
- *(.init)
*(.text)
- *(.fini)
- *(.rodata)
- ${RELOCATING+_etext = ${DATA_ALIGNMENT};}
+ CREATE_OBJECT_SYMBOLS
+ ${RELOCATING+_etext = .;}
}
- .data ${RELOCATING+${DATA_ALIGNMENT}} :
+ .init ${RELOCATING+.} ${RELOCATING-0} : { *(.init) } =${NOP-0}
+ .fini ${RELOCATING+.} ${RELOCATING-0} : { *(.fini) } =${NOP-0}
+ .ctors ${RELOCATING+.} ${RELOCATING-0} : { *(.ctors) }
+ .dtors ${RELOCATING+.} ${RELOCATING-0} : { *(.dtors) }
+ .rodata ${RELOCATING+.} ${RELOCATING-0} : { *(.rodata) }
+ .rodata1 ${RELOCATING+.} ${RELOCATING-0} : { *(.rodata1) }
+ ${RELOCATING+${OTHER_READONLY_SECTIONS}}
+ /* also: .hash .dynsym .dynstr .plt(if r/o) .rel.got */
+
+ /* Read-write section, merged into data segment: */
+ .data ${RELOCATING+
+ ${DATA_ADDR- ADDR(.rodata1)+SIZEOF(.rodata1)+${MAXPAGESIZE}}
+ }
+ ${RELOCATING-0} :
{
*(.data)
${CONSTRUCTING+CONSTRUCTORS}
${RELOCATING+_edata = .;}
}
- .bss ${RELOCATING+SIZEOF(.data) + ADDR(.data)} :
+ .data1 ${RELOCATING+.} ${RELOCATING-0} : { *(.data1) }
+ ${RELOCATING+${OTHER_READWRITE_SECTIONS}}
+ /* also (before uninitialized portion): .dynamic .got .plt(if r/w)
+ (or does .dynamic go into its own segment?) */
+ /* We want the small data sections together, so single-instruction offsets
+ can access them all, and initialized data all before uninitialized, so
+ we can shorten the on-disk segment size. */
+ .sdata ${RELOCATING+.} ${RELOCATING-0} : { *(.sdata) }
+ ${RELOCATING+__bss_start = .};
+ .sbss ${RELOCATING+.} ${RELOCATING-0} : { *(.sbss) *(.scommon) }
+ .bss ${RELOCATING+.} ${RELOCATING-0} :
{
- ${RELOCATING+ __bss_start = .};
*(.bss)
*(COMMON)
${RELOCATING+_end = . };
${RELOCATING+end = . };
}
+
+ /* Debug sections. These should never be loadable, but they must have
+ zero addresses for the debuggers to work correctly. */
+ .line 0 : { *(.line) }
+ .debug 0 : { *(.debug) }
+ .debug_sfnames 0 : { *(.debug_sfnames) }
+ .debug_srcinfo 0 : { *(.debug_srcinfo) }
+ .debug_macinfo 0 : { *(.debug_macinfo) }
+ .debug_pubnames 0 : { *(.debug_pubnames) }
+ .debug_aranges 0 : { *(.debug_aranges) }
}
EOF