Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/external/gpl3/binutils/dist Merge in OR1K support from top o...



details:   https://anonhg.NetBSD.org/src/rev/7baacbcc474f
branches:  trunk
changeset: 331974:7baacbcc474f
user:      matt <matt%NetBSD.org@localhost>
date:      Wed Sep 03 19:01:15 2014 +0000

description:
Merge in OR1K support from top of binutils-gdb GIT repository.  This replaces
the existing support and most imporantly adds support for shared libraries.

diffstat:

 external/gpl3/binutils/dist/bfd/Makefile.in                  |    18 +-
 external/gpl3/binutils/dist/bfd/archures.c                   |     6 +-
 external/gpl3/binutils/dist/bfd/bfd-in2.h                    |    32 +-
 external/gpl3/binutils/dist/bfd/coff-or32.c                  |   629 --
 external/gpl3/binutils/dist/bfd/coffcode.h                   |    15 -
 external/gpl3/binutils/dist/bfd/config.bfd                   |    15 +-
 external/gpl3/binutils/dist/bfd/configure                    |     4 +-
 external/gpl3/binutils/dist/bfd/configure.in                 |     3 +-
 external/gpl3/binutils/dist/bfd/cpu-or1k.c                   |    61 +
 external/gpl3/binutils/dist/bfd/cpu-or32.c                   |    42 -
 external/gpl3/binutils/dist/bfd/elf-bfd.h                    |     1 +
 external/gpl3/binutils/dist/bfd/elf32-openrisc.c             |   566 -
 external/gpl3/binutils/dist/bfd/elf32-or1k.c                 |  2852 ++++++++++
 external/gpl3/binutils/dist/bfd/elf32-or32.c                 |   514 -
 external/gpl3/binutils/dist/bfd/libbfd.h                     |    26 +-
 external/gpl3/binutils/dist/bfd/targets.c                    |     8 +-
 external/gpl3/binutils/dist/binutils/readelf.c               |    18 +-
 external/gpl3/binutils/dist/config.sub                       |    16 +-
 external/gpl3/binutils/dist/cpu/openrisc.cpu                 |   774 --
 external/gpl3/binutils/dist/cpu/openrisc.opc                 |   164 -
 external/gpl3/binutils/dist/cpu/or1k.cpu                     |   131 +
 external/gpl3/binutils/dist/cpu/or1k.opc                     |   421 +
 external/gpl3/binutils/dist/cpu/or1kcommon.cpu               |   360 +
 external/gpl3/binutils/dist/cpu/or1korbis.cpu                |  1145 ++++
 external/gpl3/binutils/dist/cpu/or1korfpx.cpu                |   222 +
 external/gpl3/binutils/dist/gas/Makefile.am                  |     6 +-
 external/gpl3/binutils/dist/gas/Makefile.in                  |    43 +-
 external/gpl3/binutils/dist/gas/config/tc-openrisc.c         |   363 -
 external/gpl3/binutils/dist/gas/config/tc-openrisc.h         |    61 -
 external/gpl3/binutils/dist/gas/config/tc-or1k.c             |   362 +
 external/gpl3/binutils/dist/gas/config/tc-or1k.h             |    79 +
 external/gpl3/binutils/dist/gas/config/tc-or32.c             |   967 ---
 external/gpl3/binutils/dist/gas/config/tc-or32.h             |    56 -
 external/gpl3/binutils/dist/gas/configure                    |     4 +-
 external/gpl3/binutils/dist/gas/configure.in                 |     4 +-
 external/gpl3/binutils/dist/gas/configure.tgt                |    11 +-
 external/gpl3/binutils/dist/include/dis-asm.h                |     4 +-
 external/gpl3/binutils/dist/include/elf/common.h             |     5 +-
 external/gpl3/binutils/dist/include/elf/openrisc.h           |    39 -
 external/gpl3/binutils/dist/include/elf/or1k.h               |    65 +
 external/gpl3/binutils/dist/include/elf/or32.h               |    56 -
 external/gpl3/binutils/dist/ld/Makefile.am                   |    18 +-
 external/gpl3/binutils/dist/ld/Makefile.in                   |    30 +-
 external/gpl3/binutils/dist/ld/configure.tgt                 |    10 +-
 external/gpl3/binutils/dist/ld/emulparams/elf32openrisc.sh   |    11 -
 external/gpl3/binutils/dist/ld/emulparams/elf32or1k.sh       |    14 +
 external/gpl3/binutils/dist/ld/emulparams/elf32or1k_linux.sh |     6 +
 external/gpl3/binutils/dist/ld/emulparams/elf32or1k_nbsd.sh  |     6 +
 external/gpl3/binutils/dist/ld/emulparams/or32.sh            |     5 -
 external/gpl3/binutils/dist/ld/emulparams/or32elf.sh         |     9 -
 external/gpl3/binutils/dist/opcodes/Makefile.am              |    30 +-
 external/gpl3/binutils/dist/opcodes/Makefile.in              |    41 +-
 external/gpl3/binutils/dist/opcodes/configure                |     3 +-
 external/gpl3/binutils/dist/opcodes/configure.in             |     3 +-
 external/gpl3/binutils/dist/opcodes/disassemble.c            |    17 +-
 external/gpl3/binutils/dist/opcodes/openrisc-asm.c           |   649 --
 external/gpl3/binutils/dist/opcodes/openrisc-desc.c          |  1018 ---
 external/gpl3/binutils/dist/opcodes/openrisc-desc.h          |   288 -
 external/gpl3/binutils/dist/opcodes/openrisc-dis.c           |   556 -
 external/gpl3/binutils/dist/opcodes/openrisc-ibld.c          |  1009 ---
 external/gpl3/binutils/dist/opcodes/openrisc-opc.c           |   682 --
 external/gpl3/binutils/dist/opcodes/openrisc-opc.h           |   113 -
 external/gpl3/binutils/dist/opcodes/or1k-asm.c               |   910 +++
 external/gpl3/binutils/dist/opcodes/or1k-desc.c              |  2110 +++++++
 external/gpl3/binutils/dist/opcodes/or1k-desc.h              |   682 ++
 external/gpl3/binutils/dist/opcodes/or1k-dis.c               |   561 +
 external/gpl3/binutils/dist/opcodes/or1k-ibld.c              |  1050 +++
 external/gpl3/binutils/dist/opcodes/or1k-opc.c               |  1081 +++
 external/gpl3/binutils/dist/opcodes/or1k-opc.h               |   135 +
 external/gpl3/binutils/dist/opcodes/or1k-opinst.c            |   590 ++
 external/gpl3/binutils/dist/opcodes/or32-dis.c               |   325 -
 external/gpl3/binutils/dist/opcodes/or32-opc.c               |  1031 ---
 72 files changed, 13040 insertions(+), 10121 deletions(-)

