From ad34eb2f7c3120f83d22cf2d5371673fc95040b4 Mon Sep 17 00:00:00 2001 From: Jan Kratochvil Date: Tue, 20 Jul 2010 12:54:57 +0000 Subject: [PATCH] gdb/ * linux-nat.c (linux_handle_extended_wait): Handle case when event == PTRACE_EVENT_CLONE && stopping && WSTOPSIG (status) != SIGSTOP. --- gdb/ChangeLog | 5 +++++ gdb/linux-nat.c | 17 +++++++++++++++++ 2 files changed, 22 insertions(+) diff --git a/gdb/ChangeLog b/gdb/ChangeLog index f469860ca3..042d5f5f2e 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,8 @@ +2010-07-20 Jan Kratochvil + + * linux-nat.c (linux_handle_extended_wait): Handle case when + event == PTRACE_EVENT_CLONE && stopping && WSTOPSIG (status) != SIGSTOP. + 2010-07-20 Jan Kratochvil Code cleanup. diff --git a/gdb/linux-nat.c b/gdb/linux-nat.c index b894d848bb..de0ba581da 100644 --- a/gdb/linux-nat.c +++ b/gdb/linux-nat.c @@ -2279,6 +2279,23 @@ linux_handle_extended_wait (struct lwp_info *lp, int status, linux_ops->to_resume (linux_ops, pid_to_ptid (new_pid), 0, signo); } + else + { + if (status != 0) + { + /* We created NEW_LP so it cannot yet contain STATUS. */ + gdb_assert (new_lp->status == 0); + + /* Save the wait status to report later. */ + if (debug_linux_nat) + fprintf_unfiltered (gdb_stdlog, + "LHEW: waitpid of new LWP %ld, " + "saving status %s\n", + (long) GET_LWP (new_lp->ptid), + status_to_str (status)); + new_lp->status = status; + } + } if (debug_linux_nat) fprintf_unfiltered (gdb_stdlog, -- 2.34.1