summaryrefslogtreecommitdiff
path: root/gdb/irix5-nat.c
diff options
context:
space:
mode:
authorDaniel Jacobowitz <dan@debian.org>2006-07-27 21:27:12 +0000
committerDaniel Jacobowitz <dan@debian.org>2006-07-27 21:27:12 +0000
commit6e7e4709878d5b5e9139d1ca00d9f699fd0abbf0 (patch)
tree20a71915415d9d7c49195ad0f975ea063eb3770d /gdb/irix5-nat.c
parent3c2e5d9b41c890f4ac61c5932417b23415104742 (diff)
downloadgdb-6e7e4709878d5b5e9139d1ca00d9f699fd0abbf0.tar.gz
* irix5-nat.c (fetch_core_registers): Simplify and correct logic.
Diffstat (limited to 'gdb/irix5-nat.c')
-rw-r--r--gdb/irix5-nat.c39
1 files changed, 11 insertions, 28 deletions
diff --git a/gdb/irix5-nat.c b/gdb/irix5-nat.c
index c39e0faa5b7..e7ce4721065 100644
--- a/gdb/irix5-nat.c
+++ b/gdb/irix5-nat.c
@@ -1,7 +1,7 @@
/* Native support for the SGI Iris running IRIX version 5, for GDB.
Copyright (C) 1988, 1989, 1990, 1991, 1992, 1993, 1994, 1995, 1996,
- 1998, 1999, 2000, 2001, 2002, 2004 Free Software Foundation, Inc.
+ 1998, 1999, 2000, 2001, 2002, 2004, 2006 Free Software Foundation, Inc.
Contributed by Alessandro Forin(af@cs.cmu.edu) at CMU
and by Per Bothner(bothner@cs.wisc.edu) at U.Wisconsin.
@@ -242,39 +242,22 @@ fetch_core_registers (char *core_reg_sect, unsigned core_reg_size,
int which, CORE_ADDR reg_addr)
{
char *srcp = core_reg_sect;
+ int regsize = mips_isa_regsize (current_gdbarch);
int regno;
- if (core_reg_size == deprecated_register_bytes ())
- {
- for (regno = 0; regno < NUM_REGS; regno++)
- {
- regcache_raw_write (current_regcache, regno, srcp);
- srcp += register_size (current_gdbarch, regno);
- }
- }
- else if (mips_isa_regsize (current_gdbarch) == 4 &&
- core_reg_size == (2 * mips_isa_regsize (current_gdbarch)) * NUM_REGS)
- {
- /* This is a core file from a N32 executable, 64 bits are saved
- for all registers. */
- for (regno = 0; regno < NUM_REGS; regno++)
- {
- if (regno >= FP0_REGNUM && regno < (FP0_REGNUM + 32))
- {
- regcache_raw_write (current_regcache, regno, srcp);
- }
- else
- {
- regcache_raw_write (current_regcache, regno, srcp + 4);
- }
- srcp += 8;
- }
- }
- else
+ /* If regsize is 8, this is a N32 or N64 core file.
+ If regsize is 4, this is an O32 core file. */
+ if (core_reg_size != regsize * NUM_REGS)
{
warning (_("wrong size gregset struct in core file"));
return;
}
+
+ for (regno = 0; regno < NUM_REGS; regno++)
+ {
+ regcache_raw_write (current_regcache, regno, srcp);
+ srcp += regsize;
+ }
}
/* Register that we are able to handle irix5 core file formats.