2005-12-01 Kevin Buettner <kevinb@redhat.com>
+ * thread-db.c (handle_thread_db_event): Allow underlying target a
+ chance to look at the wait status too.
+ (thread_db_check_child_state): Ensure that there's a thread list
+ to work with when using the thread_db event model.
+
+2005-12-01 Kevin Buettner <kevinb@redhat.com>
+
* linux-target.c (reginfo) [AM33_2_0_LINUX_TARGET]: Don't use
``sizeof (greg_t)'' due to this type not being defined any longer
in the headers that linux-target includes.
/* We don't have any new status to report... */
return 1;
}
+ /* Give underlying target a chance to look at the wait status. This
+ is necessary for software singlestep to work correctly. */
+ handle_waitstatus (process, w);
/* Re-insert the event breakpoints. */
insert_thread_db_event_breakpoints (serv);
process->stop_signal,
(unsigned long) debug_get_pc (process->serv, process->pid));
-#if ALWAYS_UPDATE_THREAD_LIST
- /* Update the thread list, and attach to (and thereby stop)
- any new threads we find. */
- update_thread_list (process);
+#if !ALWAYS_UPDATE_THREAD_LIST
+ /* The thread_db event model requires that `event_thread' (see
+ below) gets set correctly, but this won't happen unless there's
+ a thread list to search. So, if the thread_list is empty and
+ we're using the thread_db event model, we need to update the
+ thread list. */
+ if (thread_list == NULL && using_thread_db_events)
#endif
+ {
+ /* Update the thread list, and attach to (and thereby stop)
+ any new threads we find. */
+ update_thread_list (process);
+ }
process->event_thread = thread_list_lookup_by_lid (process->pid);