Source-Changes-HG archive

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

[src/trunk]: src/external/gpl3/gdb fix arm



details:   https://anonhg.NetBSD.org/src/rev/22b4dfae2764
branches:  trunk
changeset: 456875:22b4dfae2764
user:      christos <christos%NetBSD.org@localhost>
date:      Thu May 30 16:02:23 2019 +0000

description:
fix arm

diffstat:

 external/gpl3/gdb/dist/gdb/arm-nbsd-nat.c                   |    50 +-
 external/gpl3/gdb/dist/gdb/configure.tgt                    |     2 +-
 external/gpl3/gdb/lib/libbfd/arch/arm/bfd-in3.h             |  1415 ++++++----
 external/gpl3/gdb/lib/libbfd/arch/arm/bfd.h                 |  1415 ++++++----
 external/gpl3/gdb/lib/libbfd/arch/arm/bfdver.h              |    28 +-
 external/gpl3/gdb/lib/libbfd/arch/arm/config.h              |    34 +-
 external/gpl3/gdb/lib/libbfd/arch/arm/defs.mk               |    12 +-
 external/gpl3/gdb/lib/libbfd/arch/arm/targmatch.h           |   906 +------
 external/gpl3/gdb/lib/libdecnumber/arch/arm/config.h        |    14 +-
 external/gpl3/gdb/lib/libgdb/arch/arm/build-gnulib/config.h |   507 +++-
 external/gpl3/gdb/lib/libgdb/arch/arm/config.h              |   128 +-
 external/gpl3/gdb/lib/libgdb/arch/arm/defs.mk               |     6 +-
 external/gpl3/gdb/lib/libgdb/arch/arm/init.c                |   130 +-
 external/gpl3/gdb/lib/libgdb/arch/arm/jit-reader.h          |     6 +-
 external/gpl3/gdb/lib/libgdb/arch/arm/version.c             |     6 +-
 external/gpl3/gdb/lib/libgdb/arch/arm/xml-builtin.c         |    24 +-
 external/gpl3/gdb/lib/libiberty/arch/arm/config.h           |    12 +-
 external/gpl3/gdb/lib/libopcodes/arch/arm/config.h          |    10 +-
 external/gpl3/gdb/lib/libreadline/arch/arm/config.h         |    14 +-
 19 files changed, 2510 insertions(+), 2209 deletions(-)

diffs (truncated from 8546 to 300 lines):

