* Makefile.am (ALL_64_EMULATIONS): Add eelf64bmip.
authorMark Mitchell <mark@codesourcery.com>
Thu, 8 Jul 1999 00:22:51 +0000 (00:22 +0000)
committerMark Mitchell <mark@codesourcery.com>
Thu, 8 Jul 1999 00:22:51 +0000 (00:22 +0000)
(eelf64bmip): New target.
* Makefile.in: Regenerated.
* configure.tgt (mips-sgi-irix6*): Add 64-bit emulation.
* emulparams/elf64bmip.sh: New file.

ld/ChangeLog
ld/Makefile.am
ld/Makefile.in
ld/configure.tgt
ld/emulparams/elf64bmip.sh [new file with mode: 0755]

index 58e5b8a524eea5bae146808a7c351210b8b119e7..a3065999502c3128048578ac7e3e6eca832041fa 100644 (file)
@@ -1,3 +1,11 @@
+1999-07-07  Mark Mitchell  <mark@codesourcery.com>
+
+       * Makefile.am (ALL_64_EMULATIONS): Add eelf64bmip.
+       (eelf64bmip): New target.
+       * Makefile.in: Regenerated.
+       * configure.tgt (mips-sgi-irix6*): Add 64-bit emulation.
+       * emulparams/elf64bmip.sh: New file.
+
 1999-07-05  Nick Clifton  <nickc@cygnus.com>
 
        * emultempl/pe.em (after_open): Abort if input format is ARM and
index a84eec3295667b30efb6611cc94f1e23789cb0ec..6113e8d58c280f39e2c57678ca8fc99078998675 100644 (file)
@@ -208,7 +208,8 @@ ALL_EMULATIONS = \
 
 ALL_64_EMULATIONS = \
        eelf64_sparc.o \
-       eelf64alpha.o
+       eelf64alpha.o \
+       eelf64bmip.o
 
 ALL_EMUL_EXTRA_OFILES = \
        pe-dll.o \
@@ -382,6 +383,9 @@ eelf64alpha.c: $(srcdir)/emulparams/elf64alpha.sh \
 eelf64_sparc.c: $(srcdir)/emulparams/elf64_sparc.sh \
   $(srcdir)/emultempl/elf32.em $(srcdir)/scripttempl/elf.sc ${GEN_DEPENDS}
        ${GENSCRIPTS} elf64_sparc "$(tdir_elf64_sparc)"
+eelf64bmip.c: $(srcdir)/emulparams/elf64bmip.sh \
+  $(srcdir)/emultempl/elf32.em $(srcdir)/scripttempl/elf.sc ${GEN_DEPENDS}
+       ${GENSCRIPTS} elf64bmip "$(tdir_elf64bmip)"
 eelf_i386.c: $(srcdir)/emulparams/elf_i386.sh \
   $(srcdir)/emultempl/elf32.em $(srcdir)/scripttempl/elf.sc ${GEN_DEPENDS}
        ${GENSCRIPTS} elf_i386 "$(tdir_elf_i386)"
index 885457aaa9edaa452273cd9e70fbbbc4178b7647..83ac2f4e7b518061b2d41fe43be218672045f826 100644 (file)
@@ -63,6 +63,8 @@ host_alias = @host_alias@
 host_triplet = @host@
 target_alias = @target_alias@
 target_triplet = @target@
+AMTAR = @AMTAR@
+AMTARFLAGS = @AMTARFLAGS@
 AS = @AS@
 CATALOGS = @CATALOGS@
 CATOBJEXT = @CATOBJEXT@
@@ -91,13 +93,13 @@ MKINSTALLDIRS = @MKINSTALLDIRS@
 MSGFMT = @MSGFMT@
 NATIVE_LIB_DIRS = @NATIVE_LIB_DIRS@
 NM = @NM@
+OBJDUMP = @OBJDUMP@
 PACKAGE = @PACKAGE@
 POFILES = @POFILES@
 POSUB = @POSUB@
 RANLIB = @RANLIB@
 USE_INCLUDED_LIBINTL = @USE_INCLUDED_LIBINTL@
 USE_NLS = @USE_NLS@
-USE_SYMBOL_UNDERSCORE = @USE_SYMBOL_UNDERSCORE@
 VERSION = @VERSION@
 l = @l@
 