diffs (truncated from 24000 to 300 lines):

diff -r f8cbc03cfcc8 -r 7baacbcc474f external/gpl3/binutils/dist/bfd/Makefile.in
--- a/external/gpl3/binutils/dist/bfd/Makefile.in       Wed Sep 03 16:23:24 2014 +0000
+++ b/external/gpl3/binutils/dist/bfd/Makefile.in       Wed Sep 03 19:01:15 2014 +0000
@@ -419,7 +419,7 @@
        cpu-mt.lo \
        cpu-ns32k.lo \
        cpu-openrisc.lo \
-       cpu-or32.lo \
+       cpu-or1k.lo \
        cpu-pdp11.lo \
        cpu-pj.lo \
        cpu-plugin.lo \
@@ -500,7 +500,7 @@
        cpu-mt.c \
        cpu-ns32k.c \
        cpu-openrisc.c \
-       cpu-or32.c \
+       cpu-or1k.c \
        cpu-pdp11.c \
        cpu-pj.c \
        cpu-plugin.c \
@@ -559,7 +559,7 @@
        coff-m68k.lo \
        coff-m88k.lo \
        coff-mips.lo \
-       coff-or32.lo \
+       coff-or1k.lo \
        coff-rs6000.lo \
        coff-sh.lo \
        coff-sparc.lo \
