projects
/
deliverable
/
binutils-gdb.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
change delegation for to_read_description
[deliverable/binutils-gdb.git]
/
gdb
/
vaxbsd-nat.c
diff --git
a/gdb/vaxbsd-nat.c
b/gdb/vaxbsd-nat.c
index 0529f3eec7ea54b4f160cd0ad8d4b31579b4cbed..bc31eca0fa5ae2b7c86827df90220ca5822d9029 100644
(file)
--- a/
gdb/vaxbsd-nat.c
+++ b/
gdb/vaxbsd-nat.c
@@
-1,12
+1,12
@@
-/* Native-dependent code for VAX BSD's.
+/* Native-dependent code for
modern
VAX BSD's.
- Copyright
200
4 Free Software Foundation, Inc.
+ Copyright
(C) 2004-201
4 Free Software Foundation, Inc.
This file is part of GDB.
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
This file is part of GDB.
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
- the Free Software Foundation; either version
2
of the License, or
+ the Free Software Foundation; either version
3
of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
(at your option) any later version.
This program is distributed in the hope that it will be useful,
@@
-15,26
+15,26
@@
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
- along with this program; if not, write to the Free Software
- Foundation, Inc., 59 Temple Place - Suite 330,
- Boston, MA 02111-1307, USA. */
+ along with this program. If not, see <http://www.gnu.org/licenses/>. */
#include "defs.h"
#include "inferior.h"
#include "regcache.h"
#include "defs.h"
#include "inferior.h"
#include "regcache.h"
+#include "target.h"
#include <sys/types.h>
#include <sys/ptrace.h>
#include <machine/reg.h>
#include "vax-tdep.h"
#include <sys/types.h>
#include <sys/ptrace.h>
#include <machine/reg.h>
#include "vax-tdep.h"
+#include "inf-ptrace.h"
/* Supply the general-purpose registers stored in GREGS to REGCACHE. */
static void
vaxbsd_supply_gregset (struct regcache *regcache, const void *gregs)
{
/* Supply the general-purpose registers stored in GREGS to REGCACHE. */
static void
vaxbsd_supply_gregset (struct regcache *regcache, const void *gregs)
{
- const
char
*regs = gregs;
+ const
gdb_byte
*regs = gregs;
int regnum;
for (regnum = 0; regnum < VAX_NUM_REGS; regnum++)
int regnum;
for (regnum = 0; regnum < VAX_NUM_REGS; regnum++)
@@
-48,7
+48,7
@@
static void
vaxbsd_collect_gregset (const struct regcache *regcache,
void *gregs, int regnum)
{
vaxbsd_collect_gregset (const struct regcache *regcache,
void *gregs, int regnum)
{
-
char
*regs = gregs;
+
gdb_byte
*regs = gregs;
int i;
for (i = 0; i <= VAX_NUM_REGS; i++)
int i;
for (i = 0; i <= VAX_NUM_REGS; i++)
@@
-62,41
+62,42
@@
vaxbsd_collect_gregset (const struct regcache *regcache,
/* Fetch register REGNUM from the inferior. If REGNUM is -1, do this
for all registers. */
/* Fetch register REGNUM from the inferior. If REGNUM is -1, do this
for all registers. */
-void
-fetch_inferior_registers (int regnum)
+static void
+vaxbsd_fetch_inferior_registers (struct target_ops *ops,
+ struct regcache *regcache, int regnum)
{
struct reg regs;
{
struct reg regs;
- if (ptrace (PT_GETREGS,
PIDGET
(inferior_ptid),
- (PTRACE_
ARG3_TYPE
) ®s, 0) == -1)
- perror_with_name (
"Couldn't get registers"
);
+ if (ptrace (PT_GETREGS,
ptid_get_pid
(inferior_ptid),
+ (PTRACE_
TYPE_ARG3
) ®s, 0) == -1)
+ perror_with_name (
_("Couldn't get registers")
);
- vaxbsd_supply_gregset (
current_
regcache, ®s);
+ vaxbsd_supply_gregset (regcache, ®s);
}
/* Store register REGNUM back into the inferior. If REGNUM is -1, do
this for all registers. */
}
/* Store register REGNUM back into the inferior. If REGNUM is -1, do
this for all registers. */
-void
-store_inferior_registers (int regnum)
+static void
+vaxbsd_store_inferior_registers (struct target_ops *ops,
+ struct regcache *regcache, int regnum)
{
struct reg regs;
{
struct reg regs;
- if (ptrace (PT_GETREGS,
PIDGET
(inferior_ptid),
- (PTRACE_
ARG3_TYPE
) ®s, 0) == -1)
- perror_with_name (
"Couldn't get registers"
);
+ if (ptrace (PT_GETREGS,
ptid_get_pid
(inferior_ptid),
+ (PTRACE_
TYPE_ARG3
) ®s, 0) == -1)
+ perror_with_name (
_("Couldn't get registers")
);
- vaxbsd_collect_gregset (
current_
regcache, ®s, regnum);
+ vaxbsd_collect_gregset (regcache, ®s, regnum);
- if (ptrace (PT_SETREGS,
PIDGET
(inferior_ptid),
- (PTRACE_
ARG3_TYPE
) ®s, 0) == -1)
- perror_with_name (
"Couldn't write registers"
);
+ if (ptrace (PT_SETREGS,
ptid_get_pid
(inferior_ptid),
+ (PTRACE_
TYPE_ARG3
) ®s, 0) == -1)
+ perror_with_name (
_("Couldn't write registers")
);
}
\f
/* Support for debugging kernel virtual memory images. */
}
\f
/* Support for debugging kernel virtual memory images. */
-#include <sys/types.h>
#include <machine/pcb.h>
#include "bsd-kvm.h"
#include <machine/pcb.h>
#include "bsd-kvm.h"
@@
-133,6
+134,13
@@
void _initialize_vaxbsd_nat (void);
void
_initialize_vaxbsd_nat (void)
{
void
_initialize_vaxbsd_nat (void)
{
+ struct target_ops *t;
+
+ t = inf_ptrace_target ();
+ t->to_fetch_registers = vaxbsd_fetch_inferior_registers;
+ t->to_store_registers = vaxbsd_store_inferior_registers;
+ add_target (t);
+
/* Support debugging kernel virtual memory images. */
bsd_kvm_add_target (vaxbsd_supply_pcb);
}
/* Support debugging kernel virtual memory images. */
bsd_kvm_add_target (vaxbsd_supply_pcb);
}
This page took
0.029504 seconds
and
4
git commands to generate.