2024-01-04 19:52:08 +08:00
|
|
|
# Copyright (C) 2014-2024 Free Software Foundation, Inc.
|
2017-10-12 18:58:30 +08:00
|
|
|
#
|
2014-08-20 17:34:58 +08: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.
|
|
|
|
|
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 09:36:40 +08:00
|
|
|
# Using an empty script for ld -r is better than mashing together
|
|
|
|
# sections. This hack likely leaves ld -Ur broken.
|
|
|
|
test -n "${RELOCATING}" || exit 0
|
2002-07-17 22:15:52 +08:00
|
|
|
cat << EOF
|
2024-01-04 19:52:08 +08:00
|
|
|
/* Copyright (C) 2014-2024 Free Software Foundation, Inc.
|
2014-08-20 17:34:58 +08: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. */
|
|
|
|
|
2002-07-17 22:15:52 +08:00
|
|
|
OUTPUT_FORMAT("elf32-ip2k", "elf32-ip2k", "elf32-ip2k")
|
|
|
|
OUTPUT_ARCH(ip2k)
|
2008-02-18 22:53:44 +08:00
|
|
|
${RELOCATING+ENTRY(_start)}
|
2002-07-17 22:15:52 +08:00
|
|
|
SEARCH_DIR(.);
|
|
|
|
|
|
|
|
/* IP2022 default linker script. */
|
|
|
|
|
|
|
|
MEMORY
|
|
|
|
{
|
|
|
|
D_GPR : org = 0x01000080, len = 128
|
2017-10-12 18:58:30 +08:00
|
|
|
D_RAM : org = 0x01000100, len = 4K - 256
|
|
|
|
P_RAM : org = 0x02000000, len = 16K
|
|
|
|
P_ROM : org = 0x02010000, len = 64K - 32
|
|
|
|
P_RESET : org = 0x0201FFE0, len = 32
|
|
|
|
P_CONFIG : org = 0x02020000, len = 128
|
2002-07-17 22:15:52 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
SECTIONS
|
|
|
|
{
|
|
|
|
/* Allocated memory end markers
|
2016-11-26 04:01:52 +08:00
|
|
|
(initialized to start of appropriate memory address). */
|
2002-07-17 22:15:52 +08:00
|
|
|
__data_end = 0x01000100;
|
|
|
|
__pram_end = 0x02000000;
|
|
|
|
__flash_end = 0x02010000;
|
|
|
|
|
|
|
|
/* Global general purpose registers in direct addressing range. */
|
|
|
|
.gpr 0x01000080 :
|
|
|
|
{
|
|
|
|
*(.gpr)
|
|
|
|
} >D_GPR
|
|
|
|
|
|
|
|
/* Pre-allocated, pre-initialized data memory. */
|
|
|
|
__data_run_begin = __data_end;
|
|
|
|
__data_load_begin = (__flash_end + 1) & 0xFFFFFFFE;
|
|
|
|
.data __data_run_begin : AT (__data_load_begin)
|
|
|
|
{
|
|
|
|
* (.data);
|
|
|
|
* (.rodata)
|
|
|
|
} >D_RAM
|
|
|
|
__data_run_end = __data_run_begin + SIZEOF(.data);
|
|
|
|
__data_load_end = __data_load_begin + SIZEOF(.data);
|
|
|
|
__data_end = __data_run_end;
|
|
|
|
__flash_end = __data_load_end;
|
|
|
|
|
|
|
|
/* Pre-allocated, uninitialized data memory. */
|
|
|
|
__bss_begin = __data_end;
|
|
|
|
.bss __bss_begin :
|
|
|
|
{
|
|
|
|
* (.bss)
|
|
|
|
} >D_RAM
|
|
|
|
__bss_end = __bss_begin + SIZEOF(.bss);
|
|
|
|
__data_end = __bss_end;
|
|
|
|
|
|
|
|
/* Pre-allocated PRAM data memory. */
|
|
|
|
__pram_data_begin = (__pram_end + 1) & 0xFFFFFFFE;
|
|
|
|
.pram_data __pram_data_begin :
|
|
|
|
{
|
|
|
|
* (.pram_data)
|
|
|
|
} >P_RAM
|
|
|
|
__pram_data_end = __pram_data_begin + SIZEOF(.pram_data);
|
|
|
|
__pram_end = __pram_data_end;
|
|
|
|
|
|
|
|
/* PRAM code. */
|
|
|
|
__pram_run_begin = (__pram_end + 1) & 0xFFFFFFFE;
|
|
|
|
__pram_load_begin = (__flash_end + 1) & 0xFFFFFFFE;
|
|
|
|
.pram __pram_run_begin : AT (__pram_load_begin)
|
|
|
|
{
|
|
|
|
* (.pram)
|
|
|
|
} >P_RAM
|
|
|
|
__pram_run_end = __pram_run_begin + SIZEOF(.pram);
|
|
|
|
__pram_load_end = __pram_load_begin + SIZEOF(.pram);
|
|
|
|
|
|
|
|
__pram_load_shift = ((__pram_run_begin - __pram_load_begin) & 0x1FFFF) | 0x02000000;
|
|
|
|
__pram_end = __pram_run_end;
|
|
|
|
__flash_end = __pram_load_end;
|
|
|
|
|
|
|
|
/* PRAM overlay code. */
|
|
|
|
__pram_overlay_run_start = (__pram_end + 1) & 0xFFFFFFFE;
|
2017-10-12 18:58:30 +08:00
|
|
|
__pram_overlay_load_start = (__flash_end + 1) & 0xFFFFFFFE;
|
2002-07-17 22:15:52 +08:00
|
|
|
OVERLAY __pram_overlay_run_start : AT (__pram_overlay_load_start)
|
|
|
|
{
|
|
|
|
.pram1 { */overlay1/* (.pram); * (.pram1) }
|
|
|
|
.pram2 { */overlay2/* (.pram); * (.pram2) }
|
|
|
|
} >P_RAM
|
|
|
|
__pram_overlay_run_end = .;
|
|
|
|
__pram_overlay_load_end = __pram_overlay_load_start + SIZEOF(.pram1) + SIZEOF(.pram2);
|
|
|
|
__pram_end = __pram_overlay_run_end;
|
|
|
|
__flash_end = __pram_overlay_load_end;
|
|
|
|
|
|
|
|
/* Flash code. */
|
|
|
|
__text_begin = (__flash_end + 1) & 0xFFFFFFFE;
|
|
|
|
.text __text_begin :
|
|
|
|
{
|
|
|
|
* (.text);
|
|
|
|
* (.text.libgcc)
|
|
|
|
} >P_ROM = 0xffff
|
|
|
|
__text_end = __text_begin + SIZEOF(.text);
|
|
|
|
__flash_end = __text_end;
|
|
|
|
|
|
|
|
/* Strings. */
|
|
|
|
__strings_begin = (__flash_end + 1) & 0xFFFFFFFE;
|
|
|
|
.strings __strings_begin :
|
|
|
|
{
|
|
|
|
* (strings);
|
|
|
|
* (.progmem.data)
|
|
|
|
} >P_ROM = 0xffff
|
|
|
|
__strings_end = __strings_begin + SIZEOF (.strings);
|
|
|
|
__flash_end = __strings_end;
|
|
|
|
|
|
|
|
.ctors : { * (.ctors) } > P_ROM
|
|
|
|
.dtors : { * (.dtors) } > P_ROM
|
|
|
|
|
|
|
|
/* Reset code. */
|
|
|
|
.reset : { * (.reset) } >P_RESET = 0xffff
|
|
|
|
|
|
|
|
/* Configuration block. */
|
|
|
|
.config : { * (.config) } >P_CONFIG = 0xffff
|
|
|
|
|
|
|
|
/* Stack. */
|
|
|
|
PROVIDE (__stack = 0x01000FFF);
|
|
|
|
|
2013-04-15 16:51:58 +08:00
|
|
|
EOF
|
|
|
|
|
2023-03-16 14:40:07 +08:00
|
|
|
source_sh $srcdir/scripttempl/misc-sections.sc
|
|
|
|
source_sh $srcdir/scripttempl/DWARF.sc
|
2013-04-15 16:51:58 +08:00
|
|
|
|
|
|
|
cat <<EOF
|
2002-07-17 22:15:52 +08:00
|
|
|
}
|
|
|
|
EOF
|