144 lines
5.3 KiB
Diff
144 lines
5.3 KiB
Diff
|
2005-03-17 Daniel Jacobowitz <dan@codesourcery.com>
|
||
|
|
||
|
* linux-mips-low.c: Include "gdb_proc_service.h".
|
||
|
(PTRACE_GET_THREAD_AREA): Define.
|
||
|
(ps_get_thread_area): New function.
|
||
|
* Makefile.in: Update dependencies for linux-mips-low.o,
|
||
|
linux-i386-low.o, and linux-x86-64-low.o.
|
||
|
|
||
|
2005-03-17 Daniel Jacobowitz <dan@codesourcery.com>
|
||
|
|
||
|
* linux-mips-low.c: Include "gdb_proc_service.h".
|
||
|
(PTRACE_GET_THREAD_AREA): Define.
|
||
|
(ps_get_thread_area): New function.
|
||
|
* Makefile.in (mips-linux-nat.o): Update dependencies.
|
||
|
--
|
||
|
diff -urN gdb-6.3.50.20050915/gdb/Makefile.in gdb-6.3.50.20050915-patched/gdb/Makefile.in
|
||
|
--- gdb-6.3.50.20050915/gdb/Makefile.in 2005-09-10 13:11:01.000000000 -0500
|
||
|
+++ gdb-6.3.50.20050915-patched/gdb/Makefile.in 2005-09-15 19:24:39.000000000 -0500
|
||
|
@@ -2282,7 +2282,7 @@
|
||
|
$(gdb_string_h) $(mips_tdep_h) $(solib_svr4_h)
|
||
|
mips-irix-tdep.o: mips-irix-tdep.c $(defs_h) $(osabi_h) $(elf_bfd_h)
|
||
|
mips-linux-nat.o: mips-linux-nat.c $(defs_h) $(mips_tdep_h) $(target_h) \
|
||
|
- $(linux_nat_h)
|
||
|
+ $(linux_nat_h) $(gdb_proc_service_h)
|
||
|
mips-linux-tdep.o: mips-linux-tdep.c $(defs_h) $(gdbcore_h) $(target_h) \
|
||
|
$(solib_svr4_h) $(osabi_h) $(mips_tdep_h) $(gdb_string_h) \
|
||
|
$(gdb_assert_h) $(frame_h) $(regcache_h) $(trad_frame_h) \
|
||
|
diff -urN gdb-6.3.50.20050915/gdb/gdbserver/Makefile.in gdb-6.3.50.20050915-patched/gdb/gdbserver/Makefile.in
|
||
|
--- gdb-6.3.50.20050915/gdb/gdbserver/Makefile.in 2005-05-28 17:09:04.000000000 -0500
|
||
|
+++ gdb-6.3.50.20050915-patched/gdb/gdbserver/Makefile.in 2005-09-15 19:20:01.000000000 -0500
|
||
|
@@ -267,15 +267,18 @@
|
||
|
linux-arm-low.o: linux-arm-low.c $(linux_low_h) $(server_h)
|
||
|
linux-cris-low.o: linux-cris-low.c $(linux_low_h) $(server_h)
|
||
|
linux-crisv32-low.o: linux-crisv32-low.c $(linux_low_h) $(server_h)
|
||
|
-linux-i386-low.o: linux-i386-low.c $(linux_low_h) $(server_h)
|
||
|
+linux-i386-low.o: linux-i386-low.c $(linux_low_h) $(server_h) \
|
||
|
+ $(gdb_proc_service_h)
|
||
|
linux-ia64-low.o: linux-ia64-low.c $(linux_low_h) $(server_h)
|
||
|
linux-m32r-low.o: linux-m32r-low.c $(linux_low_h) $(server_h)
|
||
|
-linux-mips-low.o: linux-mips-low.c $(linux_low_h) $(server_h)
|
||
|
+linux-mips-low.o: linux-mips-low.c $(linux_low_h) $(server_h) \
|
||
|
+ $(gdb_proc_service_h)
|
||
|
linux-ppc-low.o: linux-ppc-low.c $(linux_low_h) $(server_h)
|
||
|
linux-ppc64-low.o: linux-ppc64-low.c $(linux_low_h) $(server_h)
|
||
|
linux-s390-low.o: linux-s390-low.c $(linux_low_h) $(server_h)
|
||
|
linux-sh-low.o: linux-sh-low.c $(linux_low_h) $(server_h)
|
||
|
-linux-x86-64-low.o: linux-x86-64-low.c $(linux_low_h) $(server_h)
|
||
|
+linux-x86-64-low.o: linux-x86-64-low.c $(linux_low_h) $(server_h) \
|
||
|
+ $(gdb_proc_service_h)
|
||
|
|
||
|
reg-arm.o : reg-arm.c $(regdef_h)
|
||
|
reg-arm.c : $(srcdir)/../regformats/reg-arm.dat $(regdat_sh)
|
||
|
diff -urN gdb-6.3.50.20050915/gdb/gdbserver/linux-mips-low.c gdb-6.3.50.20050915-patched/gdb/gdbserver/linux-mips-low.c
|
||
|
--- gdb-6.3.50.20050915/gdb/gdbserver/linux-mips-low.c 2005-06-12 20:59:22.000000000 -0500
|
||
|
+++ gdb-6.3.50.20050915-patched/gdb/gdbserver/linux-mips-low.c 2005-09-15 19:16:54.000000000 -0500
|
||
|
@@ -22,6 +22,26 @@
|
||
|
#include "server.h"
|
||
|
#include "linux-low.h"
|
||
|
|
||
|
+#include <sys/ptrace.h>
|
||
|
+
|
||
|
+/* Correct for all GNU/Linux targets (for quite some time). */
|
||
|
+#define GDB_GREGSET_T elf_gregset_t
|
||
|
+#define GDB_FPREGSET_T elf_fpregset_t
|
||
|
+
|
||
|
+#ifndef HAVE_ELF_FPREGSET_T
|
||
|
+/* Make sure we have said types. Not all platforms bring in <linux/elf.h>
|
||
|
+ via <sys/procfs.h>. */
|
||
|
+#ifdef HAVE_LINUX_ELF_H
|
||
|
+#include <linux/elf.h>
|
||
|
+#endif
|
||
|
+#endif
|
||
|
+
|
||
|
+#include "../gdb_proc_service.h"
|
||
|
+
|
||
|
+#ifndef PTRACE_GET_THREAD_AREA
|
||
|
+#define PTRACE_GET_THREAD_AREA 25
|
||
|
+#endif
|
||
|
+
|
||
|
#ifdef HAVE_SYS_REG_H
|
||
|
#include <sys/reg.h>
|
||
|
#endif
|
||
|
@@ -140,6 +160,23 @@
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
+/* Fetch the thread-local storage pointer for libthread_db. */
|
||
|
+
|
||
|
+ps_err_e
|
||
|
+ps_get_thread_area (const struct ps_prochandle *ph,
|
||
|
+ lwpid_t lwpid, int idx, void **base)
|
||
|
+{
|
||
|
+ if (ptrace (PTRACE_GET_THREAD_AREA, lwpid, NULL, base) != 0)
|
||
|
+ return PS_ERR;
|
||
|
+
|
||
|
+ /* IDX is the bias from the thread pointer to the beginning of the
|
||
|
+ thread descriptor. It has to be subtracted due to implementation
|
||
|
+ quirks in libthread_db. */
|
||
|
+ *base = (void *) ((char *)*base - idx);
|
||
|
+
|
||
|
+ return PS_OK;
|
||
|
+}
|
||
|
+
|
||
|
struct linux_target_ops the_low_target = {
|
||
|
mips_num_regs,
|
||
|
mips_regmap,
|
||
|
diff -urN gdb-6.3.50.20050915/gdb/mips-linux-nat.c gdb-6.3.50.20050915-patched/gdb/mips-linux-nat.c
|
||
|
--- gdb-6.3.50.20050915/gdb/mips-linux-nat.c 2005-09-10 13:11:04.000000000 -0500
|
||
|
+++ gdb-6.3.50.20050915-patched/gdb/mips-linux-nat.c 2005-09-15 19:16:54.000000000 -0500
|
||
|
@@ -24,6 +24,12 @@
|
||
|
#include "target.h"
|
||
|
#include "linux-nat.h"
|
||
|
|
||
|
+#include "gdb_proc_service.h"
|
||
|
+
|
||
|
+#ifndef PTRACE_GET_THREAD_AREA
|
||
|
+#define PTRACE_GET_THREAD_AREA 25
|
||
|
+#endif
|
||
|
+
|
||
|
/* Pseudo registers can not be read. ptrace does not provide a way to
|
||
|
read (or set) MIPS_PS_REGNUM, and there's no point in reading or
|
||
|
setting MIPS_ZERO_REGNUM. We also can not set BADVADDR, CAUSE, or
|
||
|
@@ -72,3 +78,20 @@
|
||
|
{
|
||
|
add_target (linux_target ());
|
||
|
}
|
||
|
+
|
||
|
+/* Fetch the thread-local storage pointer for libthread_db. */
|
||
|
+
|
||
|
+ps_err_e
|
||
|
+ps_get_thread_area (const struct ps_prochandle *ph,
|
||
|
+ lwpid_t lwpid, int idx, void **base)
|
||
|
+{
|
||
|
+ if (ptrace (PTRACE_GET_THREAD_AREA, lwpid, NULL, base) != 0)
|
||
|
+ return PS_ERR;
|
||
|
+
|
||
|
+ /* IDX is the bias from the thread pointer to the beginning of the
|
||
|
+ thread descriptor. It has to be subtracted due to implementation
|
||
|
+ quirks in libthread_db. */
|
||
|
+ *base = (void *) ((char *)*base - idx);
|
||
|
+
|
||
|
+ return PS_OK;
|
||
|
+}
|