projects
/
deliverable
/
binutils-gdb.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
merge from gcc
[deliverable/binutils-gdb.git]
/
gdb
/
ppcnbsd-tdep.c
diff --git
a/gdb/ppcnbsd-tdep.c
b/gdb/ppcnbsd-tdep.c
index 12ac5cb06f930c8caab2e6c9fec7c03db4b0c37d..ccf1b2ca64086a4ceae88e3eba65c4f802f13d74 100644
(file)
--- a/
gdb/ppcnbsd-tdep.c
+++ b/
gdb/ppcnbsd-tdep.c
@@
-1,6
+1,6
@@
/* Target-dependent code for NetBSD/powerpc.
/* Target-dependent code for NetBSD/powerpc.
- Copyright (C) 2002, 2003, 2004, 2005, 2006, 2007
+ Copyright (C) 2002, 2003, 2004, 2005, 2006, 2007
, 2008, 2009, 2010
Free Software Foundation, Inc.
Contributed by Wasabi Systems, Inc.
Free Software Foundation, Inc.
Contributed by Wasabi Systems, Inc.
@@
-9,7
+9,7
@@
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 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,
@@
-18,9
+18,7
@@
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., 51 Franklin Street, Fifth Floor,
- Boston, MA 02110-1301, USA. */
+ along with this program. If not, see <http://www.gnu.org/licenses/>. */
#include "defs.h"
#include "gdbtypes.h"
#include "defs.h"
#include "gdbtypes.h"
@@
-79,9
+77,9
@@
ppcnbsd_regset_from_core_section (struct gdbarch *gdbarch,
the moment use the broken convention. Ulgh!. */
static enum return_value_convention
the moment use the broken convention. Ulgh!. */
static enum return_value_convention
-ppcnbsd_return_value (struct gdbarch *gdbarch, struct type *
val
type,
- struct
regcache *regcache, gdb_byte *readbuf
,
- const gdb_byte *writebuf)
+ppcnbsd_return_value (struct gdbarch *gdbarch, struct type *
func_
type,
+ struct
type *valtype, struct regcache *regcache
,
+
gdb_byte *readbuf,
const gdb_byte *writebuf)
{
#if 0
if ((TYPE_CODE (valtype) == TYPE_CODE_STRUCT
{
#if 0
if ((TYPE_CODE (valtype) == TYPE_CODE_STRUCT
@@
-95,8
+93,8
@@
ppcnbsd_return_value (struct gdbarch *gdbarch, struct type *valtype,
return RETURN_VALUE_STRUCT_CONVENTION;
else
#endif
return RETURN_VALUE_STRUCT_CONVENTION;
else
#endif
- return ppc_sysv_abi_broken_return_value (gdbarch,
valtype, regcach
e,
- readbuf, writebuf);
+ return ppc_sysv_abi_broken_return_value (gdbarch,
func_type, valtyp
e,
+ re
gcache, re
adbuf, writebuf);
}
\f
}
\f
@@
-106,16
+104,17
@@
static const struct tramp_frame ppcnbsd2_sigtramp;
static void
ppcnbsd_sigtramp_cache_init (const struct tramp_frame *self,
static void
ppcnbsd_sigtramp_cache_init (const struct tramp_frame *self,
- struct frame_info *
next
_frame,
+ struct frame_info *
this
_frame,
struct trad_frame_cache *this_cache,
CORE_ADDR func)
{
struct trad_frame_cache *this_cache,
CORE_ADDR func)
{
- struct gdbarch *gdbarch = get_frame_arch (
next
_frame);
+ struct gdbarch *gdbarch = get_frame_arch (
this
_frame);
struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
CORE_ADDR addr, base;
int i;
struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
CORE_ADDR addr, base;
int i;
- base = frame_unwind_register_unsigned (next_frame, SP_REGNUM);
+ base = get_frame_register_unsigned (this_frame,
+ gdbarch_sp_regnum (gdbarch));
if (self == &ppcnbsd2_sigtramp)
addr = base + 0x10 + 2 * tdep->wordsize;
else
if (self == &ppcnbsd2_sigtramp)
addr = base + 0x10 + 2 * tdep->wordsize;
else
@@
-133,7
+132,8
@@
ppcnbsd_sigtramp_cache_init (const struct tramp_frame *self,
addr += tdep->wordsize;
trad_frame_set_reg_addr (this_cache, tdep->ppc_ctr_regnum, addr);
addr += tdep->wordsize;
addr += tdep->wordsize;
trad_frame_set_reg_addr (this_cache, tdep->ppc_ctr_regnum, addr);
addr += tdep->wordsize;
- trad_frame_set_reg_addr (this_cache, PC_REGNUM, addr); /* SRR0? */
+ trad_frame_set_reg_addr (this_cache, gdbarch_pc_regnum (gdbarch),
+ addr); /* SRR0? */
addr += tdep->wordsize;
/* Construct the frame ID using the function start. */
addr += tdep->wordsize;
/* Construct the frame ID using the function start. */
@@
-212,6
+212,8
@@
_initialize_ppcnbsd_tdep (void)
{
/* General-purpose registers. */
ppcnbsd_reg_offsets.r0_offset = 0;
{
/* General-purpose registers. */
ppcnbsd_reg_offsets.r0_offset = 0;
+ ppcnbsd_reg_offsets.gpr_size = 4;
+ ppcnbsd_reg_offsets.xr_size = 4;
ppcnbsd_reg_offsets.lr_offset = 128;
ppcnbsd_reg_offsets.cr_offset = 132;
ppcnbsd_reg_offsets.xer_offset = 136;
ppcnbsd_reg_offsets.lr_offset = 128;
ppcnbsd_reg_offsets.cr_offset = 132;
ppcnbsd_reg_offsets.xer_offset = 136;
@@
-223,6
+225,7
@@
_initialize_ppcnbsd_tdep (void)
/* Floating-point registers. */
ppcnbsd_reg_offsets.f0_offset = 0;
ppcnbsd_reg_offsets.fpscr_offset = 256;
/* Floating-point registers. */
ppcnbsd_reg_offsets.f0_offset = 0;
ppcnbsd_reg_offsets.fpscr_offset = 256;
+ ppcnbsd_reg_offsets.fpscr_size = 4;
/* AltiVec registers. */
ppcnbsd_reg_offsets.vr0_offset = 0;
/* AltiVec registers. */
ppcnbsd_reg_offsets.vr0_offset = 0;
This page took
0.024666 seconds
and
4
git commands to generate.