aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorUlrich Weigand <uweigand@de.ibm.com>2007-05-06 14:09:20 +0000
committerUlrich Weigand <uweigand@de.ibm.com>2007-05-06 14:09:20 +0000
commit6a1872e49a9d6210fdc938dbc182f48f1070f262 (patch)
tree607b86ffb3d3f85f77ee96399378866b8759b947
parent8bf955e1b8d2d5d6327d28ab8c97c2c012b8f4cd (diff)
downloadgdb-6a1872e49a9d6210fdc938dbc182f48f1070f262.zip
gdb-6a1872e49a9d6210fdc938dbc182f48f1070f262.tar.gz
gdb-6a1872e49a9d6210fdc938dbc182f48f1070f262.tar.bz2
* irix5-nat.c (fill_gregset): Use regcache_raw_collect instead
of regcache_raw_read_signed. (fill_fpregset): Use regcache_raw_collect instead of regcache_raw_read.
-rw-r--r--gdb/ChangeLog7
-rw-r--r--gdb/irix5-nat.c48
2 files changed, 33 insertions, 22 deletions
diff --git a/gdb/ChangeLog b/gdb/ChangeLog
index 754592e..bd8acfd 100644
--- a/gdb/ChangeLog
+++ b/gdb/ChangeLog
@@ -1,3 +1,10 @@
+2007-05-06 Ulrich Weigand <uweigand@de.ibm.com>
+
+ * irix5-nat.c (fill_gregset): Use regcache_raw_collect instead
+ of regcache_raw_read_signed.
+ (fill_fpregset): Use regcache_raw_collect instead of
+ regcache_raw_read.
+
2007-05-03 Kevin Buettner <kevinb@redhat.com>
* mips-tdep.c (mips_eabi_push_dummy_call): When pushing floating
diff --git a/gdb/irix5-nat.c b/gdb/irix5-nat.c
index ff23a9a..184d8ce 100644
--- a/gdb/irix5-nat.c
+++ b/gdb/irix5-nat.c
@@ -81,9 +81,9 @@ supply_gregset (gregset_t *gregsetp)
void
fill_gregset (gregset_t *gregsetp, int regno)
{
- int regi;
+ int regi, size;
greg_t *regp = &(*gregsetp)[0];
- LONGEST regval;
+ gdb_byte buf[MAX_REGISTER_SIZE];
/* Under Irix6, if GDB is built with N32 ABI and is debugging an O32
executable, we have to sign extend the registers to 64 bits before
@@ -92,37 +92,41 @@ fill_gregset (gregset_t *gregsetp, int regno)
for (regi = 0; regi <= CTX_RA; regi++)
if ((regno == -1) || (regno == regi))
{
- regcache_raw_read_signed (current_regcache, regi, &regval);
- *(regp + regi) = regval;
+ size = register_size (current_gdbarch, regi);
+ regcache_raw_collect (current_regcache, regi, buf);
+ *(regp + regi) = extract_signed_integer (buf, size);
}
if ((regno == -1) || (regno == PC_REGNUM))
{
- regcache_raw_read_signed
- (current_regcache, mips_regnum (current_gdbarch)->pc, &regval);
- *(regp + CTX_EPC) = regval;
+ regi = mips_regnum (current_gdbarch)->pc;
+ size = register_size (current_gdbarch, regi);
+ regcache_raw_collect (current_regcache, regi, buf);
+ *(regp + CTX_EPC) = extract_signed_integer (buf, size);
}
if ((regno == -1) || (regno == mips_regnum (current_gdbarch)->cause))
{
- regcache_raw_read_signed
- (current_regcache, mips_regnum (current_gdbarch)->cause, &regval);
- *(regp + CTX_CAUSE) = regval;
+ regi = mips_regnum (current_gdbarch)->cause;
+ size = register_size (current_gdbarch, regi);
+ regcache_raw_collect (current_regcache, regi, buf);
+ *(regp + CTX_CAUSE) = extract_signed_integer (buf, size);
}
- if ((regno == -1)
- || (regno == mips_regnum (current_gdbarch)->hi))
+ if ((regno == -1) || (regno == mips_regnum (current_gdbarch)->hi))
{
- regcache_raw_read_signed
- (current_regcache, mips_regnum (current_gdbarch)->hi, &regval);
- *(regp + CTX_MDHI) = regval;
+ regi = mips_regnum (current_gdbarch)->hi;
+ size = register_size (current_gdbarch, regi);
+ regcache_raw_collect (current_regcache, regi, buf);
+ *(regp + CTX_MDHI) = extract_signed_integer (buf, size);
}
if ((regno == -1) || (regno == mips_regnum (current_gdbarch)->lo))
{
- regcache_raw_read_signed
- (current_regcache, mips_regnum (current_gdbarch)->lo, &regval);
- *(regp + CTX_MDLO) = regval;
+ regi = mips_regnum (current_gdbarch)->lo;
+ size = register_size (current_gdbarch, regi);
+ regcache_raw_collect (current_regcache, regi, buf);
+ *(regp + CTX_MDLO) = extract_signed_integer (buf, size);
}
}
@@ -178,7 +182,7 @@ fill_fpregset (fpregset_t *fpregsetp, int regno)
if ((regno == -1) || (regno == regi))
{
to = (char *) &(fpregsetp->fp_r.fp_regs[regi - FP0_REGNUM]);
- regcache_raw_read (current_regcache, regi, to);
+ regcache_raw_collect (current_regcache, regi, to);
}
}
@@ -192,9 +196,9 @@ fill_fpregset (fpregset_t *fpregsetp, int regno)
is 32bits long, while the regcache expects a 64bits long buffer.
So we use a buffer of the correct size and copy the register
value from that buffer. */
- regcache_raw_read (current_regcache,
- mips_regnum (current_gdbarch)->fp_control_status,
- fsrbuf);
+ regcache_raw_collect (current_regcache,
+ mips_regnum (current_gdbarch)->fp_control_status,
+ fsrbuf);
memcpy (&fpregsetp->fp_csr, fsrbuf + 4, 4);
}