* emulparams/elf64alpha.sh (EXTRA_EM_FILE): Define.
authorAlan Modra <amodra@gmail.com>
Sun, 2 Mar 2003 22:07:10 +0000 (22:07 +0000)
committerAlan Modra <amodra@gmail.com>
Sun, 2 Mar 2003 22:07:10 +0000 (22:07 +0000)
(PARSE_AND_LIST_PROLOGUE, PARSE_AND_LIST_LONGOPTS,
PARSE_AND_LIST_OPTIONS, PARSE_AND_LIST_ARGS_CASES,
PARSE_AND_LIST_EPILOGUE): Don't define.
* emultempl/alphaelf.em: New file.

ld/ChangeLog
ld/emulparams/elf64alpha.sh
ld/emultempl/alphaelf.em [new file with mode: 0644]

index 73746d6f70c94907f1a0aece335171685a3347f3..7360588f84231c51fdb1e6c7bd221659d41f393a 100644 (file)
@@ -1,3 +1,11 @@
+2003-03-03  Alan Modra  <amodra@bigpond.net.au>
+
+       * emulparams/elf64alpha.sh (EXTRA_EM_FILE): Define.
+       (PARSE_AND_LIST_PROLOGUE, PARSE_AND_LIST_LONGOPTS,
+       PARSE_AND_LIST_OPTIONS, PARSE_AND_LIST_ARGS_CASES,
+       PARSE_AND_LIST_EPILOGUE): Don't define.
+       * emultempl/alphaelf.em: New file.
+
 2003-03-01  Alan Modra  <amodra@bigpond.net.au>
 
        * ldemul.c: Include getopt.h.
index 3dd28ef58c00e04c1cd2d9b65885b051154c795c..2d16e9caba60eb0bc173cf91e1fe782f5659e5ae 100644 (file)
@@ -2,6 +2,7 @@ ENTRY=_start
 SCRIPT_NAME=elf
 ELFSIZE=64
 TEMPLATE_NAME=elf32
+EXTRA_EM_FILE=alphaelf
 OUTPUT_FORMAT="elf64-alpha"
 TEXT_START_ADDR="0x120000000"
 MAXPAGESIZE=0x10000
@@ -17,54 +18,3 @@ NOP=0x0000fe2f1f04ff47               # unop; nop
 
 OTHER_READONLY_SECTIONS="
   .reginfo      ${RELOCATING-0} : { *(.reginfo) }"
-
-# This code gets inserted into the generic elf32.sc linker script
-# and allows us to define our own command line switches.
-PARSE_AND_LIST_PROLOGUE='
-#define OPTION_TASO            300
-/* Set the start address as in the Tru64 ld */
-#define ALPHA_TEXT_START_32BIT 0x12000000
-
-static int elf64alpha_32bit = 0;
-
-struct ld_emulation_xfer_struct ld_elf64alpha_emulation;
-static void gld_elf64alpha_finish PARAMS ((void));
-'
-
-PARSE_AND_LIST_LONGOPTS='
-  {"taso", no_argument, NULL, OPTION_TASO},
-'
-
-PARSE_AND_LIST_OPTIONS='
-  fprintf (file, _("  -taso\t\t\tLoad executable in the lower 31-bit addressable\n"));
-  fprintf (file, _("\t\t\t  virtual address range\n"));
-'
-
-PARSE_AND_LIST_ARGS_CASES='
-    case EOF:
-      if (elf64alpha_32bit && !link_info.shared && !link_info.relocateable)
-       {
-         lang_section_start (".interp",
-                             exp_binop ('\''+'\'',
-                                        exp_intop (ALPHA_TEXT_START_32BIT),
-                                        exp_nameop (SIZEOF_HEADERS, NULL)));
-         ld_elf64alpha_emulation.finish = gld_elf64alpha_finish;
-       }
-      return 0;
-
-    case OPTION_TASO:
-      elf64alpha_32bit = 1;
-      break;
-'
-
-PARSE_AND_LIST_EPILOGUE='
-#include "elf/internal.h"
-#include "elf/alpha.h"
-#include "elf-bfd.h"
-
-static void
-gld_elf64alpha_finish()
-{
-  elf_elfheader (output_bfd)->e_flags |= EF_ALPHA_32BIT;
-}
-'
diff --git a/ld/emultempl/alphaelf.em b/ld/emultempl/alphaelf.em
new file mode 100644 (file)
index 0000000..4ff83cb
--- /dev/null
@@ -0,0 +1,83 @@
+# This shell script emits a C file. -*- C -*-
+#   Copyright 2003 Free Software Foundation, Inc.
+#
+# This file is part of GLD, the Gnu Linker.
+#
+# 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 2 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+#
+
+# This file is sourced from elf32.em, and defines extra alpha
+# specific routines.
+#
+cat >>e${EMULATION_NAME}.c <<EOF
+
+#include "elf/internal.h"
+#include "elf/alpha.h"
+#include "elf-bfd.h"
+
+static void alpha_after_parse PARAMS ((void));
+static void alpha_finish PARAMS ((void));
+
+static int elf64alpha_32bit = 0;
+
+/* Set the start address as in the Tru64 ld.  */
+#define ALPHA_TEXT_START_32BIT 0x12000000
+
+static void
+alpha_after_parse ()
+{
+  if (elf64alpha_32bit && !link_info.shared && !link_info.relocateable)
+    lang_section_start (".interp",
+                       exp_binop ('+',
+                                  exp_intop (ALPHA_TEXT_START_32BIT),
+                                  exp_nameop (SIZEOF_HEADERS, NULL)));
+}
+
+static void
+alpha_finish ()
+{
+  if (elf64alpha_32bit)
+    elf_elfheader (output_bfd)->e_flags |= EF_ALPHA_32BIT;
+
+  gld${EMULATION_NAME}_finish ();
+}
+EOF
+
+# Define some shell vars to insert bits of code into the standard elf
+# parse_args and list_options functions.
+#
+PARSE_AND_LIST_PROLOGUE='
+#define OPTION_TASO            300
+'
+
+PARSE_AND_LIST_LONGOPTS='
+  {"taso", no_argument, NULL, OPTION_TASO},
+'
+
+PARSE_AND_LIST_OPTIONS='
+  fprintf (file, _("  -taso\t\t\tLoad executable in the lower 31-bit addressable\n"));
+  fprintf (file, _("\t\t\t  virtual address range\n"));
+'
+
+PARSE_AND_LIST_ARGS_CASES='
+    case OPTION_TASO:
+      elf64alpha_32bit = 1;
+      break;
+'
+
+# Put these extra alpha routines in ld_${EMULATION_NAME}_emulation
+#
+LDEMUL_AFTER_PARSE=alpha_after_parse
+LDEMUL_FINISH=alpha_finish