@@ -313,7 +315,8 @@ ALL_EMULATIONS = \
 
 ALL_64_EMULATIONS = \
        eelf64_sparc.o \
-       eelf64alpha.o
+       eelf64alpha.o \
+       eelf64bmip.o
 
 
 ALL_EMUL_EXTRA_OFILES = \
@@ -1082,6 +1085,9 @@ eelf64alpha.c: $(srcdir)/emulparams/elf64alpha.sh \
 eelf64_sparc.c: $(srcdir)/emulparams/elf64_sparc.sh \
   $(srcdir)/emultempl/elf32.em $(srcdir)/scripttempl/elf.sc ${GEN_DEPENDS}
        ${GENSCRIPTS} elf64_sparc "$(tdir_elf64_sparc)"
+eelf64bmip.c: $(srcdir)/emulparams/elf64bmip.sh \
+  $(srcdir)/emultempl/elf32.em $(srcdir)/scripttempl/elf.sc ${GEN_DEPENDS}
+       ${GENSCRIPTS} elf64bmip "$(tdir_elf64bmip)"
 eelf_i386.c: $(srcdir)/emulparams/elf_i386.sh \
   $(srcdir)/emultempl/elf32.em $(srcdir)/scripttempl/elf.sc ${GEN_DEPENDS}
        ${GENSCRIPTS} elf_i386 "$(tdir_elf_i386)"
index 97c1397a42208688d4524130d81871fc8f78f4eb..8d55dd93f3af8aaa1a6a74c4ae4b71e09a253ce9 100644 (file)
@@ -178,7 +178,7 @@ mips*-dec-ultrix*)  targ_emul=mipslit ;;
 mips*-dec-osf*)                targ_emul=mipslit ;;
 mips*-sgi-irix5*)      targ_emul=elf32bsmip ;;
 mips*-sgi-irix6*)      targ_emul=elf32bmipn32
-                       targ_extra_emuls="elf32bsmip"
+                       targ_extra_emuls="elf32bsmip elf64bmip"
                        ;;
 mips*-sgi-irix*)       targ_emul=mipsbig ;;
 mips*el-*-ecoff*)      targ_emul=mipsidtl ;;
diff --git a/ld/emulparams/elf64bmip.sh b/ld/emulparams/elf64bmip.sh
new file mode 100755 (executable)
index 0000000..c77cee4
--- /dev/null
@@ -0,0 +1,47 @@
+# This is an ELF platform.
+SCRIPT_NAME=elf
+
+# Handle both big- and little-ended 32-bit MIPS objects.
+ARCH=mips
+OUTPUT_FORMAT="elf64-bigmips"
+BIG_OUTPUT_FORMAT="elf64-bigmips"
+LITTLE_OUTPUT_FORMAT="elf64-littlemips"
+
+# Note that the elf32 template is used for 64-bit emulations as well 
+# as 32-bit emulations.
+ELFSIZE=64
+TEMPLATE_NAME=elf32
+
+TEXT_START_ADDR=0x10000000
+MAXPAGESIZE=0x100000
+ENTRY=__start
+
+# GOT-related settings.  
+OTHER_GOT_SYMBOLS='
+  _gp = ALIGN(16) + 0x7ff0;
+'
+OTHER_GOT_SECTIONS='
+  .lit8 : { *(.lit8) }
+  .lit4 : { *(.lit4) }
+  .srdata : { *(.srdata) }
+'
+
+# Magic symbols.
+TEXT_START_SYMBOLS='_ftext = . ;'
+DATA_START_SYMBOLS='_fdata = . ;'
+OTHER_BSS_SYMBOLS='_fbss = .;'
+# IRIX6 defines these symbols.  0x40 is the size of the ELF header.
+EXECUTABLE_SYMBOLS="
+  __dso_displacement = 0;
+  __elf_header = ${TEXT_START_ADDR};
+  __program_header_table = ${TEXT_START_ADDR} + 0x40;
+"
+
+# There are often dynamic relocations against the .rodata section.
+# Setting DT_TEXTREL in the .dynamic section does not convince the
+# IRIX6 linker to permit relocations against the text segment.
+# Following the IRIX linker, we simply put .rodata in the data
+# segment.
+WRITABLE_RODATA=
+
+