@@ -627,7 +627,7 @@
        elf32-msp430.lo \
        elf32-mt.lo \
        elf32-openrisc.lo \
-       elf32-or32.lo \
+       elf32-or1k.lo \
        elf32-pj.lo \
        elf32-ppc.lo \
        elf32-rl78.lo \
@@ -747,7 +747,7 @@
        coff-m68k.c \
        coff-m88k.c \
        coff-mips.c \
-       coff-or32.c \
+       coff-or1k.c \
        coff-rs6000.c \
        coff-sh.c \
        coff-sparc.c \
@@ -815,7 +815,7 @@
        elf32-msp430.c \
        elf32-mt.c \
        elf32-openrisc.c \
-       elf32-or32.c \
+       elf32-or1k.c \
        elf32-pj.c \
        elf32-ppc.c \
        elf32-rl78.c \
@@ -1253,7 +1253,7 @@
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/coff-m68k.Plo@am__quote@
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/coff-m88k.Plo@am__quote@
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/coff-mips.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/coff-or32.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/coff-or1k.Plo@am__quote@
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/coff-rs6000.Plo@am__quote@
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/coff-sh.Plo@am__quote@
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/coff-sparc.Plo@am__quote@
@@ -1323,7 +1323,7 @@
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/cpu-mt.Plo@am__quote@
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/cpu-ns32k.Plo@am__quote@
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/cpu-openrisc.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/cpu-or32.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/cpu-or1k.Plo@am__quote@
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/cpu-pdp11.Plo@am__quote@
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/cpu-pj.Plo@am__quote@
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/cpu-plugin.Plo@am__quote@
@@ -1408,7 +1408,7 @@
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/elf32-msp430.Plo@am__quote@
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/elf32-mt.Plo@am__quote@
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/elf32-openrisc.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/elf32-or32.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/elf32-or1k.Plo@am__quote@
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/elf32-pj.Plo@am__quote@
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/elf32-ppc.Plo@am__quote@
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/elf32-rl78.Plo@am__quote@
diff -r f8cbc03cfcc8 -r 7baacbcc474f external/gpl3/binutils/dist/bfd/archures.c
--- a/external/gpl3/binutils/dist/bfd/archures.c        Wed Sep 03 16:23:24 2014 +0000
+++ b/external/gpl3/binutils/dist/bfd/archures.c        Wed Sep 03 19:01:15 2014 +0000
@@ -123,7 +123,7 @@
 .#define bfd_mach_i960_jx       7
 .#define bfd_mach_i960_hx        8
 .
-.  bfd_arch_or32,      {* OpenRISC 32 *}
+.  bfd_arch_or1k,      {* OpenRISC 32 *}
 .
 .  bfd_arch_sparc,     {* SPARC *}
 .#define bfd_mach_sparc                        1
@@ -556,7 +556,7 @@
 extern const bfd_arch_info_type bfd_mt_arch;
 extern const bfd_arch_info_type bfd_ns32k_arch;
 extern const bfd_arch_info_type bfd_openrisc_arch;
-extern const bfd_arch_info_type bfd_or32_arch;
+extern const bfd_arch_info_type bfd_or1k_arch;
 extern const bfd_arch_info_type bfd_pdp11_arch;
 extern const bfd_arch_info_type bfd_pj_arch;
 extern const bfd_arch_info_type bfd_plugin_arch;
@@ -642,7 +642,7 @@
     &bfd_mt_arch,
     &bfd_ns32k_arch,
     &bfd_openrisc_arch,
