diff options
author | Mark Kettenis <kettenis@gnu.org> | 2007-07-06 11:39:44 +0000 |
---|---|---|
committer | Mark Kettenis <kettenis@gnu.org> | 2007-07-06 11:39:44 +0000 |
commit | dd041b2325c0f56dd43732d207c3a5c69b94f492 (patch) | |
tree | 457feabd0d05df9628597ef2329b760a18a71693 /gdb/bsd-uthread.c | |
parent | 0a8691edd07908ed8b82fc37f92507ee99b4acf6 (diff) | |
download | gdb-dd041b2325c0f56dd43732d207c3a5c69b94f492.tar.gz |
* bsd-uthread.c (bsd_uthread_wait): Don't try to fetch thread IDs
for terminated processes.
Diffstat (limited to 'gdb/bsd-uthread.c')
-rw-r--r-- | gdb/bsd-uthread.c | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/gdb/bsd-uthread.c b/gdb/bsd-uthread.c index 172192e4d22..bb01816805b 100644 --- a/gdb/bsd-uthread.c +++ b/gdb/bsd-uthread.c @@ -337,6 +337,12 @@ bsd_uthread_wait (ptid_t ptid, struct target_waitstatus *status) /* Pass the request to the layer beneath. */ ptid = find_target_beneath (bsd_uthread_ops_hack)->to_wait (ptid, status); + /* If the process is no longer alive, there's no point in figuring + out the thread ID. It will fail anyway. */ + if (status->kind == TARGET_WAITKIND_SIGNALLED + || status->kind == TARGET_WAITKIND_EXITED) + return ptid; + /* Fetch the corresponding thread ID, and augment the returned process ID with it. */ addr = read_memory_typed_address (bsd_uthread_thread_run_addr, |