diff -r 55baa5ff75c3 -r 22b4dfae2764 external/gpl3/gdb/dist/gdb/arm-nbsd-nat.c
--- a/external/gpl3/gdb/dist/gdb/arm-nbsd-nat.c Thu May 30 14:58:51 2019 +0000
+++ b/external/gpl3/gdb/dist/gdb/arm-nbsd-nat.c Thu May 30 16:02:23 2019 +0000
@@ -1,5 +1,4 @@
-/* Native-dependent code for BSD Unix running on ARM's, for GDB.
-
+/*
    Copyright (C) 1988-2019 Free Software Foundation, Inc.
 
    This file is part of GDB.
@@ -40,16 +39,6 @@
 #include "inf-ptrace.h"
 #include "bsd-kvm.h"
 
-#ifndef HAVE_GREGSET_T
-typedef struct reg gregset_t;
-#endif
-
-#ifndef HAVE_FPREGSET_T
-typedef struct fpreg fpregset_t;
-#endif
-
-#include "gregset.h"
-
 class arm_nbsd_nat_target final : public nbsd_nat_target
 {
 public:
@@ -62,6 +51,10 @@
 
 extern int arm_apcs_32;
 
+#define FPSCR(r) ((char *) &(r)->fpr_vfp.vfp_fpscr)
+#define FPREG(r, regno) \
+    ((char *) (r)->fpr_vfp.vfp_regs + 8 * ((regno) - ARM_D0_REGNUM))
+
 static int
 armnbsd_supply_pcb (struct regcache *regcache, struct pcb *pcb)
 {
@@ -135,14 +128,14 @@
 {
   int regno;
 
-  for (regno = ARM_F0_REGNUM; regno <= ARM_F7_REGNUM; regno++)
-    regcache->raw_supply (regno, (char *) &fparegset->fpr[regno - ARM_F0_REGNUM]);
+  for (regno = ARM_D0_REGNUM; regno < 16 + ARM_D0_REGNUM; regno++)
+    regcache->raw_supply (regno, FPREG(vfpregset, regno));
 
-  regcache->raw_supply (ARM_FPS_REGNUM, (char *) &fparegset->fpr_fpsr);
+  regcache->raw_supply (ARM_FPSCR_REGNUM, FPSCR(vfpregset));
 }
 
 static void
-arm_nbsd_nat_fetch_register (struct regcache *regcache, int regno)
+fetch_register (struct regcache *regcache, int regno)
 {
   struct reg regs;
   ptid_t ptid = regcache->ptid ();
@@ -211,11 +204,13 @@
 static void
 fetch_fp_register (struct regcache *regcache, int regno)
 {
+  ptid_t ptid = regcache->ptid ();
+  pid_t pid = ptid.pid ();
+  int lwp = ptid.lwp ();
   struct fpreg fpregs;
   int ret;
 
-  ret = ptrace (PT_GETFPREGS, pid,
-               (PTRACE_TYPE_ARG3) &fpregs, lwp); 
+  ret = ptrace (PT_GETFPREGS, pid, (PTRACE_TYPE_ARG3) &fpregs, lwp); 
 
   if (ret < 0)
     {
@@ -225,14 +220,13 @@
 
   switch (regno)
     {
-    case ARM_FPS_REGNUM:
-      regcache->raw_supply (ARM_FPS_REGNUM,
-                           (char *) &fpregs.fpr_fpsr);
+    case ARM_FPSCR_REGNUM:
+      regcache->raw_supply (ARM_FPSCR_REGNUM, FPSCR(&fpregs));
       break;
 
     default:
-      regcache->raw_supply
-       (regno, (char *) &fpregs.fpr[regno - ARM_F0_REGNUM]);
+      regno += ARM_D0_REGNUM;
+      regcache->raw_supply (regno, FPREG(&fpregs, regno));
       break;
     }
 }
@@ -407,11 +401,11 @@
   switch (regno)
     {
     case ARM_FPS_REGNUM:
-      regcache->raw_collect (ARM_FPS_REGNUM, (char *) &fpregs.fpr_fpsr);
+      regcache->raw_collect (ARM_FPS_REGNUM, FPSCR(&fpregs));
       break;
 
     default:
-      regcache->raw_collect (regno, (char *) &fpregs.fpr[regno - ARM_F0_REGNUM]);
+      regcache->raw_collect (regno, FPREG(&fpregs, regno));
       break;
     }
 
@@ -432,10 +426,10 @@
   int regno;
 
 
-  for (regno = ARM_F0_REGNUM; regno <= ARM_F7_REGNUM; regno++)
-    regcache->raw_collect (regno, (char *) &fpregs.fpr[regno - ARM_F0_REGNUM]);
+  for (regno = ARM_D0_REGNUM; regno < 16 + ARM_D0_REGNUM; regno++)
+    regcache->raw_collect (regno, FPREG(&fpregs, regno));
 
-  regcache->raw_collect (ARM_FPS_REGNUM, (char *) &fpregs.fpr_fpsr);
+  regcache->raw_collect (ARM_FPSCR_REGNUM, FPSCR(&fpregs));
 
   ret = ptrace (PT_SETFPREGS, pid, (PTRACE_TYPE_ARG3) &fpregs, lwp);
 
diff -r 55baa5ff75c3 -r 22b4dfae2764 external/gpl3/gdb/dist/gdb/configure.tgt
--- a/external/gpl3/gdb/dist/gdb/configure.tgt  Thu May 30 14:58:51 2019 +0000
+++ b/external/gpl3/gdb/dist/gdb/configure.tgt  Thu May 30 16:02:23 2019 +0000
@@ -182,7 +182,7 @@
        ;;
 arm*-*-netbsd* | arm*-*-knetbsd*-gnu)
        # Target: NetBSD/arm
-       gdb_target_obs="arm-nbsd-tdep.o"
+       gdb_target_obs="arm-bsd-tdep.o arm-nbsd-tdep.o"
        ;;
 arm*-*-openbsd*)
        # Target: OpenBSD/arm
diff -r 55baa5ff75c3 -r 22b4dfae2764 external/gpl3/gdb/lib/libbfd/arch/arm/bfd-in3.h
--- a/external/gpl3/gdb/lib/libbfd/arch/arm/bfd-in3.h   Thu May 30 14:58:51 2019 +0000
+++ b/external/gpl3/gdb/lib/libbfd/arch/arm/bfd-in3.h   Thu May 30 16:02:23 2019 +0000
@@ -1,17 +1,17 @@
 /* This file is automatically generated.  DO NOT EDIT! */
