components/gdb/patches/gdb.gdb.sparc-sol2-nat.c.patch
changeset 6420 65948e9e205b
parent 1511 4d3b0b480760
--- a/components/gdb/patches/gdb.gdb.sparc-sol2-nat.c.patch	Fri Jul 15 06:54:58 2016 -0700
+++ b/components/gdb/patches/gdb.gdb.sparc-sol2-nat.c.patch	Fri Jul 15 07:22:25 2016 -0700
@@ -1,27 +1,32 @@
---- gdb-7.6/gdb/sparc-sol2-nat.c	2012-12-31 22:32:51.000000000 -0800
-+++ gdb-7.6/gdb/sparc-sol2-nat.c	2013-10-06 14:09:16.962861100 -0700
-@@ -24,12 +24,10 @@
+# Patch required for Solaris.
+# Will contribute upstream if possible.
+
+--- gdb-7.11-orig/gdb/sparc-sol2-nat.c	Tue Feb  9 19:19:39 2016
++++ gdb-7.11/gdb/sparc-sol2-nat.c	Fri Mar 25 14:22:51 2016
+@@ -24,13 +24,11 @@
  #include "gregset.h"
  
  #include "sparc-tdep.h"
 +#include "sparc64-tdep.h"
  #include "target.h"
--#include "procfs.h"
++
+ #include "procfs.h"
  
 -/* This file provids the (temporary) glue between the Solaris SPARC
 -   target dependent code and the machine independent SVR4 /proc
 -   support.  */
-+#include "procfs.h"
- 
+-
  /* Solaris 7 (Solaris 2.7, SunOS 5.7) and up support two process data
     models, the traditional 32-bit data model (ILP32) and the 64-bit
-@@ -48,54 +46,67 @@
+    data model (LP64).  The format of /proc depends on the data model
+@@ -48,47 +46,51 @@
     Note that a 32-bit GDB won't be able to debug a 64-bit target
     process using /proc on Solaris.  */
  
 -#if (defined (__arch64__) || \
 -     (defined (PR_MODEL_NATIVE) && (PR_MODEL_NATIVE == PR_MODEL_LP64)))
--
++static int from_corefile = -1;
+ 
 -#include "sparc64-tdep.h"
 -
 -#define sparc_supply_gregset sparc64_supply_gregset
@@ -29,8 +34,8 @@
 -#define sparc_collect_gregset sparc64_collect_gregset
 -#define sparc_collect_fpregset sparc64_collect_fpregset
 -
--#define sparc_sol2_gregset sparc64_sol2_gregset
--#define sparc_sol2_fpregset sparc64_sol2_fpregset
+-#define sparc_sol2_gregmap sparc64_sol2_gregmap
+-#define sparc_sol2_fpregmap sparc64_sol2_fpregmap
 -
 -#else
 -
@@ -39,16 +44,15 @@
 -#define sparc_collect_gregset sparc32_collect_gregset
 -#define sparc_collect_fpregset sparc32_collect_fpregset
 -
--#define sparc_sol2_gregset sparc32_sol2_gregset
--#define sparc_sol2_fpregset sparc32_sol2_fpregset
+-#define sparc_sol2_gregmap sparc32_sol2_gregmap
+-#define sparc_sol2_fpregmap sparc32_sol2_fpregmap
 -
 -#endif
