2d3181c7c4
The special case for .init and .fini in update_wild_statements is ineffective for .init or .fini wildcards inside other output sections. The special case needs to be on the wildcard, not the output section. This patch is belt and braces, both fixing update_wild_statements and the scripts. * scripttempl/alpha.sc, * scripttempl/armbpabi.sc, * scripttempl/crisaout.sc, * scripttempl/elf32cr16.sc, * scripttempl/elf32crx.sc, * scripttempl/elf32xc16x.sc, * scripttempl/elf32xc16xl.sc, * scripttempl/elf32xc16xs.sc, * scripttempl/elf64hppa.sc, * scripttempl/elf_chaos.sc, * scripttempl/elfarc.sc, * scripttempl/elfarcv2.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/i386beos.sc, * scripttempl/iq2000.sc, * scripttempl/mcorepe.sc, * scripttempl/mep.sc, * scripttempl/mips.sc, * scripttempl/moxie.sc, * scripttempl/pe.sc, * scripttempl/pep.sc, * scripttempl/ppcpe.sc, * scripttempl/tic4xcoff.sc, * scripttempl/tic80coff.sc, * scripttempl/v850.sc, * scripttempl/v850_rh850.sc, * scripttempl/visium.sc, * scripttempl/xstormy16.sc: Add KEEP and SORT_NONE to .init and .fini wildcards. * scripttempl/elf32xc16x.sc, * scripttempl/elf32xc16xl.sc, * scripttempl/elf32xc16xs.sc: Add .fini wildcard. * scripttempl/elf_chaos.sc: Add .init output section. * scripttempl/elfd30v.sc: Remove duplicate .init. * scripttempl/elfm68hc11.sc, * scripttempl/elfm68hc12.sc, * scripttempl/elfm9s12z.sc, * scripttempl/elfxgate.sc: Remove duplicate .init, and add .fini wildcard. * scripttempl/ppcpe.sc (INIT, FINI): Delete. * ldlang.c (update_wild_statements): Special case .init and .fini in the wildcard, not the output section.
146 lines
5.1 KiB
Scala
146 lines
5.1 KiB
Scala
# Copyright (C) 2014-2019 Free Software Foundation, Inc.
|
|
#
|
|
# 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.
|
|
|
|
cat <<EOF
|
|
/* Copyright (C) 2014-2019 Free Software Foundation, Inc.
|
|
|
|
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. */
|
|
|
|
OUTPUT_FORMAT("a.out-cris")
|
|
OUTPUT_ARCH(cris)
|
|
${RELOCATING+ENTRY (__start)}
|
|
SECTIONS
|
|
{
|
|
.text ${RELOCATING+ ${TEXT_START_ADDR}}:
|
|
{
|
|
CREATE_OBJECT_SYMBOLS;
|
|
${CONSTRUCTING+ __Stext = .;}
|
|
${RELOCATING+*(.startup)}
|
|
*(.text)
|
|
${CONSTRUCTING+__start = DEFINED(__start) ? __start :
|
|
DEFINED(_start) ? _start :
|
|
DEFINED(start) ? start :
|
|
DEFINED(.startup) ? .startup + 2 : 2;}
|
|
${RELOCATING+*(.text.*)}
|
|
${RELOCATING+*(.gnu.linkonce.t*)}
|
|
${RELOCATING+*(.rodata)}
|
|
${RELOCATING+*(.rodata.*)}
|
|
${RELOCATING+*(.gnu.linkonce.r*)}
|
|
|
|
/* Do not "provide" init-start and fini-start symbols; they might be
|
|
referred to weakly, so the linker would not override the zero
|
|
default.
|
|
FIXME: It's somewhat unexpected to have code emitted by the linker
|
|
script. Some other mechanism could probably do better. */
|
|
${CONSTRUCTING+ . = ALIGN (2);}
|
|
${CONSTRUCTING+ ___init__start = .;}
|
|
${CONSTRUCTING+ PROVIDE (___do_global_ctors = .);}
|
|
${CONSTRUCTING+ SHORT (0xe1fc); /* push srp */}
|
|
${CONSTRUCTING+ SHORT (0xbe7e);}
|
|
${CONSTRUCTING+ KEEP (*(SORT_NONE(.init)))}
|
|
${CONSTRUCTING+ SHORT (0x0d3e); /* jump [sp+] */}
|
|
${CONSTRUCTING+ PROVIDE (__init__end = .);}
|
|
${CONSTRUCTING+ PROVIDE (___init__end = .);}
|
|
|
|
${CONSTRUCTING+ . = ALIGN (2);}
|
|
${CONSTRUCTING+ ___fini__start = .;}
|
|
${CONSTRUCTING+ PROVIDE (___do_global_dtors = .);}
|
|
${CONSTRUCTING+ SHORT (0xe1fc); /* push srp */}
|
|
${CONSTRUCTING+ SHORT (0xbe7e);}
|
|
${CONSTRUCTING+ KEEP (*(SORT_NONE(.fini)))}
|
|
${CONSTRUCTING+ SHORT (0x0d3e); /* jump [sp+] */}
|
|
${CONSTRUCTING+ PROVIDE (__fini__end = .);}
|
|
${CONSTRUCTING+ ___fini__end = .;}
|
|
|
|
/* Cater to linking from ELF. */
|
|
${CONSTRUCTING+ PROVIDE(___ctors = .);}
|
|
${CONSTRUCTING+ ___elf_ctors_dtors_begin = .;}
|
|
${CONSTRUCTING+ KEEP (*crtbegin.o(.ctors))}
|
|
${CONSTRUCTING+ KEEP (*crtbegin?.o(.ctors))}
|
|
${CONSTRUCTING+ KEEP (*(EXCLUDE_FILE (*crtend.o *crtend?.o) .ctors))}
|
|
${CONSTRUCTING+ KEEP (*(SORT(.ctors.*)))}
|
|
${CONSTRUCTING+ KEEP (*(.ctors))}
|
|
${CONSTRUCTING+ PROVIDE(___ctors_end = .);}
|
|
|
|
${CONSTRUCTING+ PROVIDE(___dtors = .);}
|
|
${CONSTRUCTING+ KEEP (*crtbegin.o(.dtors))}
|
|
${CONSTRUCTING+ KEEP (*crtbegin?.o(.dtors))}
|
|
${CONSTRUCTING+ KEEP (*(EXCLUDE_FILE (*crtend.o *crtend?.o) .dtors))}
|
|
${CONSTRUCTING+ KEEP (*(SORT(.dtors.*)))}
|
|
${CONSTRUCTING+ KEEP (*(.dtors))}
|
|
${CONSTRUCTING+ PROVIDE(___dtors_end = .);}
|
|
${CONSTRUCTING+ ___elf_ctors_dtors_end = .;}
|
|
|
|
/* We include objects that force alignment of the data segment.
|
|
Unfortunately that sometimes causes a gap between .text and .data,
|
|
which is not detectable since .data does not have a start address
|
|
of itself in the a.out header. This should only matter for
|
|
testing; for production use, .data is at a "known" location.
|
|
We assume .data does not get an alignment larger than 32 bytes. */
|
|
${CONSTRUCTING+. = ALIGN (32);}
|
|
|
|
${CONSTRUCTING+ __Etext = .;}
|
|
|
|
/* Deprecated, use __Etext. */
|
|
${CONSTRUCTING+ PROVIDE(_etext = .);}
|
|
}
|
|
|
|
/* Any dot-relative start-expression (such as "ALIGN(2)", also including
|
|
the "default" .data alignment expression) will use the initial, raw
|
|
size of .text and will be incorrect if the alignment used is less
|
|
than the alignment for .text (which might depend on input and obj
|
|
format). FIXME: Seems like a bug in ld. Seems hard to fix. Seems
|
|
unimportant. */
|
|
.data :
|
|
{
|
|
${CONSTRUCTING+ __Sdata = .;}
|
|
*(.data);
|
|
${RELOCATING+*(.data.*)}
|
|
${RELOCATING+*(.gnu.linkonce.d*)}
|
|
${RELOCATING+*(.eh_frame) /* FIXME: Make .text */}
|
|
${RELOCATING+*(.gcc_except_table)}
|
|
|
|
/* See comment at ALIGN before __Etext. */
|
|
${CONSTRUCTING+. = ALIGN (32);}
|
|
|
|
${CONSTRUCTING+ __Edata = .;}
|
|
|
|
/* Deprecated, use __Edata. */
|
|
${CONSTRUCTING+ PROVIDE(_edata = .);}
|
|
}
|
|
|
|
.bss :
|
|
{
|
|
/* Deprecated, use __Sbss. */
|
|
${CONSTRUCTING+ PROVIDE(_bss_start = .);}
|
|
|
|
${CONSTRUCTING+ __Sbss = .;}
|
|
*(.bss)
|
|
${RELOCATING+*(.bss.*)}
|
|
*(COMMON)
|
|
${CONSTRUCTING+ __Ebss = .;}
|
|
|
|
/* Deprecated, use __Ebss or __Eall as appropriate. */
|
|
${CONSTRUCTING+ PROVIDE(_end = .);}
|
|
${CONSTRUCTING+ PROVIDE(__end = .);}
|
|
}
|
|
${CONSTRUCTING+ __Eall = .;}
|
|
|
|
/* Unfortunately, stabs are not mappable from ELF to a.out.
|
|
It can probably be fixed with some amount of work. */
|
|
/DISCARD/ :
|
|
{ *(.stab) *(.stab*) *(.debug) *(.debug*) *(.comment) *(.gnu.warning.*) }
|
|
|
|
/* For the rsim and xsim simulators. */
|
|
${CONSTRUCTING+ PROVIDE(__Endmem = 0x10000000);}
|
|
|
|
/* For elinux. */
|
|
${CONSTRUCTING+ PROVIDE(__Stacksize = 0);}
|
|
}
|
|
EOF
|