summaryrefslogtreecommitdiff
path: root/ld
diff options
context:
space:
mode:
authorYoshinori Sato <ysato@users.sourceforge.jp>2020-04-30 13:35:37 +0100
committerNick Clifton <nickc@redhat.com>2020-04-30 13:35:37 +0100
commitc578f16ef18fde35d5887909d5faaf0bd0118e9d (patch)
treefbb8db4b6c95a16b98e931d799da2896d47f4c35 /ld
parentd548f47df4d2e3d117d504a4c9977982c78a0556 (diff)
downloadbinutils-gdb-c578f16ef18fde35d5887909d5faaf0bd0118e9d.tar.gz
ld: Add rx-linux emulation. gas: Change ELF flags initial value in rx-linux
ld * emulparams/elf32rx_linux.sh: New rx-linux emulation. * emultempl/rxlinux.em: New. * configure.tgt: Add rx-linux. * Makefile.am: Add eelf32rx_linux.c * Makefile.in: Regenerate. gas * config/tc-rx.c (elf_flags): Reset default value. (md_parse_option): For rx-elf Initialize elf_flags with RX_ABI.
Diffstat (limited to 'ld')
-rw-r--r--ld/ChangeLog8
-rw-r--r--ld/Makefile.am2
-rw-r--r--ld/Makefile.in2
-rw-r--r--ld/configure.tgt2
-rw-r--r--ld/emulparams/elf32rx_linux.sh17
-rw-r--r--ld/emultempl/rxlinux.em42
6 files changed, 73 insertions, 0 deletions
diff --git a/ld/ChangeLog b/ld/ChangeLog
index 43825ee4bbc..a8a5fdfcaf2 100644
--- a/ld/ChangeLog
+++ b/ld/ChangeLog
@@ -1,3 +1,11 @@
+2020-04-30 Yoshinori Sato <ysato@users.sourceforge.jp>
+
+ * emulparams/elf32rx_linux.sh: New rx-linux emulation.
+ * emultempl/rxlinux.em: New.
+ * configure.tgt: Add rx-linux.
+ * Makefile.am: Add eelf32rx_linux.c
+ * Makefile.in: Regenerate.
+
2020-04-29 Max Filippov <jcmvbkbc@gmail.com>
* testsuite/ld-xtensa/relax-diff1.d: New test definition.
diff --git a/ld/Makefile.am b/ld/Makefile.am
index a64899fc091..e3ef6865c00 100644
--- a/ld/Makefile.am
+++ b/ld/Makefile.am
@@ -277,6 +277,7 @@ ALL_EMULATION_SOURCES = \
eelf32lriscv_ilp32.c \
eelf32rl78.c \
eelf32rx.c \
+ eelf32rx_linux.c \
eelf32tilegx.c \
eelf32tilegx_be.c \
eelf32tilepro.c \
@@ -766,6 +767,7 @@ $(ALL_EMULATION_SOURCES) $(ALL_64_EMULATION_SOURCES): $(GEN_DEPENDS)
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/eelf32lriscv_ilp32.Pc@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/eelf32rl78.Pc@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/eelf32rx.Pc@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/eelf32rx_linux.Pc@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/eelf32tilegx.Pc@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/eelf32tilegx_be.Pc@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/eelf32tilepro.Pc@am__quote@
diff --git a/ld/Makefile.in b/ld/Makefile.in
index b34455b1f86..51fdd964ccb 100644
--- a/ld/Makefile.in
+++ b/ld/Makefile.in
@@ -767,6 +767,7 @@ ALL_EMULATION_SOURCES = \
eelf32lriscv_ilp32.c \
eelf32rl78.c \
eelf32rx.c \
+ eelf32rx_linux.c \
eelf32tilegx.c \
eelf32tilegx_be.c \
eelf32tilepro.c \
@@ -1346,6 +1347,7 @@ distclean-compile:
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/eelf32ppcwindiss.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/eelf32rl78.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/eelf32rx.Po@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/eelf32rx_linux.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/eelf32tilegx.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/eelf32tilegx_be.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/eelf32tilepro.Po@am__quote@
diff --git a/ld/configure.tgt b/ld/configure.tgt
index ced5d1f9924..0b6ee8bc874 100644
--- a/ld/configure.tgt
+++ b/ld/configure.tgt
@@ -775,6 +775,8 @@ rs6000-*-aix*) targ_emul=aixrs6
;;
rl78-*-*) targ_emul=elf32rl78
;;
+rx-*-linux*) targ_emul=elf32rx_linux
+ ;;
rx-*-*) targ_emul=elf32rx
;;
s12z-*-*) targ_emul=m9s12zelf
diff --git a/ld/emulparams/elf32rx_linux.sh b/ld/emulparams/elf32rx_linux.sh
new file mode 100644
index 00000000000..3abe4165d56
--- /dev/null
+++ b/ld/emulparams/elf32rx_linux.sh
@@ -0,0 +1,17 @@
+MACHINE=
+SCRIPT_NAME=elf
+OUTPUT_FORMAT="elf32-rx-linux"
+# See also `include/elf/rx.h'
+TEXT_START_ADDR=0x10000000
+ARCH=rx
+ENTRY=start
+EMBEDDED=yes
+TEMPLATE_NAME=elf
+EXTRA_EM_FILE=rxlinux
+ELFSIZE=32
+MAXPAGESIZE=256
+
+STACK_ADDR="(DEFINED(__stack) ? __stack : 0xbffffffc)"
+STACK_SENTINEL="LONG(0xdeaddead)"
+# We do not need .stack for shared library.
+test -n "$CREATE_SHLIB" && unset STACK_ADDR
diff --git a/ld/emultempl/rxlinux.em b/ld/emultempl/rxlinux.em
new file mode 100644
index 00000000000..ee036a17dd2
--- /dev/null
+++ b/ld/emultempl/rxlinux.em
@@ -0,0 +1,42 @@
+# This shell script emits a C file. -*- C -*-
+# Copyright (C) 2020 Free Software Foundation, Inc.
+#
+# This file is part of the GNU Binutils.
+#
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
+# MA 02110-1301, USA.
+#
+
+# This file is sourced from elf.em, and defines extra rx-elf
+# specific routines.
+#
+test -z "$TARGET2_TYPE" && TARGET2_TYPE="rel"
+fragment <<EOF
+
+#include "elf32-rx.h"
+
+/* This is a convenient point to tell BFD about target specific flags.
+ After the output has been created, but before inputs are read. */
+static void
+rx_linux_create_output_section_statements (void)
+{
+ extern void bfd_elf32_rx_set_target_flags (bfd_boolean, bfd_boolean);
+
+ bfd_elf32_rx_set_target_flags (FALSE, FALSE);
+}
+
+EOF
+LDEMUL_CREATE_OUTPUT_SECTION_STATEMENTS=rx_linux_create_output_section_statements
+