summaryrefslogtreecommitdiffstats
path: root/sys/kern/kern_sig.c
diff options
context:
space:
mode:
authordavidxu <davidxu@FreeBSD.org>2003-01-07 05:56:38 +0000
committerdavidxu <davidxu@FreeBSD.org>2003-01-07 05:56:38 +0000
commit87b58b164847b463017f49627b1cfed00cb6719c (patch)
treef3916382718c15f7722cf68281acdd0f06433378 /sys/kern/kern_sig.c
parentd8846eabc5bb3c87969ac71d42bfbb161abcd5d6 (diff)
downloadFreeBSD-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.c4
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 {
OpenPOWER on IntegriCloud