Source-Changes-HG archive

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

[src/trunk]: src/external/gpl3/gdb/dist/gdb put back the kvm stuff lost in pr...



details:   https://anonhg.NetBSD.org/src/rev/d63578111a51
branches:  trunk
changeset: 1000189:d63578111a51
user:      christos <christos%NetBSD.org@localhost>
date:      Fri Jul 12 22:43:15 2019 +0000

description:
put back the kvm stuff lost in previous merge.

diffstat:

 external/gpl3/gdb/dist/gdb/mips-nbsd-nat.c |  46 +++++++++++++++++++++++------
 1 files changed, 36 insertions(+), 10 deletions(-)

diffs (65 lines):

diff -r 7544794558cb -r d63578111a51 external/gpl3/gdb/dist/gdb/mips-nbsd-nat.c
--- a/external/gpl3/gdb/dist/gdb/mips-nbsd-nat.c        Fri Jul 12 22:42:45 2019 +0000
+++ b/external/gpl3/gdb/dist/gdb/mips-nbsd-nat.c        Fri Jul 12 22:43:15 2019 +0000
@@ -28,16 +28,6 @@
 #include <sys/ptrace.h>
 #include <machine/reg.h>
 
-#ifndef HAVE_GREGSET_T
-typedef struct reg gregset_t;
-#endif
-
-#ifndef HAVE_FPREGSET_T
-typedef struct fpreg fpregset_t;
-#endif
-
-#include "gregset.h"
-
 #include "mips-tdep.h"
 #include "nbsd-nat.h"
 #include "mips-nbsd-tdep.h"
@@ -133,8 +123,44 @@
     }
 }
 
+static int
+mipsnbsd_supply_pcb (struct regcache *regcache, struct pcb *pcb)
+{
+  struct label_t sf;
+
+  sf = pcb->pcb_context;
+
+  /* really should test for n{32,64} abi for this register
+     unless this is purely the "n" ABI */
+
+  regcache->raw_supply (MIPS_S0_REGNUM, &sf.val[_L_S0]);
+  regcache->raw_supply (MIPS_S1_REGNUM, &sf.val[_L_S1]);
+  regcache->raw_supply (MIPS_S2_REGNUM, &sf.val[_L_S2]);
+  regcache->raw_supply (MIPS_S3_REGNUM, &sf.val[_L_S3]);
+  regcache->raw_supply (MIPS_S4_REGNUM, &sf.val[_L_S4]);
+  regcache->raw_supply (MIPS_S5_REGNUM, &sf.val[_L_S5]);
+  regcache->raw_supply (MIPS_S6_REGNUM, &sf.val[_L_S6]);
+  regcache->raw_supply (MIPS_S7_REGNUM, &sf.val[_L_S7]);
+
+  regcache->raw_supply (MIPS_S8_REGNUM, &sf.val[_L_S8]);
+
+  regcache->raw_supply (MIPS_T8_REGNUM, &sf.val[_L_T8]);
+
+  regcache->raw_supply (MIPS_GP_REGNUM, &sf.val[_L_GP]);
+
+  regcache->raw_supply (MIPS_SP_REGNUM, &sf.val[_L_SP]);
+  regcache->raw_supply (MIPS_RA_REGNUM, &sf.val[_L_RA]);
+  regcache->raw_supply (MIPS_PS_REGNUM, &sf.val[_L_SR]);
+
+  /* provide the return address of the savectx as the current pc */
+  regcache->raw_supply (MIPS_EMBED_PC_REGNUM, &sf.val[_L_RA]);
+
+  return 0;
+}
+
 void
 _initialize_mipsnbsd_nat (void)
 {
   add_inf_child_target (&the_mips_nbsd_nat_target);
+  bsd_kvm_add_target (mipsnbsd_supply_pcb);
 }



Home | Main Index | Thread Index | Old Index