yann@438: --- gdb-6.5/./gdb/gdbserver/thread-db.c.orig 2006-03-15 08:13:29.000000000 -0800 yann@438: +++ gdb-6.5/./gdb/gdbserver/thread-db.c 2008-04-01 21:21:23.000000000 -0700 yann@96: @@ -21,6 +21,7 @@ yann@438: Foundation, Inc., 51 Franklin Street, Fifth Floor, yann@438: Boston, MA 02110-1301, USA. */ yann@96: yann@96: +#include yann@96: #include "server.h" yann@96: yann@96: #include "linux-low.h" yann@438: @@ -134,6 +135,7 @@ thread_db_create_event (CORE_ADDR where) yann@96: td_event_msg_t msg; yann@96: td_err_e err; yann@96: struct inferior_linux_data *tdata; yann@96: + int timeout; yann@96: yann@96: if (debug_threads) yann@96: fprintf (stderr, "Thread creation event.\n"); yann@438: @@ -144,7 +146,13 @@ thread_db_create_event (CORE_ADDR where) yann@96: In the LinuxThreads implementation, this is safe, yann@96: because all events come from the manager thread yann@96: (except for its own creation, of course). */ yann@96: - err = td_ta_event_getmsg (thread_agent, &msg); yann@96: + for (timeout = 0; timeout < 50000; timeout++) yann@96: + { yann@96: + err = td_ta_event_getmsg (thread_agent, &msg); yann@96: + if (err != TD_NOMSG) yann@96: + break; yann@96: + usleep(1000); yann@96: + } yann@96: if (err != TD_OK) yann@96: fprintf (stderr, "thread getmsg err: %s\n", yann@96: thread_db_err_str (err));