Fix assertion failure in linux-thread-db
Since we are no longer using thread events by default in linux-thread-db, the find_new_threads_once routine contains an assertion that it should never be called on a live inferior unless using thread events: gdb_assert (!target_has_execution || thread_db_use_events ()); However, there is a code path from thread_db_get_thread_local_address that will in fact call find_new_threads_once in some scenarios. In particular, this is currently always triggered when starting up any Cell/B.E. combined exeuctable. To fix this, this patch removes the call to thread_db_find_new_threads_1 when the current thread was not yet detected. In its place, we now just call thread_from_lwp to detect this one thread if necessary. ChangeLog: * linux-thread-db.c (thread_db_get_thread_local_address): If the thread was not yet discovered, use thread_from_lwp instead of calling thread_db_find_new_threads_1.
This commit is contained in:
parent
4e83a1e776
commit
e0fd7c47bd
2 changed files with 13 additions and 4 deletions
|
@ -1849,13 +1849,16 @@ thread_db_get_thread_local_address (struct target_ops *ops,
|
|||
struct thread_info *thread_info;
|
||||
struct target_ops *beneath;
|
||||
|
||||
/* If we have not discovered any threads yet, check now. */
|
||||
if (!have_threads (ptid))
|
||||
thread_db_find_new_threads_1 (ptid);
|
||||
|
||||
/* Find the matching thread. */
|
||||
thread_info = find_thread_ptid (ptid);
|
||||
|
||||
/* We may not have discovered the thread yet. */
|
||||
if (thread_info != NULL && thread_info->priv == NULL)
|
||||
{
|
||||
thread_from_lwp (ptid);
|
||||
thread_info = find_thread_ptid (ptid);
|
||||
}
|
||||
|
||||
if (thread_info != NULL && thread_info->priv != NULL)
|
||||
{
|
||||
td_err_e err;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue