From 47c8f7894f1a2b8718e2cd18b21a17619d874f34 Mon Sep 17 00:00:00 2001 From: Tor Egge Date: Fri, 27 Jun 1997 15:48:22 +0000 Subject: [PATCH] Don't depend upon the user structure having been aligned on a 8 KB boundary. Reviewed by: Peter Wemm --- gnu/usr.bin/binutils/gdb/i386/freebsd-nat.c | 13 ++++++++++++- gnu/usr.bin/gdb/gdb/freebsd-nat.c | 13 ++++++++++++- 2 files changed, 24 insertions(+), 2 deletions(-) diff --git a/gnu/usr.bin/binutils/gdb/i386/freebsd-nat.c b/gnu/usr.bin/binutils/gdb/i386/freebsd-nat.c index c7c506f6db3c..4fdb09f28312 100644 --- a/gnu/usr.bin/binutils/gdb/i386/freebsd-nat.c +++ b/gnu/usr.bin/binutils/gdb/i386/freebsd-nat.c @@ -23,6 +23,8 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ #include #include #include +#include +#include #include "gdbcore.h" #include "value.h" #include "inferior.h" @@ -91,8 +93,17 @@ fetch_core_registers (core_reg_sect, core_reg_size, which, reg_addr) register int cregno; register int addr; int bad_reg = -1; - int offset = -reg_addr & (core_reg_size - 1); + int offset; + struct user *tmp_uaddr; + /* + * First get virtual address of user structure. Then calculate offset. + */ + memcpy(&tmp_uaddr, + &((struct user *) core_reg_sect)->u_kproc.kp_proc.p_addr, + sizeof(tmp_uaddr)); + offset = -reg_addr - (int) tmp_uaddr; + for (regno = 0; regno < NUM_REGS; regno++) { cregno = tregmap[regno]; diff --git a/gnu/usr.bin/gdb/gdb/freebsd-nat.c b/gnu/usr.bin/gdb/gdb/freebsd-nat.c index c7c506f6db3c..4fdb09f28312 100644 --- a/gnu/usr.bin/gdb/gdb/freebsd-nat.c +++ b/gnu/usr.bin/gdb/gdb/freebsd-nat.c @@ -23,6 +23,8 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ #include #include #include +#include +#include #include "gdbcore.h" #include "value.h" #include "inferior.h" @@ -91,8 +93,17 @@ fetch_core_registers (core_reg_sect, core_reg_size, which, reg_addr) register int cregno; register int addr; int bad_reg = -1; - int offset = -reg_addr & (core_reg_size - 1); + int offset; + struct user *tmp_uaddr; + /* + * First get virtual address of user structure. Then calculate offset. + */ + memcpy(&tmp_uaddr, + &((struct user *) core_reg_sect)->u_kproc.kp_proc.p_addr, + sizeof(tmp_uaddr)); + offset = -reg_addr - (int) tmp_uaddr; + for (regno = 0; regno < NUM_REGS; regno++) { cregno = tregmap[regno];