diff options
author | Daniel Jacobowitz <dan@debian.org> | 2006-07-27 21:27:12 +0000 |
---|---|---|
committer | Daniel Jacobowitz <dan@debian.org> | 2006-07-27 21:27:12 +0000 |
commit | 6e7e4709878d5b5e9139d1ca00d9f699fd0abbf0 (patch) | |
tree | 20a71915415d9d7c49195ad0f975ea063eb3770d /gdb/irix5-nat.c | |
parent | 3c2e5d9b41c890f4ac61c5932417b23415104742 (diff) | |
download | gdb-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.c | 39 |
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. |