projects
/
deliverable
/
binutils-gdb.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
PR25172, Wrong description of --stop-address=ADDR switch
[deliverable/binutils-gdb.git]
/
gdb
/
sh-nbsd-nat.c
diff --git
a/gdb/sh-nbsd-nat.c
b/gdb/sh-nbsd-nat.c
index 90c9689899d9157f5c07e384a0d181f15b46f4b8..1717ff93f553d4351a36278ef5b81f70da41ca0b 100644
(file)
--- a/
gdb/sh-nbsd-nat.c
+++ b/
gdb/sh-nbsd-nat.c
@@
-1,6
+1,6
@@
/* Native-dependent code for NetBSD/sh.
/* Native-dependent code for NetBSD/sh.
- Copyright (C) 2002-201
7
Free Software Foundation, Inc.
+ Copyright (C) 2002-201
9
Free Software Foundation, Inc.
Contributed by Wasabi Systems, Inc.
Contributed by Wasabi Systems, Inc.
@@
-30,6
+30,13
@@
#include "inf-ptrace.h"
#include "regcache.h"
#include "inf-ptrace.h"
#include "regcache.h"
+struct sh_nbsd_nat_target final : public inf_ptrace_target
+{
+ void fetch_registers (struct regcache *, int) override;
+ void store_registers (struct regcache *, int) override;
+};
+
+static sh_nbsd_nat_target the_sh_nbsd_nat_target;
/* Determine if PT_GETREGS fetches this register. */
#define GETREGS_SUPPLIES(gdbarch, regno) \
/* Determine if PT_GETREGS fetches this register. */
#define GETREGS_SUPPLIES(gdbarch, regno) \
@@
-41,15
+48,16
@@
/* Sizeof `struct reg' in <machine/reg.h>. */
#define SHNBSD_SIZEOF_GREGS (21 * 4)
/* Sizeof `struct reg' in <machine/reg.h>. */
#define SHNBSD_SIZEOF_GREGS (21 * 4)
-static void
-shnbsd_fetch_inferior_registers (struct target_ops *ops,
- struct regcache *regcache, int regno)
+void
+sh_nbsd_nat_target::fetch_registers (struct regcache *regcache, int regno)
{
{
- if (regno == -1 || GETREGS_SUPPLIES (get_regcache_arch (regcache), regno))
+ pid_t pid = regcache->ptid ().pid ();
+
+ if (regno == -1 || GETREGS_SUPPLIES (regcache->arch (), regno))
{
struct reg inferior_registers;
{
struct reg inferior_registers;
- if (ptrace (PT_GETREGS, p
tid_get_pid (inferior_ptid)
,
+ if (ptrace (PT_GETREGS, p
id
,
(PTRACE_TYPE_ARG3) &inferior_registers, 0) == -1)
perror_with_name (_("Couldn't get registers"));
(PTRACE_TYPE_ARG3) &inferior_registers, 0) == -1)
perror_with_name (_("Couldn't get registers"));
@@
-62,15
+70,16
@@
shnbsd_fetch_inferior_registers (struct target_ops *ops,
}
}
}
}
-static void
-shnbsd_store_inferior_registers (struct target_ops *ops,
- struct regcache *regcache, int regno)
+void
+sh_nbsd_nat_target::store_registers (struct regcache *regcache, int regno)
{
{
- if (regno == -1 || GETREGS_SUPPLIES (get_regcache_arch (regcache), regno))
+ pid_t pid = regcache->ptid ().pid ();
+
+ if (regno == -1 || GETREGS_SUPPLIES (regcache->arch (), regno))
{
struct reg inferior_registers;
{
struct reg inferior_registers;
- if (ptrace (PT_GETREGS, p
tid_get_pid (inferior_ptid)
,
+ if (ptrace (PT_GETREGS, p
id
,
(PTRACE_TYPE_ARG3) &inferior_registers, 0) == -1)
perror_with_name (_("Couldn't get registers"));
(PTRACE_TYPE_ARG3) &inferior_registers, 0) == -1)
perror_with_name (_("Couldn't get registers"));
@@
-78,7
+87,7
@@
shnbsd_store_inferior_registers (struct target_ops *ops,
(char *) &inferior_registers,
SHNBSD_SIZEOF_GREGS);
(char *) &inferior_registers,
SHNBSD_SIZEOF_GREGS);
- if (ptrace (PT_SETREGS, p
tid_get_pid (inferior_ptid)
,
+ if (ptrace (PT_SETREGS, p
id
,
(PTRACE_TYPE_ARG3) &inferior_registers, 0) == -1)
perror_with_name (_("Couldn't set registers"));
(PTRACE_TYPE_ARG3) &inferior_registers, 0) == -1)
perror_with_name (_("Couldn't set registers"));
@@
-87,16
+96,8
@@
shnbsd_store_inferior_registers (struct target_ops *ops,
}
}
}
}
-/* Provide a prototype to silence -Wmissing-prototypes. */
-void _initialize_shnbsd_nat (void);
-
void
_initialize_shnbsd_nat (void)
{
void
_initialize_shnbsd_nat (void)
{
- struct target_ops *t;
-
- t = inf_ptrace_target ();
- t->to_fetch_registers = shnbsd_fetch_inferior_registers;
- t->to_store_registers = shnbsd_store_inferior_registers;
- add_target (t);
+ add_inf_child_target (&the_sh_nbsd_nat_target);
}
}
This page took
0.026231 seconds
and
4
git commands to generate.