-/* Generated from: NetBSD: mknative-gdb,v 1.7 2016/10/16 04:37:42 mrg Exp  */
-/* Generated from: NetBSD: mknative.common,v 1.15 2017/11/29 03:32:28 christos Exp  */
-
-/* DO NOT EDIT!  -*- buffer-read-only: t -*-  This file is automatically 
-   generated from "bfd-in.h", "init.c", "opncls.c", "libbfd.c", 
-   "bfdio.c", "bfdwin.c", "section.c", "archures.c", "reloc.c", 
-   "syms.c", "bfd.c", "archive.c", "corefile.c", "targets.c", "format.c", 
+/* Generated from: NetBSD: mknative-gdb,v 1.8 2019/05/29 01:56:06 christos Exp  */
+/* Generated from: NetBSD: mknative.common,v 1.16 2018/04/15 15:13:37 christos Exp  */
+
+/* DO NOT EDIT!  -*- buffer-read-only: t -*-  This file is automatically
+   generated from "bfd-in.h", "init.c", "opncls.c", "libbfd.c",
+   "bfdio.c", "bfdwin.c", "section.c", "archures.c", "reloc.c",
+   "syms.c", "bfd.c", "archive.c", "corefile.c", "targets.c", "format.c",
    "linker.c", "simple.c" and "compress.c".
    Run "make headers" in your build bfd/ to regenerate.  */
 
 /* Main header file for the bfd library -- portable access to object files.
 
-   Copyright (C) 1990-2017 Free Software Foundation, Inc.
+   Copyright (C) 1990-2019 Free Software Foundation, Inc.
 
    Contributed by Cygnus Support.
 
@@ -45,6 +45,8 @@
 
 #include "ansidecl.h"
 #include "symcat.h"
+#include "bfd_stdint.h"
+#include "diagnostics.h"
 #include <stdarg.h>
 #include <sys/stat.h>
 
@@ -102,6 +104,24 @@
 typedef BFD_HOST_U_64_BIT bfd_uint64_t;
 #endif
 
+#ifdef HAVE_INTTYPES_H
+# include <inttypes.h>
+#else
+# if BFD_HOST_64BIT_LONG
+#  define BFD_PRI64 "l"
+# elif defined (__MSVCRT__)
+#  define BFD_PRI64 "I64"
+# else
+#  define BFD_PRI64 "ll"
+# endif
+# undef PRId64
+# define PRId64 BFD_PRI64 "d"
+# undef PRIu64
+# define PRIu64 BFD_PRI64 "u"
+# undef PRIx64
+# define PRIx64 BFD_PRI64 "x"
+#endif
+
 #if BFD_ARCH_SIZE >= 64
 #define BFD64
 #endif
@@ -115,7 +135,7 @@
 #endif
 
 /* Declaring a type wide enough to hold a host long and a host pointer.  */
-#define BFD_HOSTPTR_T  unsigned long
+#define BFD_HOSTPTR_T unsigned long
 typedef BFD_HOSTPTR_T bfd_hostptr_t;
 
 /* Forward declaration.  */
@@ -226,9 +246,6 @@
 /* A count of carsyms (canonical archive symbols).  */
 typedef unsigned long symindex;
 
-/* How to perform a relocation.  */
-typedef const struct reloc_howto_struct reloc_howto_type;
-
 #define BFD_NO_MORE_SYMBOLS ((symindex) ~0)
 
 /* General purpose part of a symbol X;
@@ -258,7 +275,7 @@
 
 /* Used in generating armaps (archive tables of contents).
    Perhaps just a forward definition would do?  */