-    &bfd_or32_arch,
+    &bfd_or1k_arch,
     &bfd_pdp11_arch,
     &bfd_powerpc_arch,
     &bfd_rs6000_arch,
diff -r f8cbc03cfcc8 -r 7baacbcc474f external/gpl3/binutils/dist/bfd/bfd-in2.h
--- a/external/gpl3/binutils/dist/bfd/bfd-in2.h Wed Sep 03 16:23:24 2014 +0000
+++ b/external/gpl3/binutils/dist/bfd/bfd-in2.h Wed Sep 03 19:01:15 2014 +0000
@@ -1852,7 +1852,9 @@
 #define bfd_mach_i960_jx        7
 #define bfd_mach_i960_hx        8
 
-  bfd_arch_or32,      /* OpenRISC 32 */
+  bfd_arch_or1k,      /* OpenRISC 1000 */
+#define bfd_mach_or1k          1
+#define bfd_mach_or1knd                2
 
   bfd_arch_sparc,     /* SPARC */
 #define bfd_mach_sparc                 1
@@ -4803,9 +4805,31 @@
   BFD_RELOC_860_HIGOT,
   BFD_RELOC_860_HIGOTOFF,
 
-/* OpenRISC Relocations.  */
-  BFD_RELOC_OPENRISC_ABS_26,
-  BFD_RELOC_OPENRISC_REL_26,
+/* OpenRISC 1000 Relocations.  */
+  BFD_RELOC_OR1K_REL_26,
+  BFD_RELOC_OR1K_GOTPC_HI16,
+  BFD_RELOC_OR1K_GOTPC_LO16,
+  BFD_RELOC_OR1K_GOT16,
+  BFD_RELOC_OR1K_PLT26,
+  BFD_RELOC_OR1K_GOTOFF_HI16,
+  BFD_RELOC_OR1K_GOTOFF_LO16,
+  BFD_RELOC_OR1K_COPY,
+  BFD_RELOC_OR1K_GLOB_DAT,
+  BFD_RELOC_OR1K_JMP_SLOT,
+  BFD_RELOC_OR1K_RELATIVE,
+  BFD_RELOC_OR1K_TLS_GD_HI16,
+  BFD_RELOC_OR1K_TLS_GD_LO16,
+  BFD_RELOC_OR1K_TLS_LDM_HI16,
+  BFD_RELOC_OR1K_TLS_LDM_LO16,
+  BFD_RELOC_OR1K_TLS_LDO_HI16,
+  BFD_RELOC_OR1K_TLS_LDO_LO16,
+  BFD_RELOC_OR1K_TLS_IE_HI16,
+  BFD_RELOC_OR1K_TLS_IE_LO16,
+  BFD_RELOC_OR1K_TLS_LE_HI16,
+  BFD_RELOC_OR1K_TLS_LE_LO16,
+  BFD_RELOC_OR1K_TLS_TPOFF,
+  BFD_RELOC_OR1K_TLS_DTPOFF,
+  BFD_RELOC_OR1K_TLS_DTPMOD,
 
 /* H8 elf Relocations.  */
   BFD_RELOC_H8_DIR16A8,
