From: Pedro Alves Date: Mon, 8 Sep 2008 21:37:01 +0000 (+0000) Subject: * bsd-uthread.c (bsd_uthread_find_new_threads): Claim the main X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=757f359dd1a926e78902b65e2b19e4c9bb96844a;p=binutils-gdb.git * bsd-uthread.c (bsd_uthread_find_new_threads): Claim the main thread. --- diff --git a/gdb/ChangeLog b/gdb/ChangeLog index 4001707d660..ce292c8f5d9 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,8 @@ +2008-09-08 Pedro Alves + + * bsd-uthread.c (bsd_uthread_find_new_threads): Claim the main + thread. + 2008-09-08 Pedro Alves * corelow.c (add_to_thread_list): If this is the first time we diff --git a/gdb/bsd-uthread.c b/gdb/bsd-uthread.c index b6a18f0144f..93198d3e224 100644 --- a/gdb/bsd-uthread.c +++ b/gdb/bsd-uthread.c @@ -422,7 +422,15 @@ bsd_uthread_find_new_threads (void) ptid_t ptid = ptid_build (pid, 0, addr); if (!in_thread_list (ptid) || is_exited (ptid)) - add_thread (ptid); + { + /* If INFERIOR_PTID doesn't have a tid member yet, then ptid + is still the initial thread of the process. Notify GDB + core about it. */ + if (ptid_get_tid (inferior_ptid) == 0) + thread_change_ptid (inferior_ptid, ptid); + else + add_thread (ptid); + } addr = read_memory_typed_address (addr + offset, builtin_type_void_data_ptr);