1# This variant of elf.sc is used for ARM BPABI platforms, like Symbian 2# OS, where a separate postlinker will operated on the generated 3# executable or shared object. See elf.sc for configuration variables 4# that apply; only BPABI-specific variables will be noted here. 5 6test -z "$ENTRY" && ENTRY=_start 7test -z "${BIG_OUTPUT_FORMAT}" && BIG_OUTPUT_FORMAT=${OUTPUT_FORMAT} 8test -z "${LITTLE_OUTPUT_FORMAT}" && LITTLE_OUTPUT_FORMAT=${OUTPUT_FORMAT} 9if [ -z "$MACHINE" ]; then OUTPUT_ARCH=${ARCH}; else OUTPUT_ARCH=${ARCH}:${MACHINE}; fi 10test -z "${ELFSIZE}" && ELFSIZE=32 11test -z "${ALIGNMENT}" && ALIGNMENT="${ELFSIZE} / 8" 12test "$LD_FLAG" = "N" && DATA_ADDR=. 13test -n "$CREATE_SHLIB$CREATE_PIE" && test -n "$SHLIB_DATA_ADDR" && COMMONPAGESIZE="" 14test -z "$CREATE_SHLIB$CREATE_PIE" && test -n "$DATA_ADDR" && COMMONPAGESIZE="" 15test -n "$RELRO_NOW" && unset SEPARATE_GOTPLT 16DATA_SEGMENT_ALIGN="ALIGN(${SEGMENT_SIZE}) + (. & (${MAXPAGESIZE} - 1))" 17DATA_SEGMENT_RELRO_END="" 18DATA_SEGMENT_RELRO_GOTPLT_END="" 19DATA_SEGMENT_END="" 20if test -n "${COMMONPAGESIZE}"; then 21 DATA_SEGMENT_ALIGN="ALIGN (${SEGMENT_SIZE}) - ((${MAXPAGESIZE} - .) & (${MAXPAGESIZE} - 1)); . = DATA_SEGMENT_ALIGN (${MAXPAGESIZE}, ${COMMONPAGESIZE})" 22 DATA_SEGMENT_END=". = DATA_SEGMENT_END (.);" 23 if test -n "${SEPARATE_GOTPLT}"; then 24 DATA_SEGMENT_RELRO_GOTPLT_END=". = DATA_SEGMENT_RELRO_END (. + ${SEPARATE_GOTPLT});" 25 else 26 DATA_SEGMENT_RELRO_END=". = DATA_SEGMENT_RELRO_END (.);" 27 fi 28fi 29INTERP=".interp 0 : { *(.interp) }" 30PLT=".plt ${RELOCATING-0} : { *(.plt) }" 31RODATA=".rodata ${RELOCATING-0} : { *(.rodata${RELOCATING+ .rodata.* .gnu.linkonce.r.*}) }" 32DATARELRO=".data.rel.ro : { *(.data.rel.ro.local) *(.data.rel.ro*) }" 33STACKNOTE="/DISCARD/ : { *(.note.GNU-stack) }" 34if test -z "${NO_SMALL_DATA}"; then 35 SBSS=".sbss ${RELOCATING-0} : 36 { 37 ${RELOCATING+PROVIDE (__sbss_start = .);} 38 ${RELOCATING+PROVIDE (___sbss_start = .);} 39 *(.dynsbss) 40 *(.sbss${RELOCATING+ .sbss.* .gnu.linkonce.sb.*}) 41 *(.scommon) 42 ${RELOCATING+PROVIDE (__sbss_end = .);} 43 ${RELOCATING+PROVIDE (___sbss_end = .);} 44 }" 45 SBSS2=".sbss2 ${RELOCATING-0} : { *(.sbss2${RELOCATING+ .sbss2.* .gnu.linkonce.sb2.*}) }" 46 SDATA="/* We want the small data sections together, so single-instruction offsets 47 can access them all, and initialized data all before uninitialized, so 48 we can shorten the on-disk segment size. */ 49 .sdata ${RELOCATING-0} : 50 { 51 ${RELOCATING+${SDATA_START_SYMBOLS}} 52 *(.sdata${RELOCATING+ .sdata.* .gnu.linkonce.s.*}) 53 }" 54 SDATA2=".sdata2 ${RELOCATING-0} : { *(.sdata2${RELOCATING+ .sdata2.* .gnu.linkonce.s2.*}) }" 55 REL_SDATA=".rel.sdata ${RELOCATING-0} : { *(.rel.sdata${RELOCATING+ .rel.sdata.* .rel.gnu.linkonce.s.*}) } 56 .rela.sdata ${RELOCATING-0} : { *(.rela.sdata${RELOCATING+ .rela.sdata.* .rela.gnu.linkonce.s.*}) }" 57 REL_SBSS=".rel.sbss ${RELOCATING-0} : { *(.rel.sbss${RELOCATING+ .rel.sbss.* .rel.gnu.linkonce.sb.*}) } 58 .rela.sbss ${RELOCATING-0} : { *(.rela.sbss${RELOCATING+ .rela.sbss.* .rela.gnu.linkonce.sb.*}) }" 59 REL_SDATA2=".rel.sdata2 ${RELOCATING-0} : { *(.rel.sdata2${RELOCATING+ .rel.sdata2.* .rel.gnu.linkonce.s2.*}) } 60 .rela.sdata2 ${RELOCATING-0} : { *(.rela.sdata2${RELOCATING+ .rela.sdata2.* .rela.gnu.linkonce.s2.*}) }" 61 REL_SBSS2=".rel.sbss2 ${RELOCATING-0} : { *(.rel.sbss2${RELOCATING+ .rel.sbss2.* .rel.gnu.linkonce.sb2.*}) } 62 .rela.sbss2 ${RELOCATING-0} : { *(.rela.sbss2${RELOCATING+ .rela.sbss2.* .rela.gnu.linkonce.sb2.*}) }" 63else 64 NO_SMALL_DATA=" " 65fi 66test -n "$SEPARATE_GOTPLT" && SEPARATE_GOTPLT=" " 67CTOR=".ctors ${CONSTRUCTING-0} : 68 { 69 ${CONSTRUCTING+${CTOR_START}} 70 /* gcc uses crtbegin.o to find the start of 71 the constructors, so we make sure it is 72 first. Because this is a wildcard, it 73 doesn't matter if the user does not 74 actually link against crtbegin.o; the 75 linker won't look for a file to match a 76 wildcard. The wildcard also means that it 77 doesn't matter which directory crtbegin.o 78 is in. */ 79 80 KEEP (*crtbegin*.o(.ctors)) 81 82 /* We don't want to include the .ctor section from 83 from the crtend.o file until after the sorted ctors. 84 The .ctor section from the crtend file contains the 85 end of ctors marker and it must be last */ 86 87 KEEP (*(EXCLUDE_FILE (*crtend*.o $OTHER_EXCLUDE_FILES) .ctors)) 88 KEEP (*(SORT(.ctors.*))) 89 KEEP (*(.ctors)) 90 ${CONSTRUCTING+${CTOR_END}} 91 }" 92DTOR=".dtors ${CONSTRUCTING-0} : 93 { 94 ${CONSTRUCTING+${DTOR_START}} 95 KEEP (*crtbegin*.o(.dtors)) 96 KEEP (*(EXCLUDE_FILE (*crtend*.o $OTHER_EXCLUDE_FILES) .dtors)) 97 KEEP (*(SORT(.dtors.*))) 98 KEEP (*(.dtors)) 99 ${CONSTRUCTING+${DTOR_END}} 100 }" 101STACK=" .stack ${RELOCATING-0}${RELOCATING+${STACK_ADDR}} : 102 { 103 ${RELOCATING+_stack = .;} 104 *(.stack) 105 }" 106 107TEXT_START_ADDR="SEGMENT_START(\"text\", ${TEXT_START_ADDR})" 108SHLIB_TEXT_START_ADDR="SEGMENT_START(\"text\", ${SHLIB_TEXT_START_ADDR:-0})" 109DATA_ADDR="SEGMENT_START(\"data\", ${DATA_ADDR-${DATA_SEGMENT_ALIGN}})" 110SHLIB_DATA_ADDR="SEGMENT_START(\"data\", ${SHLIB_DATA_ADDR-${DATA_SEGMENT_ALIGN}})" 111 112# if this is for an embedded system, don't add SIZEOF_HEADERS. 113if [ -z "$EMBEDDED" ]; then 114 test -z "${TEXT_BASE_ADDRESS}" && TEXT_BASE_ADDRESS="${TEXT_START_ADDR} + SIZEOF_HEADERS" 115 SHLIB_BASE_ADDRESS="${SHLIB_TEXT_START_ADDR} + SIZEOF_HEADERS" 116else 117 test -z "${TEXT_BASE_ADDRESS}" && TEXT_BASE_ADDRESS="${TEXT_START_ADDR}" 118 SHLIB_BASE_ADDRESS="${SHLIB_TEXT_START_ADDR}" 119fi 120 121cat <<EOF 122OUTPUT_FORMAT("${OUTPUT_FORMAT}", "${BIG_OUTPUT_FORMAT}", 123 "${LITTLE_OUTPUT_FORMAT}") 124OUTPUT_ARCH(${OUTPUT_ARCH}) 125ENTRY(${ENTRY}) 126 127${RELOCATING+${LIB_SEARCH_DIRS}} 128${RELOCATING+/* Do we need any of these for elf? 129 __DYNAMIC = 0; ${STACKZERO+${STACKZERO}} ${SHLIB_PATH+${SHLIB_PATH}} */} 130${RELOCATING+${EXECUTABLE_SYMBOLS}} 131${RELOCATING+${INPUT_FILES}} 132${RELOCATING- /* For some reason, the Solaris linker makes bad executables 133 if gld -r is used and the intermediate file has sections starting 134 at non-zero addresses. Could be a Solaris ld bug, could be a GNU ld 135 bug. But for now assigning the zero vmas works. */} 136 137/* ARM's proprietary toolchain generate these symbols to match the start 138 and end of particular sections of the image. SymbianOS uses these 139 symbols. We provide them for compatibility with ARM's toolchains. 140 These symbols should be bound locally; each shared object may define 141 its own version of these symbols. */ 142 143VERSION 144{ 145 /* Give these a dummy version to work around linker lameness. 146 The name used shouldn't matter as these are all local symbols. */ 147 __GNU { 148 local: 149 Image\$\$ER_RO\$\$Base; 150 Image\$\$ER_RO\$\$Limit; 151 SHT\$\$INIT_ARRAY\$\$Base; 152 SHT\$\$INIT_ARRAY\$\$Limit; 153 .ARM.exidx\$\$Base; 154 .ARM.exidx\$\$Limit; 155 }; 156} 157 158SECTIONS 159{ 160 /* Read-only sections, merged into text segment: */ 161 ${CREATE_SHLIB-${CREATE_PIE-${RELOCATING+PROVIDE (__executable_start = ${TEXT_START_ADDR});}}} 162 163 ${CREATE_SHLIB-${CREATE_PIE-${RELOCATING+ . = ${TEXT_BASE_ADDRESS};}}} 164 ${CREATE_SHLIB+${RELOCATING+. = ${SHLIB_BASE_ADDRESS};}} 165 ${CREATE_PIE+${RELOCATING+. = ${SHLIB_BASE_ADDRESS};}} 166 167 /* Define Image\$\$ER_RO\$\$Base. */ 168 ${RELOCATING+PROVIDE (Image\$\$ER_RO\$\$Base = .);} 169 170 ${INITIAL_READONLY_SECTIONS} 171 172EOF 173cat <<EOF 174 .init ${RELOCATING-0} : 175 { 176 ${RELOCATING+${INIT_START}} 177 KEEP (*(.init)) 178 ${RELOCATING+${INIT_END}} 179 } =${NOP-0} 180 .text ${RELOCATING-0} : 181 { 182 ${RELOCATING+${TEXT_START_SYMBOLS}} 183 *(.text .stub${RELOCATING+ .text.* .gnu.linkonce.t.*}) 184 KEEP (*(.text.*personality*)) 185 /* .gnu.warning sections are handled specially by elf32.em. */ 186 *(.gnu.warning) 187 ${RELOCATING+${OTHER_TEXT_SECTIONS}} 188 } =${NOP-0} 189 .fini ${RELOCATING-0} : 190 { 191 ${RELOCATING+${FINI_START}} 192 KEEP (*(.fini)) 193 ${RELOCATING+${FINI_END}} 194 } =${NOP-0} 195 /* The SymbianOS kernel requires that the PLT go at the end of the 196 text section. */ 197 ${DATA_PLT-${BSS_PLT-${PLT}}} 198 ${RELOCATING+PROVIDE (__etext = .);} 199 ${RELOCATING+PROVIDE (_etext = .);} 200 ${RELOCATING+PROVIDE (etext = .);} 201 202 /* Define Image\$\$ER_RO\$\$Limit. */ 203 ${RELOCATING+PROVIDE (Image\$\$ER_RO\$\$Limit = .);} 204 205 ${WRITABLE_RODATA-${RODATA}} 206 .rodata1 ${RELOCATING-0} : { *(.rodata1) } 207 ${CREATE_SHLIB-${SDATA2}} 208 ${CREATE_SHLIB-${SBSS2}} 209 210 /* On SymbianOS, put .init_array and friends in the read-only 211 segment; there is no runtime relocation applied to these 212 arrays. */ 213 214 /* Ensure the __preinit_array_start label is properly aligned. We 215 could instead move the label definition inside the section, but 216 the linker would then create the section even if it turns out to 217 be empty, which isn't pretty. */ 218 ${RELOCATING+. = ALIGN(${ALIGNMENT});} 219 ${RELOCATING+${CREATE_SHLIB-PROVIDE (__preinit_array_start = .);}} 220 .preinit_array ${RELOCATING-0} : { *(.preinit_array) } 221 ${RELOCATING+${CREATE_SHLIB-PROVIDE (__preinit_array_end = .);}} 222 223 ${RELOCATING+${CREATE_SHLIB-PROVIDE (__init_array_start = .);}} 224 /* SymbianOS uses this symbol. */ 225 ${RELOCATING+PROVIDE (SHT\$\$INIT_ARRAY\$\$Base = .);} 226 .init_array ${RELOCATING-0} : { *(.init_array) } 227 /* SymbianOS uses this symbol. */ 228 ${RELOCATING+PROVIDE (SHT\$\$INIT_ARRAY\$\$Limit = .);} 229 ${RELOCATING+${CREATE_SHLIB-PROVIDE (__init_array_end = .);}} 230 231 ${RELOCATING+${CREATE_SHLIB-PROVIDE (__fini_array_start = .);}} 232 .fini_array ${RELOCATING-0} : { *(.fini_array) } 233 ${RELOCATING+${CREATE_SHLIB-PROVIDE (__fini_array_end = .);}} 234 235 ${OTHER_READONLY_SECTIONS} 236 .eh_frame_hdr : { *(.eh_frame_hdr) } 237 .eh_frame ${RELOCATING-0} : ONLY_IF_RO { KEEP (*(.eh_frame)) } 238 .gcc_except_table ${RELOCATING-0} : ONLY_IF_RO { KEEP (*(.gcc_except_table)) *(.gcc_except_table.*) } 239 240 /* Adjust the address for the data segment. We want to adjust up to 241 the same address within the page on the next page up. */ 242 ${CREATE_SHLIB-${CREATE_PIE-${RELOCATING+. = ${DATA_ADDR};}}} 243 ${CREATE_SHLIB+${RELOCATING+. = ${SHLIB_DATA_ADDR};}} 244 ${CREATE_PIE+${RELOCATING+. = ${SHLIB_DATA_ADDR};}} 245 246 /* Exception handling */ 247 .eh_frame ${RELOCATING-0} : ONLY_IF_RW { KEEP (*(.eh_frame)) } 248 .gcc_except_table ${RELOCATING-0} : ONLY_IF_RW { KEEP (*(.gcc_except_table)) *(.gcc_except_table.*) } 249 250 /* Thread Local Storage sections */ 251 .tdata ${RELOCATING-0} : { *(.tdata${RELOCATING+ .tdata.* .gnu.linkonce.td.*}) } 252 .tbss ${RELOCATING-0} : { *(.tbss${RELOCATING+ .tbss.* .gnu.linkonce.tb.*})${RELOCATING+ *(.tcommon)} } 253 254 ${RELOCATING+${CTOR}} 255 ${RELOCATING+${DTOR}} 256 .jcr ${RELOCATING-0} : { KEEP (*(.jcr)) } 257 258 ${RELOCATING+${DATARELRO}} 259 ${OTHER_RELRO_SECTIONS} 260 ${RELOCATING+${DATA_SEGMENT_RELRO_END}} 261 262 ${DATA_PLT+${PLT_BEFORE_GOT-${PLT}}} 263 264 .data ${RELOCATING-0} : 265 { 266 ${RELOCATING+${DATA_START_SYMBOLS}} 267 *(.data${RELOCATING+ .data.* .gnu.linkonce.d.*}) 268 KEEP (*(.gnu.linkonce.d.*personality*)) 269 ${CONSTRUCTING+SORT(CONSTRUCTORS)} 270 } 271 .data1 ${RELOCATING-0} : { *(.data1) } 272 ${WRITABLE_RODATA+${RODATA}} 273 ${OTHER_READWRITE_SECTIONS} 274 ${DATA_PLT+${PLT_BEFORE_GOT+${PLT}}} 275 ${CREATE_SHLIB+${SDATA2}} 276 ${CREATE_SHLIB+${SBSS2}} 277 ${SDATA} 278 ${OTHER_SDATA_SECTIONS} 279 ${RELOCATING+_edata = .;} 280 ${RELOCATING+PROVIDE (edata = .);} 281 ${RELOCATING+. = DEFINED(__bss_segment_start) ? __bss_segment_start : .;} 282 ${RELOCATING+__bss_start = .;} 283 ${RELOCATING+${OTHER_BSS_SYMBOLS}} 284 ${SBSS} 285 ${BSS_PLT+${PLT}} 286 .bss ${RELOCATING-0} : 287 { 288 *(.dynbss) 289 *(.bss${RELOCATING+ .bss.* .gnu.linkonce.b.*}) 290 *(COMMON) 291 /* Align here to ensure that the .bss section occupies space up to 292 _end. Align after .bss to ensure correct alignment even if the 293 .bss section disappears because there are no input sections. */ 294 ${RELOCATING+. = ALIGN(${ALIGNMENT});} 295 } 296 ${OTHER_BSS_SECTIONS} 297 ${RELOCATING+. = ALIGN(${ALIGNMENT});} 298 ${RELOCATING+_end = .;} 299 ${RELOCATING+${OTHER_BSS_END_SYMBOLS}} 300 ${RELOCATING+PROVIDE (end = .);} 301 ${RELOCATING+${DATA_SEGMENT_END}} 302 303 /* These sections are not mapped under the BPABI. */ 304 .dynamic 0 : { *(.dynamic) } 305 .hash 0 : { *(.hash) } 306 .dynsym 0 : { *(.dynsym) } 307 .dynstr 0 : { *(.dynstr) } 308 .gnu.version 0 : { *(.gnu.version) } 309 .gnu.version_d 0: { *(.gnu.version_d) } 310 .gnu.version_r 0: { *(.gnu.version_r) } 311 ${CREATE_SHLIB-${INTERP}} 312 313 /* Stabs debugging sections. */ 314 .stab 0 : { *(.stab) } 315 .stabstr 0 : { *(.stabstr) } 316 .stab.excl 0 : { *(.stab.excl) } 317 .stab.exclstr 0 : { *(.stab.exclstr) } 318 .stab.index 0 : { *(.stab.index) } 319 .stab.indexstr 0 : { *(.stab.indexstr) } 320 321 .comment 0 : { *(.comment) } 322 323 /* DWARF debug sections. 324 Symbols in the DWARF debugging sections are relative to the beginning 325 of the section so we begin them at 0. */ 326 327 /* DWARF 1 */ 328 .debug 0 : { *(.debug) } 329 .line 0 : { *(.line) } 330 331 /* GNU DWARF 1 extensions */ 332 .debug_srcinfo 0 : { *(.debug_srcinfo) } 333 .debug_sfnames 0 : { *(.debug_sfnames) } 334 335 /* DWARF 1.1 and DWARF 2 */ 336 .debug_aranges 0 : { *(.debug_aranges) } 337 .debug_pubnames 0 : { *(.debug_pubnames) } 338 339 /* DWARF 2 */ 340 .debug_info 0 : { *(.debug_info .gnu.linkonce.wi.*) } 341 .debug_abbrev 0 : { *(.debug_abbrev) } 342 .debug_line 0 : { *(.debug_line) } 343 .debug_frame 0 : { *(.debug_frame) } 344 .debug_str 0 : { *(.debug_str) } 345 .debug_loc 0 : { *(.debug_loc) } 346 .debug_macinfo 0 : { *(.debug_macinfo) } 347 348 /* SGI/MIPS DWARF 2 extensions */ 349 .debug_weaknames 0 : { *(.debug_weaknames) } 350 .debug_funcnames 0 : { *(.debug_funcnames) } 351 .debug_typenames 0 : { *(.debug_typenames) } 352 .debug_varnames 0 : { *(.debug_varnames) } 353 354 ${STACK_ADDR+${STACK}} 355 ${OTHER_SECTIONS} 356 ${RELOCATING+${OTHER_END_SYMBOLS}} 357 ${RELOCATING+${STACKNOTE}} 358EOF 359 360# These relocations sections are part of the read-only segment in SVR4 361# executables, but are not mapped in BPABI executables. 362if [ "x$COMBRELOC" = x ]; then 363 COMBRELOCCAT=cat 364else 365 COMBRELOCCAT="cat > $COMBRELOC" 366fi 367eval $COMBRELOCCAT <<EOF 368 .rel.init 0 : { *(.rel.init) } 369 .rela.init 0 : { *(.rela.init) } 370 .rel.text 0 : { *(.rel.text${RELOCATING+ .rel.text.* .rel.gnu.linkonce.t.*}) } 371 .rela.text 0 : { *(.rela.text${RELOCATING+ .rela.text.* .rela.gnu.linkonce.t.*}) } 372 .rel.fini 0 : { *(.rel.fini) } 373 .rela.fini 0 : { *(.rela.fini) } 374 .rel.rodata 0 : { *(.rel.rodata${RELOCATING+ .rel.rodata.* .rel.gnu.linkonce.r.*}) } 375 .rela.rodata 0 : { *(.rela.rodata${RELOCATING+ .rela.rodata.* .rela.gnu.linkonce.r.*}) } 376 ${OTHER_READONLY_RELOC_SECTIONS} 377 .rel.data.rel.ro 0 : { *(.rel.data.rel.ro${RELOCATING+*}) } 378 .rela.data.rel.ro 0 : { *(.rel.data.rel.ro${RELOCATING+*}) } 379 .rel.data 0 : { *(.rel.data${RELOCATING+ .rel.data.* .rel.gnu.linkonce.d.*}) } 380 .rela.data 0 : { *(.rela.data${RELOCATING+ .rela.data.* .rela.gnu.linkonce.d.*}) } 381 .rel.tdata 0 : { *(.rel.tdata${RELOCATING+ .rel.tdata.* .rel.gnu.linkonce.td.*}) } 382 .rela.tdata 0 : { *(.rela.tdata${RELOCATING+ .rela.tdata.* .rela.gnu.linkonce.td.*}) } 383 .rel.tbss 0 : { *(.rel.tbss${RELOCATING+ .rel.tbss.* .rel.gnu.linkonce.tb.*}) } 384 .rela.tbss 0 : { *(.rela.tbss${RELOCATING+ .rela.tbss.* .rela.gnu.linkonce.tb.*}) } 385 .rel.ctors 0 : { *(.rel.ctors) } 386 .rela.ctors 0 : { *(.rela.ctors) } 387 .rel.dtors 0 : { *(.rel.dtors) } 388 .rela.dtors 0 : { *(.rela.dtors) } 389 ${REL_SDATA} 390 ${REL_SBSS} 391 ${REL_SDATA2} 392 ${REL_SBSS2} 393 .rel.bss 0 : { *(.rel.bss${RELOCATING+ .rel.bss.* .rel.gnu.linkonce.b.*}) } 394 .rela.bss 0 : { *(.rela.bss${RELOCATING+ .rela.bss.* .rela.gnu.linkonce.b.*}) } 395 .rel.init_array 0 : { *(.rel.init_array) } 396 .rela.init_array 0 : { *(.rela.init_array) } 397 .rel.fini_array 0 : { *(.rel.fini_array) } 398 .rela.fini_array 0 : { *(.rela.fini_array) } 399EOF 400if [ -n "$COMBRELOC" ]; then 401cat <<EOF 402 .rel.dyn 0 : 403 { 404EOF 405sed -e '/^[ ]*[{}][ ]*$/d;/:[ ]*$/d;/\.rela\./d;s/^.*: { *\(.*\)}$/ \1/' $COMBRELOC 406cat <<EOF 407 } 408 .rela.dyn 0 : 409 { 410EOF 411sed -e '/^[ ]*[{}][ ]*$/d;/:[ ]*$/d;/\.rel\./d;s/^.*: { *\(.*\)}/ \1/' $COMBRELOC 412cat <<EOF 413 } 414EOF 415fi 416cat <<EOF 417 .rel.plt 0 : { *(.rel.plt) } 418 .rela.plt 0 : { *(.rela.plt) } 419 ${OTHER_PLT_RELOC_SECTIONS} 420 .rel.other 0 : { *(.rel.*) } 421 .rela.other 0 : { *(.rela.*) } 422 .reli.other 0 : { *(.reli.*) } 423} 424EOF 425