-struct orl                     /* Output ranlib.  */
+struct orl             /* Output ranlib.  */
 {
   char **name;         /* Symbol name.  */
   union
@@ -276,7 +293,7 @@
   union
   {
     struct bfd_symbol *sym;    /* Function name.  */
-    bfd_vma offset;                    /* Offset into section.  */
+    bfd_vma offset;            /* Offset into section.  */
   } u;
 }
 alent;
@@ -340,11 +357,11 @@
 {
   symvalue value;
   char type;
-  const char *name;            /* Symbol name.  */
-  unsigned char stab_type;     /* Stab type.  */
-  char stab_other;             /* Stab other.  */
-  short stab_desc;             /* Stab desc.  */
-  const char *stab_name;       /* String for stab type.  */
+  const char *name;            /* Symbol name.  */
+  unsigned char stab_type;     /* Stab type.  */
+  char stab_other;             /* Stab other.  */
+  short stab_desc;             /* Stab desc.  */
+  const char *stab_name;       /* String for stab type.  */
 } symbol_info;
 
 /* Get the name of a stabs type code.  */
@@ -382,7 +399,7 @@
      only if the argument is NULL.  */
   struct bfd_hash_entry *(*newfunc)
     (struct bfd_hash_entry *, struct bfd_hash_table *, const char *);
-   /* An objalloc for this hash table.  This is a struct objalloc *,
+  /* An objalloc for this hash table.  This is a struct objalloc *,
      but we use void * to avoid requiring the inclusion of objalloc.h.  */
   void *memory;
   /* The number of slots in the hash table.  */
@@ -500,7 +517,7 @@
   (_bfd_warn_deprecated ("bfd_read", __FILE__, __LINE__, __FUNCTION__),        \
    bfd_bread ((BUF), (ELTSIZE) * (NITEMS), (ABFD)))
 #define bfd_write(BUF, ELTSIZE, NITEMS, ABFD)                          \
-  (_bfd_warn_deprecated ("bfd_write", __FILE__, __LINE__, __FUNCTION__),       \
+  (_bfd_warn_deprecated ("bfd_write", __FILE__, __LINE__, __FUNCTION__), \
    bfd_bwrite ((BUF), (ELTSIZE) * (NITEMS), (ABFD)))
 #else
 #define bfd_read(BUF, ELTSIZE, NITEMS, ABFD)                           \
@@ -574,6 +591,8 @@
 void bfd_putl64 (bfd_uint64_t, void *);
 void bfd_putb32 (bfd_vma, void *);
 void bfd_putl32 (bfd_vma, void *);
+void bfd_putb24 (bfd_vma, void *);
+void bfd_putl24 (bfd_vma, void *);
 void bfd_putb16 (bfd_vma, void *);
 void bfd_putl16 (bfd_vma, void *);
 
@@ -601,8 +620,6 @@
 
 /* Externally visible ECOFF routines.  */
 
-extern bfd_vma bfd_ecoff_get_gp_value
-  (bfd * abfd);
 extern bfd_boolean bfd_ecoff_set_gp_value
   (bfd *abfd, bfd_vma gp_value);
 extern bfd_boolean bfd_ecoff_set_regmasks
@@ -771,8 +788,6 @@
 
 extern bfd_boolean bfd_i386linux_size_dynamic_sections
   (bfd *, struct bfd_link_info *);
-extern bfd_boolean bfd_m68klinux_size_dynamic_sections
-  (bfd *, struct bfd_link_info *);
 extern bfd_boolean bfd_sparclinux_size_dynamic_sections
   (bfd *, struct bfd_link_info *);
 
@@ -841,9 +856,6 @@
 extern bfd_boolean bfd_coff_set_symbol_class
   (bfd *, struct bfd_symbol *, unsigned int);
 
-extern bfd_boolean bfd_m68k_coff_create_embedded_relocs
-  (bfd *, struct bfd_link_info *, struct bfd_section *, struct bfd_section *, char **);



Home | Main Index | Thread Index | Old Index