diff options
author | davidxu <davidxu@FreeBSD.org> | 2003-01-07 05:56:38 +0000 |
---|---|---|
committer | davidxu <davidxu@FreeBSD.org> | 2003-01-07 05:56:38 +0000 |
commit | 87b58b164847b463017f49627b1cfed00cb6719c (patch) | |
tree | f3916382718c15f7722cf68281acdd0f06433378 /sys/kern/kern_sig.c | |
parent | d8846eabc5bb3c87969ac71d42bfbb161abcd5d6 (diff) | |
download | FreeBSD-src-87b58b164847b463017f49627b1cfed00cb6719c.zip FreeBSD-src-87b58b164847b463017f49627b1cfed00cb6719c.tar.gz |
Check signals for idled threads.
Diffstat (limited to 'sys/kern/kern_sig.c')
-rw-r--r-- | sys/kern/kern_sig.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/sys/kern/kern_sig.c b/sys/kern/kern_sig.c index 3329b87..77ee34b 100644 --- a/sys/kern/kern_sig.c +++ b/sys/kern/kern_sig.c @@ -1528,8 +1528,6 @@ psignal(p, sig) else if (TD_IS_IDLE(td)) { thread_suspend_one(td); } - - } if (p->p_suspcount == p->p_numthreads) { mtx_unlock_spin(&sched_lock); @@ -1642,6 +1640,8 @@ tdsignal(struct thread *td, int sig, sig_t action) cv_abort(td); else abortsleep(td); + } else if (TD_IS_IDLE(td)) { + TD_CLR_IDLE(td); } #ifdef SMP else { |