2020-01-01 18:27:01 +10:30
|
|
|
# Copyright (C) 2014-2020 Free Software Foundation, Inc.
|
2017-10-12 21:28:30 +10:30
|
|
|
#
|
2014-08-20 10:34:58 +01:00
|
|
|
# Copying and distribution of this file, with or without modification,
|
|
|
|
# are permitted in any medium without royalty provided the copyright
|
|
|
|
# notice and this notice are preserved.
|
|
|
|
|
2009-07-29 00:25:22 +00:00
|
|
|
# MMO is not a relocateable format, and we don't want to require an
|
|
|
|
# explicit (e.g.) "-m elf64mmix" when -r is used.
|
2014-08-20 10:34:58 +01:00
|
|
|
|
2009-07-29 00:25:22 +00:00
|
|
|
test -z $RELOCATEABLE_OUTPUT_FORMAT && RELOCATEABLE_OUTPUT_FORMAT=$OUTPUT_FORMAT
|
|
|
|
test -z ${RELOCATING+0} && OUTPUT_FORMAT=$RELOCATEABLE_OUTPUT_FORMAT
|
2014-08-20 10:34:58 +01:00
|
|
|
|
2001-10-30 15:20:14 +00:00
|
|
|
cat <<EOF
|
2020-01-01 18:27:01 +10:30
|
|
|
/* Copyright (C) 2014-2020 Free Software Foundation, Inc.
|
2014-08-20 10:34:58 +01:00
|
|
|
|
|
|
|
Copying and distribution of this script, with or without modification,
|
|
|
|
are permitted in any medium without royalty provided the copyright
|
|
|
|
notice and this notice are preserved. */
|
|
|
|
|
2009-07-29 00:25:22 +00:00
|
|
|
OUTPUT_FORMAT("$OUTPUT_FORMAT")
|
2001-10-30 15:20:14 +00:00
|
|
|
OUTPUT_ARCH(mmix)
|
2009-07-29 00:25:22 +00:00
|
|
|
${RELOCATING+ENTRY(Main)}
|
2001-10-30 15:20:14 +00:00
|
|
|
SECTIONS
|
|
|
|
{
|
|
|
|
.text ${RELOCATING+ ${TEXT_START_ADDR}}:
|
|
|
|
{
|
|
|
|
*(.text)
|
|
|
|
${RELOCATING+*(.text.*)}
|
|
|
|
${RELOCATING+*(.gnu.linkonce.t*)}
|
|
|
|
${RELOCATING+*(.rodata)}
|
|
|
|
${RELOCATING+*(.rodata.*)}
|
|
|
|
${RELOCATING+*(.gnu.linkonce.r*)}
|
|
|
|
|
|
|
|
/* FIXME: Move .init, .fini, .ctors and .dtors to their own sections. */
|
|
|
|
${RELOCATING+ PROVIDE (_init_start = .);}
|
|
|
|
${RELOCATING+ PROVIDE (_init = .);}
|
2012-09-09 16:30:40 +00:00
|
|
|
${RELOCATING+ KEEP (*(SORT_NONE(.init)))}
|
2001-10-30 15:20:14 +00:00
|
|
|
${RELOCATING+ PROVIDE (_init_end = .);}
|
|
|
|
|
|
|
|
${RELOCATING+ PROVIDE (_fini_start = .);}
|
|
|
|
${RELOCATING+ PROVIDE (_fini = .);}
|
2012-09-09 16:30:40 +00:00
|
|
|
${RELOCATING+ KEEP (*(SORT_NONE(.fini)))}
|
2001-10-30 15:20:14 +00:00
|
|
|
${RELOCATING+ PROVIDE (_fini_end = .);}
|
|
|
|
|
|
|
|
/* FIXME: Align ctors, dtors, ehframe. */
|
|
|
|
${RELOCATING+ PROVIDE (_ctors_start = .);}
|
|
|
|
${RELOCATING+ PROVIDE (__ctors_start = .);}
|
|
|
|
${RELOCATING+ PROVIDE (_ctors = .);}
|
|
|
|
${RELOCATING+ PROVIDE (__ctors = .);}
|
2006-08-28 01:52:56 +00:00
|
|
|
${RELOCATING+ KEEP (*crtbegin.o(.ctors))}
|
|
|
|
${RELOCATING+ KEEP (*crtbegin?.o(.ctors))}
|
|
|
|
${RELOCATING+ KEEP (*(EXCLUDE_FILE (*crtend.o *crtend?.o) .ctors))}
|
2001-10-30 15:20:14 +00:00
|
|
|
${RELOCATING+ KEEP (*(SORT(.ctors.*)))}
|
|
|
|
${RELOCATING+ KEEP (*(.ctors))}
|
|
|
|
${RELOCATING+ PROVIDE (_ctors_end = .);}
|
|
|
|
${RELOCATING+ PROVIDE (__ctors_end = .);}
|
|
|
|
|
|
|
|
${RELOCATING+ PROVIDE (_dtors_start = .);}
|
|
|
|
${RELOCATING+ PROVIDE (__dtors_start = .);}
|
|
|
|
${RELOCATING+ PROVIDE (_dtors = .);}
|
|
|
|
${RELOCATING+ PROVIDE (__dtors = .);}
|
2006-08-28 01:52:56 +00:00
|
|
|
${RELOCATING+ KEEP (*crtbegin.o(.dtors))}
|
|
|
|
${RELOCATING+ KEEP (*crtbegin?.o(.dtors))}
|
|
|
|
${RELOCATING+ KEEP (*(EXCLUDE_FILE (*crtend.o *crtend?.o) .dtors))}
|
2001-10-30 15:20:14 +00:00
|
|
|
${RELOCATING+ KEEP (*(SORT(.dtors.*)))}
|
|
|
|
${RELOCATING+ KEEP (*(.dtors))}
|
|
|
|
${RELOCATING+ PROVIDE (_dtors_end = .);}
|
|
|
|
${RELOCATING+ PROVIDE (__dtors_end = .);}
|
|
|
|
|
|
|
|
${RELOCATING+KEEP (*(.jcr))}
|
|
|
|
${RELOCATING+KEEP (*(.eh_frame))}
|
|
|
|
${RELOCATING+*(.gcc_except_table)}
|
|
|
|
|
2010-08-31 05:11:29 +00:00
|
|
|
${RELOCATING+Main = DEFINED (Main) ? Main : (DEFINED (_start) ? _start : ADDR (.text));}
|
2001-10-30 15:20:14 +00:00
|
|
|
}
|
|
|
|
|
2012-09-09 16:30:40 +00:00
|
|
|
/* The following NOP assignment and those after .data and .bss, are
|
|
|
|
necessary to get orphan sections adopted by the .text inserted before
|
|
|
|
the following end-section symbols. An output section would also serve
|
|
|
|
this purpose, but we can't do that. */
|
|
|
|
. = .;
|
|
|
|
${RELOCATING+ PROVIDE(etext = .);}
|
|
|
|
${RELOCATING+ PROVIDE(_etext = .);}
|
|
|
|
${RELOCATING+ PROVIDE(__etext = .);}
|
2012-06-29 07:58:46 +00:00
|
|
|
|
2001-10-30 15:20:14 +00:00
|
|
|
.data ${RELOCATING+ ${DATA_ADDR}}:
|
|
|
|
{
|
|
|
|
${RELOCATING+ PROVIDE(__Sdata = .);}
|
|
|
|
|
|
|
|
*(.data);
|
|
|
|
${RELOCATING+*(.data.*)}
|
|
|
|
${RELOCATING+*(.gnu.linkonce.d*)}
|
|
|
|
}
|
2012-09-09 16:30:40 +00:00
|
|
|
. = .;
|
|
|
|
${RELOCATING+ PROVIDE(__Edata = .);}
|
|
|
|
/* Deprecated, use __Edata. */
|
|
|
|
${RELOCATING+ PROVIDE(edata = .);}
|
|
|
|
${RELOCATING+ PROVIDE(_edata = .);}
|
|
|
|
${RELOCATING+ PROVIDE(__edata = .);}
|
2001-10-30 15:20:14 +00:00
|
|
|
|
|
|
|
/* At the moment, although perhaps we should, we can't map sections
|
|
|
|
without contents to sections *with* contents due to FIXME: a BFD bug.
|
|
|
|
Anyway, the mmo back-end ignores sections without contents when
|
|
|
|
writing out sections, so this works fine. */
|
|
|
|
.bss :
|
|
|
|
{
|
|
|
|
${RELOCATING+ PROVIDE(__Sbss = .);}
|
|
|
|
${RELOCATING+ PROVIDE(__bss_start = .);}
|
|
|
|
${RELOCATING+ *(.sbss);}
|
|
|
|
${RELOCATING+ *(.bss);}
|
|
|
|
${RELOCATING+*(.bss.*)}
|
|
|
|
${RELOCATING+ *(COMMON);}
|
|
|
|
}
|
2012-09-09 16:30:40 +00:00
|
|
|
. = .;
|
|
|
|
${RELOCATING+ PROVIDE(__Ebss = .);}
|
2001-10-30 15:20:14 +00:00
|
|
|
|
|
|
|
/* Deprecated, use __Ebss or __Eall as appropriate. */
|
|
|
|
${RELOCATING+ PROVIDE(end = .);}
|
|
|
|
${RELOCATING+ PROVIDE(_end = .);}
|
|
|
|
${RELOCATING+ PROVIDE(__end = .);}
|
|
|
|
${RELOCATING+ PROVIDE(__Eall = .);}
|
|
|
|
|
2012-09-09 16:30:40 +00:00
|
|
|
.stab 0 : { *(.stab) }
|
|
|
|
.stabstr 0 : { *(.stabstr) }
|
|
|
|
.stab.excl 0 : { *(.stab.excl) }
|
|
|
|
.stab.exclstr 0 : { *(.stab.exclstr) }
|
|
|
|
.stab.index 0 : { *(.stab.index) }
|
|
|
|
.stab.indexstr 0 : { *(.stab.indexstr) }
|
2013-04-15 08:51:58 +00:00
|
|
|
EOF
|
|
|
|
|
2013-04-28 14:52:55 +00:00
|
|
|
. $srcdir/scripttempl/DWARF.sc
|
2012-09-09 16:30:40 +00:00
|
|
|
|
2013-04-15 08:51:58 +00:00
|
|
|
cat <<EOF
|
2001-10-30 15:20:14 +00:00
|
|
|
.MMIX.reg_contents :
|
|
|
|
{
|
|
|
|
/* Note that this section always has a fixed VMA - that of its
|
|
|
|
first register * 8. */
|
2002-02-01 08:24:03 +00:00
|
|
|
*(.MMIX.reg_contents.linker_allocated);
|
2001-10-30 15:20:14 +00:00
|
|
|
*(.MMIX.reg_contents);
|
|
|
|
}
|
|
|
|
|
ELF ld -r scripts
"ld -r" generally should not combine object file sections with
different names. For example, "ld -r" should not combine ".text",
".text.hot" and ".text.cold" into an output ".text" section. An
exception needs to be made for linker created sections, for example,
branch trampoline sections that might be created even for ld -r.
"ld -r" also should not define symbols in linker scripts. Any
definitions are likely to conflict with those defined at final link.
A MEMORY spec is also not needed for ld -r.
* Makefile.am (eelf32btsmip_fbsd.c, eelf32btsmipn32_fbsd.c),
(eelf32epiphany.c, eelf32epiphany_4x4.c, eelf32ltsmip_fbsd.c),
(eelf32ltsmipn32_fbsd.c, eelf32xc16x.c, eelf32xc16xl.c),
(eelf32xc16xs.c, emcorepe.c, enios2elf.c, enios2linux.c),
(eelf64btsmip_fbsd.c, eelf64ltsmip_fbsd.c): Correct dependencies.
* Makefile.in: Regenerate.
* emulparams/aarch64cloudabi.sh, * emulparams/aarch64fbsd.sh,
* emulparams/aarch64linux.sh, * emulparams/aarch64linux32.sh,
* emulparams/arc-nps.sh, * emulparams/elf32_spu.sh,
* emulparams/elf32_tic6x_le.sh, * emulparams/elf32bmip.sh,
* emulparams/elf32btsmipn32.sh, * emulparams/elf32lr5900n32.sh,
* emulparams/elf32mep.sh, * emulparams/elf32metag.sh,
* emulparams/elf64btsmip.sh, * emulparams/shelf_vxworks.sh,
* emulparams/shlelf_fd.sh, * scripttempl/DWARF.sc,
* scripttempl/alpha.sc, * scripttempl/alphavms.sc,
* scripttempl/arclinux.sc, * scripttempl/armbpabi.sc,
* scripttempl/avr.sc, * scripttempl/dlx.sc, * scripttempl/elf.sc,
* scripttempl/elf32cr16.sc, * scripttempl/elf32cr16c.sc,
* scripttempl/elf32crx.sc, * scripttempl/elf32msp430.sc,
* scripttempl/elf32msp430_3.sc, * scripttempl/elf32xc16x.sc,
* scripttempl/elf32xc16xl.sc, * scripttempl/elf32xc16xs.sc,
* scripttempl/elf64hppa.sc, * scripttempl/elf_chaos.sc,
* scripttempl/elfarc.sc, * scripttempl/elfarcv2.sc,
* scripttempl/elfd10v.sc, * scripttempl/elfd30v.sc,
* scripttempl/elfm68hc11.sc, * scripttempl/elfm68hc12.sc,
* scripttempl/elfm9s12z.sc, * scripttempl/elfmicroblaze.sc,
* scripttempl/elfxgate.sc, * scripttempl/elfxtensa.sc,
* scripttempl/epiphany_4x4.sc, * scripttempl/ft32.sc,
* scripttempl/hppaelf.sc, * scripttempl/ia64vms.sc,
* scripttempl/ip2k.sc, * scripttempl/iq2000.sc,
* scripttempl/mep.sc, * scripttempl/mmo.sc,
* scripttempl/nds32elf.sc, * scripttempl/pru.sc,
* scripttempl/sh.sc, * scripttempl/v850.sc,
* scripttempl/v850_rh850.sc, * scripttempl/visium.sc,
* scripttempl/xstormy16.sc: Condition various parts of scripts on
${RELOCATABLE} in order to prevent ld -r merging sections or
defining symbols. Remove MEMORY and VERSION definitions from
ld -r scripts too.
* testsuite/ld-elf/group2.d, * testsuite/ld-elf/group4.d,
* testsuite/ld-elf/group5.d, * testsuite/ld-elf/group6.d,
* testsuite/ld-elf/group7.d, * testsuite/ld-elf/group8a.d,
* testsuite/ld-elf/group8b.d, * testsuite/ld-elf/group9a.d,
* testsuite/ld-elf/group9b.d, * testsuite/ld-elf/pr17550a.d,
* testsuite/ld-elf/pr17550b.d,
* testsuite/ld-elf/pr17550d.d: Don't xfail cr16 and crx.
* testsuite/ld-elf/init-fini-arrays.d,
* testsuite/ld-elf/pr22677.d: Likewise, and dont' xfail mep.
2018-10-12 12:06:40 +10:30
|
|
|
${RELOCATING+/* By default, put the high end of the stack where the register stack
|
2001-10-30 15:20:14 +00:00
|
|
|
begins. They grow in opposite directions. */
|
ELF ld -r scripts
"ld -r" generally should not combine object file sections with
different names. For example, "ld -r" should not combine ".text",
".text.hot" and ".text.cold" into an output ".text" section. An
exception needs to be made for linker created sections, for example,
branch trampoline sections that might be created even for ld -r.
"ld -r" also should not define symbols in linker scripts. Any
definitions are likely to conflict with those defined at final link.
A MEMORY spec is also not needed for ld -r.
* Makefile.am (eelf32btsmip_fbsd.c, eelf32btsmipn32_fbsd.c),
(eelf32epiphany.c, eelf32epiphany_4x4.c, eelf32ltsmip_fbsd.c),
(eelf32ltsmipn32_fbsd.c, eelf32xc16x.c, eelf32xc16xl.c),
(eelf32xc16xs.c, emcorepe.c, enios2elf.c, enios2linux.c),
(eelf64btsmip_fbsd.c, eelf64ltsmip_fbsd.c): Correct dependencies.
* Makefile.in: Regenerate.
* emulparams/aarch64cloudabi.sh, * emulparams/aarch64fbsd.sh,
* emulparams/aarch64linux.sh, * emulparams/aarch64linux32.sh,
* emulparams/arc-nps.sh, * emulparams/elf32_spu.sh,
* emulparams/elf32_tic6x_le.sh, * emulparams/elf32bmip.sh,
* emulparams/elf32btsmipn32.sh, * emulparams/elf32lr5900n32.sh,
* emulparams/elf32mep.sh, * emulparams/elf32metag.sh,
* emulparams/elf64btsmip.sh, * emulparams/shelf_vxworks.sh,
* emulparams/shlelf_fd.sh, * scripttempl/DWARF.sc,
* scripttempl/alpha.sc, * scripttempl/alphavms.sc,
* scripttempl/arclinux.sc, * scripttempl/armbpabi.sc,
* scripttempl/avr.sc, * scripttempl/dlx.sc, * scripttempl/elf.sc,
* scripttempl/elf32cr16.sc, * scripttempl/elf32cr16c.sc,
* scripttempl/elf32crx.sc, * scripttempl/elf32msp430.sc,
* scripttempl/elf32msp430_3.sc, * scripttempl/elf32xc16x.sc,
* scripttempl/elf32xc16xl.sc, * scripttempl/elf32xc16xs.sc,
* scripttempl/elf64hppa.sc, * scripttempl/elf_chaos.sc,
* scripttempl/elfarc.sc, * scripttempl/elfarcv2.sc,
* scripttempl/elfd10v.sc, * scripttempl/elfd30v.sc,
* scripttempl/elfm68hc11.sc, * scripttempl/elfm68hc12.sc,
* scripttempl/elfm9s12z.sc, * scripttempl/elfmicroblaze.sc,
* scripttempl/elfxgate.sc, * scripttempl/elfxtensa.sc,
* scripttempl/epiphany_4x4.sc, * scripttempl/ft32.sc,
* scripttempl/hppaelf.sc, * scripttempl/ia64vms.sc,
* scripttempl/ip2k.sc, * scripttempl/iq2000.sc,
* scripttempl/mep.sc, * scripttempl/mmo.sc,
* scripttempl/nds32elf.sc, * scripttempl/pru.sc,
* scripttempl/sh.sc, * scripttempl/v850.sc,
* scripttempl/v850_rh850.sc, * scripttempl/visium.sc,
* scripttempl/xstormy16.sc: Condition various parts of scripts on
${RELOCATABLE} in order to prevent ld -r merging sections or
defining symbols. Remove MEMORY and VERSION definitions from
ld -r scripts too.
* testsuite/ld-elf/group2.d, * testsuite/ld-elf/group4.d,
* testsuite/ld-elf/group5.d, * testsuite/ld-elf/group6.d,
* testsuite/ld-elf/group7.d, * testsuite/ld-elf/group8a.d,
* testsuite/ld-elf/group8b.d, * testsuite/ld-elf/group9a.d,
* testsuite/ld-elf/group9b.d, * testsuite/ld-elf/pr17550a.d,
* testsuite/ld-elf/pr17550b.d,
* testsuite/ld-elf/pr17550d.d: Don't xfail cr16 and crx.
* testsuite/ld-elf/init-fini-arrays.d,
* testsuite/ld-elf/pr22677.d: Likewise, and dont' xfail mep.
2018-10-12 12:06:40 +10:30
|
|
|
PROVIDE (__Stack_start = 0x6000000000000000);}
|
2001-10-30 15:20:14 +00:00
|
|
|
|
|
|
|
/* Unfortunately, stabs are not mappable from ELF to MMO.
|
|
|
|
It can probably be fixed with some amount of work. */
|
|
|
|
/DISCARD/ :
|
2009-07-29 00:25:22 +00:00
|
|
|
{ ${RELOCATING+ *(.gnu.warning.*);} }
|
2012-09-09 16:30:40 +00:00
|
|
|
|
|
|
|
.gnu.attributes 0 : { KEEP (*(.gnu.attributes)) }
|
2001-10-30 15:20:14 +00:00
|
|
|
}
|
|
|
|
EOF
|