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