summaryrefslogtreecommitdiffstats
path: root/sys/kern/kern_thread.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_thread.c
parentd8846eabc5bb3c87969ac71d42bfbb161abcd5d6 (diff)
downloadFreeBSD-src-87b58b164847b463017f49627b1cfed00cb6719c.zip
FreeBSD-src-87b58b164847b463017f49627b1cfed00cb6719c.tar.gz
Check signals for idled threads.
Diffstat (limited to 'sys/kern/kern_thread.c')
-rw-r--r--sys/kern/kern_thread.c3
1 files changed, 1 insertions, 2 deletions
diff --git a/sys/kern/kern_thread.c b/sys/kern/kern_thread.c
index 7e1982b..ff34488 100644
--- a/sys/kern/kern_thread.c
+++ b/sys/kern/kern_thread.c
@@ -368,9 +368,8 @@ kse_release(struct thread * td, struct kse_release_args * uap)
mtx_lock_spin(&sched_lock);
/* Change OURSELF to become an upcall. */
td->td_flags = TDF_UPCALLING; /* BOUND */
- if (!(td->td_kse->ke_flags & KEF_DOUPCALL) &&
+ if (!(td->td_kse->ke_flags & (KEF_DOUPCALL|KEF_ASTPENDING)) &&
(kg->kg_completed == NULL)) {
- /* XXXKSE also look for waiting signals etc. */
/*
* The KSE will however be lendable.
*/
OpenPOWER on IntegriCloud