-+static int from_corefile = -1;
- 
+-
  void
  supply_gregset (struct regcache *regcache, const prgregset_t *gregs)
  {
--  sparc_supply_gregset (&sparc_sol2_gregset, regcache, -1, gregs);
+-  sparc_supply_gregset (&sparc_sol2_gregmap, regcache, -1, gregs);
 +  struct gdbarch *gdbarch = get_regcache_arch (regcache);
 +  int pointer_size = gdbarch_ptr_bit (gdbarch);
 +
@@ -56,15 +60,15 @@
 +    from_corefile = regcache_from_corefile (regcache);
 +
 +  if ((pointer_size == 32) && (from_corefile == 1))
-+    sparc32_supply_gregset (&sparc32_sol2_gregset, regcache, -1, gregs);
++    sparc32_supply_gregset (&sparc32_sol2_gregmap, regcache, -1, gregs);
 +  else
-+    sparc64_supply_gregset (&sparc64_sol2_gregset, regcache, -1, gregs);
++    sparc64_supply_gregset (&sparc64_sol2_gregmap, regcache, -1, gregs);
  }
  
  void
  supply_fpregset (struct regcache *regcache, const prfpregset_t *fpregs)
  {
--  sparc_supply_fpregset (&sparc_sol2_fpregset, regcache, -1, fpregs);
+-  sparc_supply_fpregset (&sparc_sol2_fpregmap, regcache, -1, fpregs);
 +  struct gdbarch *gdbarch = get_regcache_arch (regcache);
 +  int pointer_size = gdbarch_ptr_bit (gdbarch);
 +
@@ -72,15 +76,15 @@
 +    from_corefile = regcache_from_corefile (regcache);
 +
 +  if ((pointer_size == 32) && (from_corefile == 1))
-+    sparc32_supply_fpregset (&sparc32_sol2_fpregset, regcache, -1, fpregs);
++    sparc32_supply_fpregset (&sparc32_sol2_fpregmap, regcache, -1, fpregs);
 +  else
-+    sparc64_supply_fpregset (&sparc64_sol2_fpregset, regcache, -1, fpregs);
++    sparc64_supply_fpregset (&sparc64_sol2_fpregmap, regcache, -1, fpregs);
  }
  
  void
  fill_gregset (const struct regcache *regcache, prgregset_t *gregs, int regnum)
  {
--  sparc_collect_gregset (&sparc_sol2_gregset, regcache, regnum, gregs);
+-  sparc_collect_gregset (&sparc_sol2_gregmap, regcache, regnum, gregs);
 +  struct gdbarch *gdbarch = get_regcache_arch (regcache);
 +  int pointer_size = gdbarch_ptr_bit (gdbarch);
 +
@@ -88,16 +92,17 @@
 +    from_corefile = regcache_from_corefile (regcache);
 +
 +  if ((pointer_size == 32) && (from_corefile == 1))
-+    sparc32_collect_gregset (&sparc32_sol2_gregset, regcache, regnum, gregs);
++    sparc32_collect_gregset (&sparc32_sol2_gregmap, regcache, regnum, gregs);
 +  else
-+    sparc64_collect_gregset (&sparc64_sol2_gregset, regcache, regnum, gregs);
++    sparc64_collect_gregset (&sparc64_sol2_gregmap, regcache, regnum, gregs);
  }
  
  void
+@@ -95,7 +97,16 @@
  fill_fpregset (const struct regcache *regcache,
  	       prfpregset_t *fpregs, int regnum)
  {
--  sparc_collect_fpregset (&sparc_sol2_fpregset, regcache, regnum, fpregs);
+-  sparc_collect_fpregset (&sparc_sol2_fpregmap, regcache, regnum, fpregs);
 +  struct gdbarch *gdbarch = get_regcache_arch (regcache);
 +  int pointer_size = gdbarch_ptr_bit (gdbarch);
 +
@@ -105,9 +110,9 @@
 +    from_corefile = regcache_from_corefile (regcache);
 +
 +  if ((pointer_size == 32) && (from_corefile == 1))
-+    sparc32_collect_fpregset (&sparc32_sol2_fpregset, regcache, regnum, fpregs);
++    sparc32_collect_fpregset (&sparc32_sol2_fpregmap, regcache, regnum, fpregs);
 +  else
-+    sparc64_collect_fpregset (&sparc64_sol2_fpregset, regcache, regnum, fpregs);
++    sparc64_collect_fpregset (&sparc64_sol2_fpregmap, regcache, regnum, fpregs);
  }
  
  /* Provide a prototype to silence -Wmissing-prototypes.  */