diff options
| author | John Birrell <jb@FreeBSD.org> | 1998-11-15 10:01:34 +0000 |
|---|---|---|
| committer | John Birrell <jb@FreeBSD.org> | 1998-11-15 10:01:34 +0000 |
| commit | 4896148e72356128de5a6170f0bf1a1dca956442 (patch) | |
| tree | c6baf2135f3f3ce063155cae1e6d03bd924d0d0e /lib/libpthread/thread/thr_kill.c | |
| parent | e7b7b3f3de2ea8c389c26f118e0c1bd750a89299 (diff) | |
Notes
Diffstat (limited to 'lib/libpthread/thread/thr_kill.c')
| -rw-r--r-- | lib/libpthread/thread/thr_kill.c | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/lib/libpthread/thread/thr_kill.c b/lib/libpthread/thread/thr_kill.c index 292ba5caf8f2..7572c05faff7 100644 --- a/lib/libpthread/thread/thr_kill.c +++ b/lib/libpthread/thread/thr_kill.c @@ -83,6 +83,26 @@ pthread_kill(pthread_t pthread, int sig) sigaddset(&pthread->sigpend,sig); break; + case PS_SELECT_WAIT: + case PS_FDR_WAIT: + case PS_FDW_WAIT: + case PS_SLEEP_WAIT: + if (!sigismember(&pthread->sigmask, sig) && + (_thread_sigact[sig - 1].sa_handler != SIG_IGN)) { + /* Flag the operation as interrupted: */ + pthread->interrupted = 1; + + /* Change the state of the thread to run: */ + PTHREAD_NEW_STATE(pthread,PS_RUNNING); + + /* Return the signal number: */ + pthread->signo = sig; + } else { + /* Increment the pending signal count: */ + sigaddset(&pthread->sigpend,sig); + } + break; + default: /* Increment the pending signal count: */ sigaddset(&pthread->sigpend,sig); |
