From: Pedro Alves Date: Mon, 8 Sep 2008 21:25:05 +0000 (+0000) Subject: * inf-ptrace.c: Include "gdbthread.h". X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=af99052775b274a23fd8004bf816f9b299b96b23;p=binutils-gdb.git * inf-ptrace.c: Include "gdbthread.h". (inf_ptrace_attach): Add the main thread here. * linux-nat.c (linux_nat_attach): Don't add the main thread here. Decorate the main thread id with the lwp id. --- diff --git a/gdb/ChangeLog b/gdb/ChangeLog index 3f73fe1e46b..22bd2b284b2 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,10 @@ +2008-09-08 Pedro Alves + + * inf-ptrace.c: Include "gdbthread.h". + (inf_ptrace_attach): Add the main thread here. + * linux-nat.c (linux_nat_attach): Don't add the main thread here. + Decorate the main thread id with the lwp id. + 2008-09-08 Pedro Alves * linux-nat.c (linux_nat_wait): Update inferior_ptid's ptid with diff --git a/gdb/inf-ptrace.c b/gdb/inf-ptrace.c index ee2c8fa397d..6899be0bc85 100644 --- a/gdb/inf-ptrace.c +++ b/gdb/inf-ptrace.c @@ -33,6 +33,7 @@ #include #include "inf-child.h" +#include "gdbthread.h" /* HACK: Save the ptrace ops returned by inf_ptrace_target. */ static struct target_ops *ptrace_ops_hack; @@ -218,6 +219,11 @@ inf_ptrace_attach (char *args, int from_tty) #endif inferior_ptid = pid_to_ptid (pid); + + /* Always add a main thread. If some target extends the ptrace + target, it should decorate the ptid later with more info. */ + add_thread_silent (inferior_ptid); + push_target (ptrace_ops_hack); } diff --git a/gdb/linux-nat.c b/gdb/linux-nat.c index fe78c258bdb..8ba6ea982f9 100644 --- a/gdb/linux-nat.c +++ b/gdb/linux-nat.c @@ -1345,6 +1345,7 @@ linux_nat_attach (char *args, int from_tty) { struct lwp_info *lp; int status; + ptid_t ptid; /* FIXME: We should probably accept a list of process id's, and attach all of them. */ @@ -1359,18 +1360,18 @@ linux_nat_attach (char *args, int from_tty) sigdelset (&suspend_mask, SIGCHLD); } + /* The ptrace base target adds the main thread with (pid,0,0) + format. Decorate it with lwp info. */ + ptid = BUILD_LWP (GET_PID (inferior_ptid), GET_PID (inferior_ptid)); + thread_change_ptid (inferior_ptid, ptid); + /* Add the initial process as the first LWP to the list. */ - inferior_ptid = BUILD_LWP (GET_PID (inferior_ptid), GET_PID (inferior_ptid)); - lp = add_lwp (inferior_ptid); + lp = add_lwp (ptid); status = linux_nat_post_attach_wait (lp->ptid, 1, &lp->cloned, &lp->signalled); lp->stopped = 1; - /* If this process is not using thread_db, then we still don't - detect any other threads, but add at least this one. */ - add_thread_silent (lp->ptid); - /* Save the wait status to report later. */ lp->resumed = 1; if (debug_linux_nat)