yann@96: --- gdb-6.3.org/gdb/gdbserver/thread-db.c 2004-10-17 02:42:00.000000000 +0900 yann@96: +++ gdb-6.3/gdb/gdbserver/thread-db.c 2005-01-27 12:19:29.000000000 +0900 yann@96: @@ -21,6 +21,7 @@ yann@96: Foundation, Inc., 59 Temple Place - Suite 330, yann@96: Boston, MA 02111-1307, USA. */ yann@96: yann@96: +#include yann@96: #include "server.h" yann@96: yann@96: #include "linux-low.h" yann@96: @@ -142,6 +143,7 @@ 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@96: @@ -152,7 +154,13 @@ 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)); yann@96: