diff options
Diffstat (limited to 'gdb/sparc-linux-nat.c')
-rw-r--r-- | gdb/sparc-linux-nat.c | 25 |
1 files changed, 15 insertions, 10 deletions
diff --git a/gdb/sparc-linux-nat.c b/gdb/sparc-linux-nat.c index 3a5132c..c32d0ec 100644 --- a/gdb/sparc-linux-nat.c +++ b/gdb/sparc-linux-nat.c @@ -28,6 +28,19 @@ #include "target.h" #include "linux-nat.h" +class sparc_linux_nat_target final : public linux_nat_target +{ +public: + /* Add our register access methods. */ + void fetch_registers (struct regcache *regcache, int regnum) override + { sparc_fetch_inferior_registers (regcache, regnum); } + + void store_registers (struct regcache *regcache, int regnum) override; + { sparc_store_inferior_registers (regcache, regnum); } +}; + +static sparc_linux_nat_target the_sparc_linux_nat_target; + void supply_gregset (struct regcache *regcache, const prgregset_t *gregs) { @@ -56,17 +69,9 @@ fill_fpregset (const struct regcache *regcache, void _initialize_sparc_linux_nat (void) { - struct target_ops *t; - - /* Fill in the generic GNU/Linux methods. */ - t = linux_target (); - sparc_fpregmap = &sparc32_bsd_fpregmap; - /* Add our register access methods. */ - t->to_fetch_registers = sparc_fetch_inferior_registers; - t->to_store_registers = sparc_store_inferior_registers; - /* Register the target. */ - linux_nat_add_target (t); + linux_target = &the_sparc_linux_nat_target; + add_target (&the_sparc_linux_nat_target); } |