summaryrefslogtreecommitdiff
path: root/gdb/i386gnu-nat.c
diff options
context:
space:
mode:
authorMark Kettenis <kettenis@gnu.org>2004-10-11 20:03:55 +0000
committerMark Kettenis <kettenis@gnu.org>2004-10-11 20:03:55 +0000
commit6bc071f16b69b193775050c9f77555e998089e87 (patch)
tree2b765ebf548b1ac53848bcbba63b459e46bbfc3a /gdb/i386gnu-nat.c
parent6870494e6e9d26d768c36633f478f08883bda6f3 (diff)
downloadgdb-6bc071f16b69b193775050c9f77555e998089e87.tar.gz
* i386gnu-nat.c: Include "gdb_string.h".
(fetch_fpregs): Use i387_supply_fxsave to fill the floating-point registers when the floating-point state isn't initialized. * Makefile.in (i386gnu-nat.o): Update dependencies.
Diffstat (limited to 'gdb/i386gnu-nat.c')
-rw-r--r--gdb/i386gnu-nat.c23
1 files changed, 11 insertions, 12 deletions
diff --git a/gdb/i386gnu-nat.c b/gdb/i386gnu-nat.c
index f694eba91e5..023fbb7d6e8 100644
--- a/gdb/i386gnu-nat.c
+++ b/gdb/i386gnu-nat.c
@@ -28,6 +28,7 @@
#include "gdb_assert.h"
#include <errno.h>
#include <stdio.h>
+#include "gdb_string.h"
#include <mach.h>
#include <mach_error.h>
@@ -60,8 +61,9 @@ static int reg_offset[] =
#define REG_ADDR(state, regnum) ((char *)(state) + reg_offset[regnum])
-/* Get the whole floating-point state of THREAD and record the
- values of the corresponding (pseudo) registers. */
+/* Get the whole floating-point state of THREAD and record the values
+ of the corresponding (pseudo) registers. */
+
static void
fetch_fpregs (struct proc *thread)
{
@@ -79,18 +81,15 @@ fetch_fpregs (struct proc *thread)
}
if (!state.initialized)
- /* The floating-point state isn't initialized. */
{
- int i;
-
- for (i = FP0_REGNUM; i <= FOP_REGNUM; i++)
- regcache_raw_supply (current_regcache, i, NULL);
-
- return;
+ /* The floating-point state isn't initialized. */
+ i387_supply_fsave (current_regcache, -1, NULL);
+ }
+ else
+ {
+ /* Supply the floating-point registers. */
+ i387_supply_fsave (current_regcache, -1, state.hw_state);
}
-
- /* Supply the floating-point registers. */
- i387_supply_fsave (current_regcache, -1, state.hw_state);
}
#ifdef HAVE_SYS_PROCFS_H