1# Copyright (C) 2014 Free Software Foundation, Inc. 2# 3# Copying and distribution of this file, with or without modification, 4# are permitted in any medium without royalty provided the copyright 5# notice and this notice are preserved. 6# 7# Unusual variables checked by this code: 8# NOP - four byte opcode for no-op (defaults to none) 9# NO_SMALL_DATA - no .sbss/.sbss2/.sdata/.sdata2 sections if not 10# empty. 11# SMALL_DATA_CTOR - .ctors contains small data. 12# SMALL_DATA_DTOR - .dtors contains small data. 13# DATA_ADDR - if end-of-text-plus-one-page isn't right for data start 14# INITIAL_READONLY_SECTIONS - at start of text segment 15# OTHER_READONLY_SECTIONS - other than .text .init .rodata ... 16# (e.g., .PARISC.milli) 17# OTHER_TEXT_SECTIONS - these get put in .text when relocating 18# INITIAL_READWRITE_SECTIONS - at start of data segment (after relro) 19# OTHER_READWRITE_SECTIONS - other than .data .bss .ctors .sdata ... 20# (e.g., .PARISC.global) 21# OTHER_RELRO_SECTIONS - other than .data.rel.ro ... 22# (e.g. PPC32 .fixup, .got[12]) 23# OTHER_BSS_SECTIONS - other than .bss .sbss ... 24# ATTRS_SECTIONS - at the end 25# OTHER_SECTIONS - at the end 26# EXECUTABLE_SYMBOLS - symbols that must be defined for an 27# executable (e.g., _DYNAMIC_LINK) 28# TEXT_START_ADDR - the first byte of the text segment, after any 29# headers. 30# TEXT_BASE_ADDRESS - the first byte of the text segment. 31# TEXT_START_SYMBOLS - symbols that appear at the start of the 32# .text section. 33# DATA_START_SYMBOLS - symbols that appear at the start of the 34# .data section. 35# DATA_END_SYMBOLS - symbols that appear at the end of the 36# writeable data sections. 37# OTHER_GOT_SYMBOLS - symbols defined just before .got. 38# OTHER_GOT_SECTIONS - sections just after .got. 39# OTHER_SDATA_SECTIONS - sections just after .sdata. 40# OTHER_BSS_SYMBOLS - symbols that appear at the start of the 41# .bss section besides __bss_start. 42# PLT_NEXT_DATA - .plt next to data segment when .plt is in text segment. 43# DATA_PLT - .plt should be in data segment, not text segment. 44# PLT_BEFORE_GOT - .plt just before .got when .plt is in data segement. 45# BSS_PLT - .plt should be in bss segment 46# NO_REL_RELOCS - Don't include .rel.* sections in script 47# NO_RELA_RELOCS - Don't include .rela.* sections in script 48# NON_ALLOC_DYN - Place dynamic sections after data segment. 49# TEXT_DYNAMIC - .dynamic in text segment, not data segment. 50# EMBEDDED - whether this is for an embedded system. 51# SHLIB_TEXT_START_ADDR - if set, add to SIZEOF_HEADERS to set 52# start address of shared library. 53# INPUT_FILES - INPUT command of files to always include 54# WRITABLE_RODATA - if set, the .rodata section should be writable 55# INIT_START, INIT_END - statements just before and just after 56# combination of .init sections. 57# FINI_START, FINI_END - statements just before and just after 58# combination of .fini sections. 59# STACK_ADDR - start of a .stack section. 60# OTHER_SYMBOLS - symbols to place right at the end of the script. 61# ETEXT_NAME - name of a symbol for the end of the text section, 62# normally etext. 63# SEPARATE_CODE - if set, .text and similar sections containing 64# actual machine instructions must be in wholly disjoint 65# pages from any other data, including headers 66# SEPARATE_GOTPLT - if set, .got.plt should be separate output section, 67# so that .got can be in the RELRO area. It should be set to 68# the number of bytes in the beginning of .got.plt which can be 69# in the RELRO area as well. 70# USER_LABEL_PREFIX - prefix to add to user-visible symbols. 71# RODATA_NAME, SDATA_NAME, SBSS_NAME, BSS_NAME - base parts of names 72# for standard sections, without initial "." or suffixes. 73# 74# When adding sections, do note that the names of some sections are used 75# when specifying the start address of the next. 76# 77 78# Many sections come in three flavours. There is the 'real' section, 79# like ".data". Then there are the per-procedure or per-variable 80# sections, generated by -ffunction-sections and -fdata-sections in GCC, 81# and useful for --gc-sections, which for a variable "foo" might be 82# ".data.foo". Then there are the linkonce sections, for which the linker 83# eliminates duplicates, which are named like ".gnu.linkonce.d.foo". 84# The exact correspondences are: 85# 86# Section Linkonce section 87# .text .gnu.linkonce.t.foo 88# .rodata .gnu.linkonce.r.foo 89# .data .gnu.linkonce.d.foo 90# .bss .gnu.linkonce.b.foo 91# .sdata .gnu.linkonce.s.foo 92# .sbss .gnu.linkonce.sb.foo 93# .sdata2 .gnu.linkonce.s2.foo 94# .sbss2 .gnu.linkonce.sb2.foo 95# .debug_info .gnu.linkonce.wi.foo 96# .tdata .gnu.linkonce.td.foo 97# .tbss .gnu.linkonce.tb.foo 98# .lrodata .gnu.linkonce.lr.foo 99# .ldata .gnu.linkonce.l.foo 100# .lbss .gnu.linkonce.lb.foo 101# 102# Each of these can also have corresponding .rel.* and .rela.* sections. 103 104if test -n "$NOP"; then 105 FILL="=$NOP" 106else 107 FILL= 108fi 109 110test -z "$RODATA_NAME" && RODATA_NAME=rodata 111test -z "$SDATA_NAME" && SDATA_NAME=sdata 112test -z "$SBSS_NAME" && SBSS_NAME=sbss 113test -z "$BSS_NAME" && BSS_NAME=bss 114test -z "$ENTRY" && ENTRY=${USER_LABEL_PREFIX}_start 115test -z "${BIG_OUTPUT_FORMAT}" && BIG_OUTPUT_FORMAT=${OUTPUT_FORMAT} 116test -z "${LITTLE_OUTPUT_FORMAT}" && LITTLE_OUTPUT_FORMAT=${OUTPUT_FORMAT} 117if [ -z "$MACHINE" ]; then OUTPUT_ARCH=${ARCH}; else OUTPUT_ARCH=${ARCH}:${MACHINE}; fi 118test -z "${ELFSIZE}" && ELFSIZE=32 119test -z "${ALIGNMENT}" && ALIGNMENT="${ELFSIZE} / 8" 120test "$LD_FLAG" = "N" && DATA_ADDR=. 121test -z "${ETEXT_NAME}" && ETEXT_NAME=${USER_LABEL_PREFIX}etext 122test -n "$CREATE_SHLIB$CREATE_PIE" && test -n "$SHLIB_DATA_ADDR" && COMMONPAGESIZE="" 123test -z "$CREATE_SHLIB$CREATE_PIE" && test -n "$DATA_ADDR" && COMMONPAGESIZE="" 124test -n "$RELRO_NOW" && unset SEPARATE_GOTPLT 125test -z "$ATTRS_SECTIONS" && ATTRS_SECTIONS=".gnu.attributes 0 : { KEEP (*(.gnu.attributes)) }" 126DATA_SEGMENT_ALIGN="ALIGN(${SEGMENT_SIZE}) + (. & (${MAXPAGESIZE} - 1))" 127DATA_SEGMENT_RELRO_END="" 128DATA_SEGMENT_END="" 129if test -n "${COMMONPAGESIZE}"; then 130 if [ "$ELFSIZE" = "64" ]; then 131 DATA_SEGMENT_ALIGN="ALIGN (${SEGMENT_SIZE}) - ((${MAXPAGESIZE} - .) & (${MAXPAGESIZE} - 1)); . = DATA_SEGMENT_ALIGN (${MAXPAGESIZE}, ${COMMONPAGESIZE})" 132 else 133 # For 32, we align at exactly a page boundary. 134 DATA_SEGMENT_ALIGN="ALIGN (${SEGMENT_SIZE}); . = DATA_SEGMENT_ALIGN (${MAXPAGESIZE}, ${COMMONPAGESIZE})" 135 fi 136 DATA_SEGMENT_END=". = DATA_SEGMENT_END (.);" 137 DATA_SEGMENT_RELRO_END=". = DATA_SEGMENT_RELRO_END (${SEPARATE_GOTPLT-0}, .);" 138fi 139if test -z "${INITIAL_READONLY_SECTIONS}${CREATE_SHLIB}"; then 140 INITIAL_READONLY_SECTIONS=".interp ${RELOCATING-0} : { *(.interp) }" 141fi 142if test -z "$PLT"; then 143 IPLT=".iplt ${RELOCATING-0} : { *(.iplt) }" 144 PLT=".plt ${RELOCATING-0} : { *(.plt)${IREL_IN_PLT+ *(.iplt)} } 145 ${IREL_IN_PLT-$IPLT}" 146fi 147test -n "${DATA_PLT-${BSS_PLT-text}}" && TEXT_PLT= 148if test -z "$GOT"; then 149 if test -z "$SEPARATE_GOTPLT"; then 150 GOT=".got ${RELOCATING-0} : { *(.got.plt) *(.igot.plt) *(.got) *(.igot) }" 151 else 152 GOT=".got ${RELOCATING-0} : { *(.got) *(.igot) }" 153 GOTPLT=".got.plt ${RELOCATING-0} : { *(.got.plt) *(.igot.plt) }" 154 fi 155fi 156REL_IFUNC=".rel.ifunc ${RELOCATING-0} : { *(.rel.ifunc) }" 157RELA_IFUNC=".rela.ifunc ${RELOCATING-0} : { *(.rela.ifunc) }" 158REL_IPLT=".rel.iplt ${RELOCATING-0} : 159 { 160 ${RELOCATING+${CREATE_SHLIB-PROVIDE_HIDDEN (${USER_LABEL_PREFIX}__rel_iplt_start = .);}} 161 *(.rel.iplt) 162 ${RELOCATING+${CREATE_SHLIB-PROVIDE_HIDDEN (${USER_LABEL_PREFIX}__rel_iplt_end = .);}} 163 }" 164RELA_IPLT=".rela.iplt ${RELOCATING-0} : 165 { 166 ${RELOCATING+${CREATE_SHLIB-PROVIDE_HIDDEN (${USER_LABEL_PREFIX}__rela_iplt_start = .);}} 167 *(.rela.iplt) 168 ${RELOCATING+${CREATE_SHLIB-PROVIDE_HIDDEN (${USER_LABEL_PREFIX}__rela_iplt_end = .);}} 169 }" 170DYNAMIC=".dynamic ${RELOCATING-0} : { *(.dynamic) }" 171RODATA=".${RODATA_NAME} ${RELOCATING-0} : { *(.${RODATA_NAME}${RELOCATING+ .${RODATA_NAME}.* .gnu.linkonce.r.*}) }" 172DATARELRO=".data.rel.ro : { *(.data.rel.ro.local* .gnu.linkonce.d.rel.ro.local.*) *(.data.rel.ro .data.rel.ro.* .gnu.linkonce.d.rel.ro.*) }" 173DISCARDED="/DISCARD/ : { *(.note.GNU-stack) *(.gnu_debuglink) *(.gnu.lto_*) *(.mdebug.*) }" 174if test -z "${NO_SMALL_DATA}"; then 175 SBSS=".${SBSS_NAME} ${RELOCATING-0} : 176 { 177 ${RELOCATING+${SBSS_START_SYMBOLS}} 178 ${CREATE_SHLIB+*(.${SBSS_NAME}2 .${SBSS_NAME}2.* .gnu.linkonce.sb2.*)} 179 *(.dyn${SBSS_NAME}) 180 *(.${SBSS_NAME}${RELOCATING+ .${SBSS_NAME}.* .gnu.linkonce.sb.*}) 181 *(.scommon) 182 ${RELOCATING+${SBSS_END_SYMBOLS}} 183 }" 184 SBSS2=".${SBSS_NAME}2 ${RELOCATING-0} : { *(.${SBSS_NAME}2${RELOCATING+ .${SBSS_NAME}2.* .gnu.linkonce.sb2.*}) }" 185 SDATA="/* We want the small data sections together, so single-instruction offsets 186 can access them all, and initialized data all before uninitialized, so 187 we can shorten the on-disk segment size. */ 188 .${SDATA_NAME} ${RELOCATING-0} : 189 { 190 ${RELOCATING+${SDATA_START_SYMBOLS}} 191 ${CREATE_SHLIB+*(.${SDATA_NAME}2 .${SDATA_NAME}2.* .gnu.linkonce.s2.*)} 192 *(.${SDATA_NAME}${RELOCATING+ .${SDATA_NAME}.* .gnu.linkonce.s.*}) 193 }" 194 SDATA2=".${SDATA_NAME}2 ${RELOCATING-0} : 195 { 196 ${RELOCATING+${SDATA2_START_SYMBOLS}} 197 *(.${SDATA_NAME}2${RELOCATING+ .${SDATA_NAME}2.* .gnu.linkonce.s2.*}) 198 }" 199 REL_SDATA=".rel.${SDATA_NAME} ${RELOCATING-0} : { *(.rel.${SDATA_NAME}${RELOCATING+ .rel.${SDATA_NAME}.* .rel.gnu.linkonce.s.*}) } 200 .rela.${SDATA_NAME} ${RELOCATING-0} : { *(.rela.${SDATA_NAME}${RELOCATING+ .rela.${SDATA_NAME}.* .rela.gnu.linkonce.s.*}) }" 201 REL_SBSS=".rel.${SBSS_NAME} ${RELOCATING-0} : { *(.rel.${SBSS_NAME}${RELOCATING+ .rel.${SBSS_NAME}.* .rel.gnu.linkonce.sb.*}) } 202 .rela.${SBSS_NAME} ${RELOCATING-0} : { *(.rela.${SBSS_NAME}${RELOCATING+ .rela.${SBSS_NAME}.* .rela.gnu.linkonce.sb.*}) }" 203 REL_SDATA2=".rel.${SDATA_NAME}2 ${RELOCATING-0} : { *(.rel.${SDATA_NAME}2${RELOCATING+ .rel.${SDATA_NAME}2.* .rel.gnu.linkonce.s2.*}) } 204 .rela.${SDATA_NAME}2 ${RELOCATING-0} : { *(.rela.${SDATA_NAME}2${RELOCATING+ .rela.${SDATA_NAME}2.* .rela.gnu.linkonce.s2.*}) }" 205 REL_SBSS2=".rel.${SBSS_NAME}2 ${RELOCATING-0} : { *(.rel.${SBSS_NAME}2${RELOCATING+ .rel.${SBSS_NAME}2.* .rel.gnu.linkonce.sb2.*}) } 206 .rela.${SBSS_NAME}2 ${RELOCATING-0} : { *(.rela.${SBSS_NAME}2${RELOCATING+ .rela.${SBSS_NAME}2.* .rela.gnu.linkonce.sb2.*}) }" 207else 208 NO_SMALL_DATA=" " 209fi 210if test -z "${DATA_GOT}"; then 211 if test -n "${NO_SMALL_DATA}"; then 212 DATA_GOT=" " 213 fi 214fi 215if test -z "${SDATA_GOT}"; then 216 if test -z "${NO_SMALL_DATA}"; then 217 SDATA_GOT=" " 218 fi 219fi 220test -n "$SEPARATE_GOTPLT" && SEPARATE_GOTPLT=" " 221test "${LARGE_SECTIONS}" = "yes" && REL_LARGE=" 222 .rel.ldata ${RELOCATING-0} : { *(.rel.ldata${RELOCATING+ .rel.ldata.* .rel.gnu.linkonce.l.*}) } 223 .rela.ldata ${RELOCATING-0} : { *(.rela.ldata${RELOCATING+ .rela.ldata.* .rela.gnu.linkonce.l.*}) } 224 .rel.lbss ${RELOCATING-0} : { *(.rel.lbss${RELOCATING+ .rel.lbss.* .rel.gnu.linkonce.lb.*}) } 225 .rela.lbss ${RELOCATING-0} : { *(.rela.lbss${RELOCATING+ .rela.lbss.* .rela.gnu.linkonce.lb.*}) } 226 .rel.lrodata ${RELOCATING-0} : { *(.rel.lrodata${RELOCATING+ .rel.lrodata.* .rel.gnu.linkonce.lr.*}) } 227 .rela.lrodata ${RELOCATING-0} : { *(.rela.lrodata${RELOCATING+ .rela.lrodata.* .rela.gnu.linkonce.lr.*}) }" 228test "${LARGE_SECTIONS}" = "yes" && LARGE_BSS=" 229 .lbss ${RELOCATING-0} : 230 { 231 *(.dynlbss) 232 *(.lbss${RELOCATING+ .lbss.* .gnu.linkonce.lb.*}) 233 *(LARGE_COMMON) 234 }" 235test "${LARGE_SECTIONS}" = "yes" && LARGE_SECTIONS=" 236 .lrodata ${RELOCATING-0} ${RELOCATING+ALIGN(${MAXPAGESIZE}) + (. & (${MAXPAGESIZE} - 1))} : 237 { 238 *(.lrodata${RELOCATING+ .lrodata.* .gnu.linkonce.lr.*}) 239 } 240 .ldata ${RELOCATING-0} ${RELOCATING+ALIGN(${MAXPAGESIZE}) + (. & (${MAXPAGESIZE} - 1))} : 241 { 242 *(.ldata${RELOCATING+ .ldata.* .gnu.linkonce.l.*}) 243 ${RELOCATING+. = ALIGN(. != 0 ? ${ALIGNMENT} : 1);} 244 }" 245if test "${ENABLE_INITFINI_ARRAY}" = "yes"; then 246 SORT_INIT_ARRAY="KEEP (*(SORT_BY_INIT_PRIORITY(.init_array.*) SORT_BY_INIT_PRIORITY(.ctors.*)))" 247 SORT_FINI_ARRAY="KEEP (*(SORT_BY_INIT_PRIORITY(.fini_array.*) SORT_BY_INIT_PRIORITY(.dtors.*)))" 248 CTORS_IN_INIT_ARRAY="EXCLUDE_FILE (*crtbegin.o *crtbegin*.o *crtend.o *crtend*.o $OTHER_EXCLUDE_FILES) .ctors" 249 DTORS_IN_FINI_ARRAY="EXCLUDE_FILE (*crtbegin.o *crtbegin*.o *crtend.o *crtend*.o $OTHER_EXCLUDE_FILES) .dtors" 250else 251 SORT_INIT_ARRAY="KEEP (*(SORT(.init_array.*)))" 252 SORT_FINI_ARRAY="KEEP (*(SORT(.fini_array.*)))" 253 CTORS_IN_INIT_ARRAY= 254 DTORS_IN_FINI_ARRAY= 255fi 256INIT_ARRAY=".init_array ${RELOCATING-0} : 257 { 258 KEEP (*crtbegin*.o(.init_array)) 259 ${SORT_INIT_ARRAY} 260 KEEP (*(.init_array ${CTORS_IN_INIT_ARRAY})) 261 }" 262FINI_ARRAY=".fini_array ${RELOCATING-0} : 263 { 264 KEEP (*crtbegin*.o(.fini_array)) 265 ${SORT_FINI_ARRAY} 266 KEEP (*(.fini_array ${DTORS_IN_FINI_ARRAY})) 267 }" 268CTOR=".ctors ${CONSTRUCTING-0} : 269 { 270 ${CONSTRUCTING+${CTOR_START}} 271 /* gcc uses crtbegin.o to find the start of 272 the constructors, so we make sure it is 273 first. Because this is a wildcard, it 274 doesn't matter if the user does not 275 actually link against crtbegin.o; the 276 linker won't look for a file to match a 277 wildcard. The wildcard also means that it 278 doesn't matter which directory crtbegin.o 279 is in. */ 280 281 KEEP (*crtbegin.o(.ctors)) 282 KEEP (*crtbegin*.o(.ctors)) 283 284 /* We don't want to include the .ctor section from 285 the crtend.o file until after the sorted ctors. 286 The .ctor section from the crtend file contains the 287 end of ctors marker and it must be last */ 288 289 KEEP (*(EXCLUDE_FILE (*crtend.o *crtend*.o $OTHER_EXCLUDE_FILES) .ctors)) 290 KEEP (*(SORT(.ctors.*))) 291 KEEP (*(.ctors)) 292 ${CONSTRUCTING+${CTOR_END}} 293 }" 294DTOR=".dtors ${CONSTRUCTING-0} : 295 { 296 ${CONSTRUCTING+${DTOR_START}} 297 KEEP (*crtbegin.o(.dtors)) 298 KEEP (*crtbegin*.o(.dtors)) 299 KEEP (*(EXCLUDE_FILE (*crtend.o *crtend*.o $OTHER_EXCLUDE_FILES) .dtors)) 300 KEEP (*(SORT(.dtors.*))) 301 KEEP (*(.dtors)) 302 ${CONSTRUCTING+${DTOR_END}} 303 }" 304STACK=" .stack ${RELOCATING-0}${RELOCATING+${STACK_ADDR}} : 305 { 306 ${RELOCATING+${USER_LABEL_PREFIX}_stack = .;} 307 *(.stack) 308 }" 309 310# For Android, remove SEGMENT_START. 311#TEXT_START_ADDR="SEGMENT_START(\"text-segment\", ${TEXT_START_ADDR})" 312#SHLIB_TEXT_START_ADDR="SEGMENT_START(\"text-segment\", ${SHLIB_TEXT_START_ADDR:-0})" 313TEXT_START_ADDR="${TEXT_START_ADDR}" 314SHLIB_TEXT_START_ADDR="0" 315 316if [ -z "$SEPARATE_CODE" ]; then 317 SIZEOF_HEADERS_CODE=" + SIZEOF_HEADERS" 318else 319 SIZEOF_HEADERS_CODE= 320fi 321 322# If this is for an embedded system, don't add SIZEOF_HEADERS. 323if [ -z "$EMBEDDED" ]; then 324 test -z "${TEXT_BASE_ADDRESS}" && TEXT_BASE_ADDRESS="${TEXT_START_ADDR}${SIZEOF_HEADERS_CODE}" 325else 326 test -z "${TEXT_BASE_ADDRESS}" && TEXT_BASE_ADDRESS="${TEXT_START_ADDR}" 327fi 328 329cat <<EOF 330/* Copyright (C) 2014 Free Software Foundation, Inc. 331 332 Copying and distribution of this script, with or without modification, 333 are permitted in any medium without royalty provided the copyright 334 notice and this notice are preserved. */ 335 336OUTPUT_FORMAT("${OUTPUT_FORMAT}", "${BIG_OUTPUT_FORMAT}", 337 "${LITTLE_OUTPUT_FORMAT}") 338OUTPUT_ARCH(${OUTPUT_ARCH}) 339${RELOCATING+ENTRY(${ENTRY})} 340 341${RELOCATING+${LIB_SEARCH_DIRS}} 342${RELOCATING+${EXECUTABLE_SYMBOLS}} 343${RELOCATING+${INPUT_FILES}} 344${RELOCATING- /* For some reason, the Solaris linker makes bad executables 345 if gld -r is used and the intermediate file has sections starting 346 at non-zero addresses. Could be a Solaris ld bug, could be a GNU ld 347 bug. But for now assigning the zero vmas works. */} 348 349SECTIONS 350{ 351 /* Read-only sections, merged into text segment: */ 352 ${CREATE_SHLIB-${CREATE_PIE-${RELOCATING+PROVIDE (__executable_start = ${TEXT_START_ADDR}); . = ${TEXT_BASE_ADDRESS};}}} 353 ${CREATE_SHLIB+${RELOCATING+. = ${SHLIB_TEXT_START_ADDR}${SIZEOF_HEADERS_CODE};}} 354 ${CREATE_PIE+${RELOCATING+PROVIDE (__executable_start = ${SHLIB_TEXT_START_ADDR}); . = ${SHLIB_TEXT_START_ADDR}${SIZEOF_HEADERS_CODE};}} 355EOF 356 357emit_early_ro() 358{ 359 cat <<EOF 360 ${INITIAL_READONLY_SECTIONS} 361 .note.gnu.build-id : { *(.note.gnu.build-id) } 362EOF 363} 364 365test -n "${SEPARATE_CODE}" || emit_early_ro 366 367test -n "${RELOCATING+0}" || unset NON_ALLOC_DYN 368test -z "${NON_ALLOC_DYN}" || TEXT_DYNAMIC= 369cat > ldscripts/dyntmp.$$ <<EOF 370 ${TEXT_DYNAMIC+${DYNAMIC}} 371 .hash ${RELOCATING-0} : { *(.hash) } 372 .gnu.hash ${RELOCATING-0} : { *(.gnu.hash) } 373 .dynsym ${RELOCATING-0} : { *(.dynsym) } 374 .dynstr ${RELOCATING-0} : { *(.dynstr) } 375 .gnu.version ${RELOCATING-0} : { *(.gnu.version) } 376 .gnu.version_d ${RELOCATING-0}: { *(.gnu.version_d) } 377 .gnu.version_r ${RELOCATING-0}: { *(.gnu.version_r) } 378EOF 379 380if [ "x$COMBRELOC" = x ]; then 381 COMBRELOCCAT="cat >> ldscripts/dyntmp.$$" 382else 383 COMBRELOCCAT="cat > $COMBRELOC" 384fi 385eval $COMBRELOCCAT <<EOF 386 ${INITIAL_RELOC_SECTIONS} 387 .rel.init ${RELOCATING-0} : { *(.rel.init) } 388 .rela.init ${RELOCATING-0} : { *(.rela.init) } 389 .rel.text ${RELOCATING-0} : { *(.rel.text${RELOCATING+ .rel.text.* .rel.gnu.linkonce.t.*}) } 390 .rela.text ${RELOCATING-0} : { *(.rela.text${RELOCATING+ .rela.text.* .rela.gnu.linkonce.t.*}) } 391 .rel.fini ${RELOCATING-0} : { *(.rel.fini) } 392 .rela.fini ${RELOCATING-0} : { *(.rela.fini) } 393 .rel.${RODATA_NAME} ${RELOCATING-0} : { *(.rel.${RODATA_NAME}${RELOCATING+ .rel.${RODATA_NAME}.* .rel.gnu.linkonce.r.*}) } 394 .rela.${RODATA_NAME} ${RELOCATING-0} : { *(.rela.${RODATA_NAME}${RELOCATING+ .rela.${RODATA_NAME}.* .rela.gnu.linkonce.r.*}) } 395 ${OTHER_READONLY_RELOC_SECTIONS} 396 .rel.data.rel.ro ${RELOCATING-0} : { *(.rel.data.rel.ro${RELOCATING+ .rel.data.rel.ro.* .rel.gnu.linkonce.d.rel.ro.*}) } 397 .rela.data.rel.ro ${RELOCATING-0} : { *(.rela.data.rel.ro${RELOCATING+ .rela.data.rel.ro.* .rela.gnu.linkonce.d.rel.ro.*}) } 398 .rel.data ${RELOCATING-0} : { *(.rel.data${RELOCATING+ .rel.data.* .rel.gnu.linkonce.d.*}) } 399 .rela.data ${RELOCATING-0} : { *(.rela.data${RELOCATING+ .rela.data.* .rela.gnu.linkonce.d.*}) } 400 ${OTHER_READWRITE_RELOC_SECTIONS} 401 .rel.tdata ${RELOCATING-0} : { *(.rel.tdata${RELOCATING+ .rel.tdata.* .rel.gnu.linkonce.td.*}) } 402 .rela.tdata ${RELOCATING-0} : { *(.rela.tdata${RELOCATING+ .rela.tdata.* .rela.gnu.linkonce.td.*}) } 403 .rel.tbss ${RELOCATING-0} : { *(.rel.tbss${RELOCATING+ .rel.tbss.* .rel.gnu.linkonce.tb.*}) } 404 .rela.tbss ${RELOCATING-0} : { *(.rela.tbss${RELOCATING+ .rela.tbss.* .rela.gnu.linkonce.tb.*}) } 405 .rel.ctors ${RELOCATING-0} : { *(.rel.ctors) } 406 .rela.ctors ${RELOCATING-0} : { *(.rela.ctors) } 407 .rel.dtors ${RELOCATING-0} : { *(.rel.dtors) } 408 .rela.dtors ${RELOCATING-0} : { *(.rela.dtors) } 409 .rel.got ${RELOCATING-0} : { *(.rel.got) } 410 .rela.got ${RELOCATING-0} : { *(.rela.got) } 411 ${OTHER_GOT_RELOC_SECTIONS} 412 ${REL_SDATA} 413 ${REL_SBSS} 414 ${REL_SDATA2} 415 ${REL_SBSS2} 416 .rel.${BSS_NAME} ${RELOCATING-0} : { *(.rel.${BSS_NAME}${RELOCATING+ .rel.${BSS_NAME}.* .rel.gnu.linkonce.b.*}) } 417 .rela.${BSS_NAME} ${RELOCATING-0} : { *(.rela.${BSS_NAME}${RELOCATING+ .rela.${BSS_NAME}.* .rela.gnu.linkonce.b.*}) } 418 ${REL_LARGE} 419 ${IREL_IN_PLT+$REL_IFUNC} 420 ${IREL_IN_PLT+$RELA_IFUNC} 421 ${IREL_IN_PLT-$REL_IPLT} 422 ${IREL_IN_PLT-$RELA_IPLT} 423EOF 424 425if [ -n "$COMBRELOC" ]; then 426cat >> ldscripts/dyntmp.$$ <<EOF 427 .rel.dyn ${RELOCATING-0} : 428 { 429EOF 430sed -e '/^[ ]*[{}][ ]*$/d;/:[ ]*$/d;/\.rela\./d;/__rela_iplt_/d;s/^.*: { *\(.*\)}$/ \1/' $COMBRELOC >> ldscripts/dyntmp.$$ 431cat >> ldscripts/dyntmp.$$ <<EOF 432 } 433 .rela.dyn ${RELOCATING-0} : 434 { 435EOF 436sed -e '/^[ ]*[{}][ ]*$/d;/:[ ]*$/d;/\.rel\./d;/__rel_iplt_/d;s/^.*: { *\(.*\)}/ \1/' $COMBRELOC >> ldscripts/dyntmp.$$ 437cat >> ldscripts/dyntmp.$$ <<EOF 438 } 439EOF 440fi 441 442cat >> ldscripts/dyntmp.$$ <<EOF 443 .rel.plt ${RELOCATING-0} : 444 { 445 *(.rel.plt) 446 ${IREL_IN_PLT+${RELOCATING+${CREATE_SHLIB-PROVIDE_HIDDEN (${USER_LABEL_PREFIX}__rel_iplt_start = .);}}} 447 ${IREL_IN_PLT+${RELOCATING+*(.rel.iplt)}} 448 ${IREL_IN_PLT+${RELOCATING+${CREATE_SHLIB-PROVIDE_HIDDEN (${USER_LABEL_PREFIX}__rel_iplt_end = .);}}} 449 } 450 .rela.plt ${RELOCATING-0} : 451 { 452 *(.rela.plt) 453 ${IREL_IN_PLT+${RELOCATING+${CREATE_SHLIB-PROVIDE_HIDDEN (${USER_LABEL_PREFIX}__rela_iplt_start = .);}}} 454 ${IREL_IN_PLT+${RELOCATING+*(.rela.iplt)}} 455 ${IREL_IN_PLT+${RELOCATING+${CREATE_SHLIB-PROVIDE_HIDDEN (${USER_LABEL_PREFIX}__rela_iplt_end = .);}}} 456 } 457 ${OTHER_PLT_RELOC_SECTIONS} 458EOF 459 460emit_dyn() 461{ 462 if test -z "${NO_REL_RELOCS}${NO_RELA_RELOCS}"; then 463 cat ldscripts/dyntmp.$$ 464 else 465 if test -z "${NO_REL_RELOCS}"; then 466 sed -e '/^[ ]*\.rela\.[^}]*$/,/}/d;/^[ ]*\.rela\./d;/__rela_iplt_/d' ldscripts/dyntmp.$$ 467 fi 468 if test -z "${NO_RELA_RELOCS}"; then 469 sed -e '/^[ ]*\.rel\.[^}]*$/,/}/d;/^[ ]*\.rel\./d;/__rel_iplt_/d' ldscripts/dyntmp.$$ 470 fi 471 fi 472 rm -f ldscripts/dyntmp.$$ 473} 474 475test -n "${NON_ALLOC_DYN}${SEPARATE_CODE}" || emit_dyn 476 477cat <<EOF 478 .init ${RELOCATING-0} : 479 { 480 ${RELOCATING+${INIT_START}} 481 KEEP (*(SORT_NONE(.init))) 482 ${RELOCATING+${INIT_END}} 483 } ${FILL} 484 485 ${TEXT_PLT+${PLT_NEXT_DATA-${PLT}}} 486 ${TINY_READONLY_SECTION} 487 .text ${RELOCATING-0} : 488 { 489 ${RELOCATING+${TEXT_START_SYMBOLS}} 490 ${RELOCATING+*(.text.unlikely .text.*_unlikely .text.unlikely.*)} 491 ${RELOCATING+*(.text.exit .text.exit.*)} 492 ${RELOCATING+*(.text.startup .text.startup.*)} 493 ${RELOCATING+*(.text.hot .text.hot.*)} 494 *(.text .stub${RELOCATING+ .text.* .gnu.linkonce.t.*}) 495 /* .gnu.warning sections are handled specially by elf32.em. */ 496 *(.gnu.warning) 497 ${RELOCATING+${OTHER_TEXT_SECTIONS}} 498 } ${FILL} 499 .fini ${RELOCATING-0} : 500 { 501 ${RELOCATING+${FINI_START}} 502 KEEP (*(SORT_NONE(.fini))) 503 ${RELOCATING+${FINI_END}} 504 } ${FILL} 505 ${RELOCATING+PROVIDE (__${ETEXT_NAME} = .);} 506 ${RELOCATING+PROVIDE (_${ETEXT_NAME} = .);} 507 ${RELOCATING+PROVIDE (${ETEXT_NAME} = .);} 508EOF 509 510if test -n "${SEPARATE_CODE}"; then 511 if test -n "${RODATA_ADDR}"; then 512 RODATA_ADDR="\ 513SEGMENT_START(\"rodata-segment\", ${RODATA_ADDR}) + SIZEOF_HEADERS" 514 else 515 RODATA_ADDR="ALIGN(${SEGMENT_SIZE}) + (. & (${MAXPAGESIZE} - 1))" 516 RODATA_ADDR="SEGMENT_START(\"rodata-segment\", ${RODATA_ADDR})" 517 fi 518 if test -n "${SHLIB_RODATA_ADDR}"; then 519 SHLIB_RODATA_ADDR="\ 520SEGMENT_START(\"rodata-segment\", ${SHLIB_RODATA_ADDR}) + SIZEOF_HEADERS" 521 else 522 SHLIB_RODATA_ADDR="SEGMENT_START(\"rodata-segment\", ${SHLIB_RODATA_ADDR})" 523 SHLIB_RODATA_ADDR="ALIGN(${SEGMENT_SIZE}) + (. & (${MAXPAGESIZE} - 1))" 524 fi 525 cat <<EOF 526 /* Adjust the address for the rodata segment. We want to adjust up to 527 the same address within the page on the next page up. */ 528 ${CREATE_SHLIB-${CREATE_PIE-${RELOCATING+. = ${RODATA_ADDR};}}} 529 ${CREATE_SHLIB+${RELOCATING+. = ${SHLIB_RODATA_ADDR};}} 530 ${CREATE_PIE+${RELOCATING+. = ${SHLIB_RODATA_ADDR};}} 531EOF 532 emit_early_ro 533 emit_dyn 534fi 535 536cat <<EOF 537 ${WRITABLE_RODATA-${RODATA}} 538 .${RODATA_NAME}1 ${RELOCATING-0} : { *(.${RODATA_NAME}1) } 539 ${CREATE_SHLIB-${SDATA2}} 540 ${CREATE_SHLIB-${SBSS2}} 541 ${OTHER_READONLY_SECTIONS} 542 .eh_frame_hdr : { *(.eh_frame_hdr) } 543 .eh_frame ${RELOCATING-0} : ONLY_IF_RO { KEEP (*(.eh_frame)) } 544 .gcc_except_table ${RELOCATING-0} : ONLY_IF_RO { *(.gcc_except_table 545 .gcc_except_table.*) } 546 /* These sections are generated by the Sun/Oracle C++ compiler. */ 547 .exception_ranges ${RELOCATING-0} : ONLY_IF_RO { *(.exception_ranges 548 .exception_ranges*) } 549 ${TEXT_PLT+${PLT_NEXT_DATA+${PLT}}} 550 551 /* Adjust the address for the data segment. For 32 bits we want to align 552 at exactly a page boundary to make life easier for apriori. */ 553 ${CREATE_SHLIB-${CREATE_PIE-${RELOCATING+. = ${DATA_ADDR-${DATA_SEGMENT_ALIGN}};}}} 554 ${CREATE_SHLIB+${RELOCATING+. = ${SHLIB_DATA_ADDR-${DATA_SEGMENT_ALIGN}};}} 555 ${CREATE_PIE+${RELOCATING+. = ${SHLIB_DATA_ADDR-${DATA_SEGMENT_ALIGN}};}} 556 557 /* Exception handling */ 558 .eh_frame ${RELOCATING-0} : ONLY_IF_RW { KEEP (*(.eh_frame)) } 559 .gcc_except_table ${RELOCATING-0} : ONLY_IF_RW { *(.gcc_except_table .gcc_except_table.*) } 560 .exception_ranges ${RELOCATING-0} : ONLY_IF_RW { *(.exception_ranges .exception_ranges*) } 561 562 /* Thread Local Storage sections */ 563 .tdata ${RELOCATING-0} : { *(.tdata${RELOCATING+ .tdata.* .gnu.linkonce.td.*}) } 564 .tbss ${RELOCATING-0} : { *(.tbss${RELOCATING+ .tbss.* .gnu.linkonce.tb.*})${RELOCATING+ *(.tcommon)} } 565 566 /* Ensure the __preinit_array_start label is properly aligned. We 567 could instead move the label definition inside the section, but 568 the linker would then create the section even if it turns out to 569 be empty, which isn't pretty. */ 570 ${RELOCATING+. = ALIGN(${ALIGNMENT});} 571 ${RELOCATING+${CREATE_SHLIB-PROVIDE_HIDDEN (${USER_LABEL_PREFIX}__preinit_array_start = .);}} 572 .preinit_array ${RELOCATING-0} : 573 { 574 KEEP (*(.preinit_array)) 575 } 576 ${RELOCATING+${CREATE_SHLIB-PROVIDE_HIDDEN (${USER_LABEL_PREFIX}__preinit_array_end = .);}} 577 ${RELOCATING+${CREATE_SHLIB-PROVIDE_HIDDEN (${USER_LABEL_PREFIX}__init_array_start = .);}} 578 ${RELOCATING+${INIT_ARRAY}} 579 ${RELOCATING+${CREATE_SHLIB-PROVIDE_HIDDEN (${USER_LABEL_PREFIX}__init_array_end = .);}} 580 ${RELOCATING+${CREATE_SHLIB-PROVIDE_HIDDEN (${USER_LABEL_PREFIX}__fini_array_start = .);}} 581 ${RELOCATING+${FINI_ARRAY}} 582 ${RELOCATING+${CREATE_SHLIB-PROVIDE_HIDDEN (${USER_LABEL_PREFIX}__fini_array_end = .);}} 583 ${SMALL_DATA_CTOR-${RELOCATING+${CTOR}}} 584 ${SMALL_DATA_DTOR-${RELOCATING+${DTOR}}} 585 .jcr ${RELOCATING-0} : { KEEP (*(.jcr)) } 586 587 ${RELOCATING+${DATARELRO}} 588 ${OTHER_RELRO_SECTIONS} 589 ${TEXT_DYNAMIC-${DYNAMIC}} 590 ${DATA_GOT+${RELRO_NOW+${GOT}}} 591 ${DATA_GOT+${RELRO_NOW+${GOTPLT}}} 592 ${DATA_GOT+${RELRO_NOW-${SEPARATE_GOTPLT+${GOT}}}} 593 ${RELOCATING+${DATA_SEGMENT_RELRO_END}} 594 ${INITIAL_READWRITE_SECTIONS} 595 ${DATA_GOT+${RELRO_NOW-${SEPARATE_GOTPLT-${GOT}}}} 596 ${DATA_GOT+${RELRO_NOW-${GOTPLT}}} 597 598 ${DATA_PLT+${PLT_BEFORE_GOT-${PLT}}} 599 600 .data ${RELOCATING-0} : 601 { 602 ${RELOCATING+${DATA_START_SYMBOLS}} 603 *(.data${RELOCATING+ .data.* .gnu.linkonce.d.*}) 604 ${CONSTRUCTING+SORT(CONSTRUCTORS)} 605 } 606 .data1 ${RELOCATING-0} : { *(.data1) } 607 ${WRITABLE_RODATA+${RODATA}} 608 ${OTHER_READWRITE_SECTIONS} 609 ${SMALL_DATA_CTOR+${RELOCATING+${CTOR}}} 610 ${SMALL_DATA_DTOR+${RELOCATING+${DTOR}}} 611 ${DATA_PLT+${PLT_BEFORE_GOT+${PLT}}} 612 ${SDATA_GOT+${RELOCATING+${OTHER_GOT_SYMBOLS}}} 613 ${SDATA_GOT+${GOT}} 614 ${SDATA_GOT+${OTHER_GOT_SECTIONS}} 615 ${SDATA} 616 ${OTHER_SDATA_SECTIONS} 617 ${RELOCATING+${DATA_END_SYMBOLS-${USER_LABEL_PREFIX}_edata = .; PROVIDE (${USER_LABEL_PREFIX}edata = .);}} 618 ${RELOCATING+${USER_LABEL_PREFIX}__bss_start = .;} 619 ${RELOCATING+${OTHER_BSS_SYMBOLS}} 620 ${SBSS} 621 ${BSS_PLT+${PLT}} 622 .${BSS_NAME} ${RELOCATING-0} : 623 { 624 *(.dyn${BSS_NAME}) 625 *(.${BSS_NAME}${RELOCATING+ .${BSS_NAME}.* .gnu.linkonce.b.*}) 626 *(COMMON) 627 /* Align here to ensure that the .bss section occupies space up to 628 _end. Align after .bss to ensure correct alignment even if the 629 .bss section disappears because there are no input sections. */ 630 ${RELOCATING+. = ALIGN(${ALIGNMENT});} 631 } 632 ${OTHER_BSS_SECTIONS} 633 ${LARGE_BSS_AFTER_BSS+${LARGE_BSS}} 634 ${RELOCATING+${OTHER_BSS_END_SYMBOLS}} 635 ${RELOCATING+. = ALIGN(${ALIGNMENT});} 636EOF 637 638LARGE_DATA_ADDR=". = SEGMENT_START(\"ldata-segment\", ${LARGE_DATA_ADDR-.});" 639SHLIB_LARGE_DATA_ADDR=". = SEGMENT_START(\"ldata-segment\", ${SHLIB_LARGE_DATA_ADDR-.});" 640 641 cat <<EOF 642 ${RELOCATING+${CREATE_SHLIB-${CREATE_PIE-${LARGE_DATA_ADDR}}}} 643 ${RELOCATING+${CREATE_SHLIB+${SHLIB_LARGE_DATA_ADDR}}} 644 ${RELOCATING+${CREATE_PIE+${SHLIB_LARGE_DATA_ADDR}}} 645 ${LARGE_SECTIONS} 646 ${LARGE_BSS_AFTER_BSS-${LARGE_BSS}} 647 ${RELOCATING+. = ALIGN(${ALIGNMENT});} 648 ${RELOCATING+${OTHER_END_SYMBOLS}} 649 ${RELOCATING+${END_SYMBOLS-${USER_LABEL_PREFIX}_end = .; 650 _bss_end__ = . ; __bss_end__ = . ; __end__ = . ; 651 PROVIDE (${USER_LABEL_PREFIX}end = .);}} 652 ${RELOCATING+${DATA_SEGMENT_END}} 653EOF 654 655test -z "${NON_ALLOC_DYN}" || emit_dyn 656 657cat <<EOF 658 /* Stabs debugging sections. */ 659 .stab 0 : { *(.stab) } 660 .stabstr 0 : { *(.stabstr) } 661 .stab.excl 0 : { *(.stab.excl) } 662 .stab.exclstr 0 : { *(.stab.exclstr) } 663 .stab.index 0 : { *(.stab.index) } 664 .stab.indexstr 0 : { *(.stab.indexstr) } 665 666 .comment 0 : { *(.comment) } 667 668EOF 669 670. $srcdir/scripttempl/DWARF.sc 671 672cat <<EOF 673 674 ${TINY_DATA_SECTION} 675 ${TINY_BSS_SECTION} 676 677 ${STACK_ADDR+${STACK}} 678 ${ATTRS_SECTIONS} 679 ${OTHER_SECTIONS} 680 ${RELOCATING+${OTHER_SYMBOLS}} 681 ${RELOCATING+${DISCARDED}} 682} 683EOF 684