diff -r f8cbc03cfcc8 -r 7baacbcc474f external/gpl3/binutils/dist/bfd/coff-or32.c
--- a/external/gpl3/binutils/dist/bfd/coff-or32.c       Wed Sep 03 16:23:24 2014 +0000
+++ /dev/null   Thu Jan 01 00:00:00 1970 +0000
@@ -1,629 +0,0 @@
-/* BFD back-end for OpenRISC 1000 COFF binaries.
-   Copyright 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2011, 2012
-   Free Software Foundation, Inc.
-   Contributed by Ivan Guzvinec  <ivang%opencores.org@localhost>
-
-   This file is part of BFD, the Binary File Descriptor library.
-
-   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.  */
-
-#define OR32 1
-
-#include "sysdep.h"
-#include "bfd.h"
-#include "libbfd.h"
-#include "coff/or32.h"
-#include "coff/internal.h"
-#include "libcoff.h"
-
-static bfd_reloc_status_type or32_reloc
-  (bfd *, arelent *, asymbol *, void *, asection *, bfd *, char **);
-
-#define COFF_DEFAULT_SECTION_ALIGNMENT_POWER (2)
-
-#define INSERT_HWORD(WORD,HWORD)              \
-    (((WORD) & 0xffff0000) | ((HWORD)& 0x0000ffff))
-#define EXTRACT_HWORD(WORD)                   \
-    ((WORD) & 0x0000ffff)
-#define SIGN_EXTEND_HWORD(HWORD)              \
-    ((HWORD) & 0x8000 ? (HWORD)|(~0xffffL) : (HWORD))
-
-#define INSERT_JUMPTARG(WORD,JT)              \
-    (((WORD) & 0xfc000000) | ((JT)& 0x03ffffff))
-#define EXTRACT_JUMPTARG(WORD)                   \
-    ((WORD) & 0x03ffffff)
-#define SIGN_EXTEND_JUMPTARG(JT)              \
-    ((JT) & 0x04000000 ? (JT)|(~0x03ffffffL) : (JT))
-
-/* Provided the symbol, returns the value reffed.  */
-
-static long
-get_symbol_value (asymbol *symbol)
-{
-  long relocation = 0;
-
-  if (bfd_is_com_section (symbol->section))
-    relocation = 0;
-  else
-    relocation = symbol->value +
-      symbol->section->output_section->vma +
-      symbol->section->output_offset;
-
-  return relocation;
-}
-
-/* This function is in charge of performing all the or32 relocations.  */
-
-static bfd_reloc_status_type
-or32_reloc (bfd *abfd,
-           arelent *reloc_entry,
-           asymbol *symbol_in,
-           void * data,
-           asection *input_section,
-           bfd *output_bfd,
-           char **error_message)
-{
-  /* The consth relocation comes in two parts, we have to remember
-     the state between calls, in these variables.  */
-  static bfd_boolean part1_consth_active = FALSE;
-  static unsigned long part1_consth_value;
-
-  unsigned long insn;
-  unsigned long sym_value;
-  unsigned long unsigned_value;
-  unsigned short r_type;
-  long signed_value;
-
-  unsigned long addr = reloc_entry->address ;   /*+ input_section->vma*/
-  bfd_byte *hit_data =addr + (bfd_byte *)(data);
-
-  r_type = reloc_entry->howto->type;
-
-  if (output_bfd)
-    {
-      /* Partial linking - do nothing.  */
-      reloc_entry->address += input_section->output_offset;
-      return bfd_reloc_ok;
-    }
-
-  if (symbol_in != NULL
-      && bfd_is_und_section (symbol_in->section))
-    {
-      /* Keep the state machine happy in case we're called again.  */
-      if (r_type == R_IHIHALF)
-        {
-          part1_consth_active = TRUE;
-          part1_consth_value  = 0;
-        }
-
-      return bfd_reloc_undefined;
-    }
-
-  if ((part1_consth_active) && (r_type != R_IHCONST))
-    {
-      part1_consth_active = FALSE;
-      *error_message = (char *) "Missing IHCONST";
-
-      return bfd_reloc_dangerous;
-    }
-
-  sym_value = get_symbol_value (symbol_in);
-
-  switch (r_type)
-    {
-    case R_IREL:
-      insn = bfd_get_32(abfd, hit_data);
-
-      /* Take the value in the field and sign extend it.  */
-      signed_value = EXTRACT_JUMPTARG (insn);
-      signed_value = SIGN_EXTEND_JUMPTARG (signed_value);
-      signed_value <<= 2;



Home | Main Index | Thread Index | Old Index