From f61d4432c4a66d25b46d56aa5e9b599ff7444ae3 Mon Sep 17 00:00:00 2001 From: davidxu Date: Wed, 3 Sep 2003 00:21:10 +0000 Subject: Move kse_wakeup_multi call to just before KSE_SCHED_UNLOCK. Tested on: SMP --- lib/libpthread/thread/thr_kern.c | 6 ++---- 1 file changed, 2 insertions(+), 4 deletions(-) (limited to 'lib/libpthread/thread/thr_kern.c') diff --git a/lib/libpthread/thread/thr_kern.c b/lib/libpthread/thread/thr_kern.c index d7e28ba..f9a17a5 100644 --- a/lib/libpthread/thread/thr_kern.c +++ b/lib/libpthread/thread/thr_kern.c @@ -1039,8 +1039,6 @@ kse_sched_multi(struct kse_mailbox *kmbx) kse_switchout_thread(curkse, curthread); curkse->k_curthread = NULL; - kse_wakeup_multi(curkse); - #ifdef DEBUG_THREAD_KERN dump_queues(curkse); #endif @@ -1071,6 +1069,7 @@ kse_sched_multi(struct kse_mailbox *kmbx) * created thread would be assigned to us (the initial * kse[g]). */ + kse_wakeup_multi(curkse); KSE_SCHED_UNLOCK(curkse, curkse->k_kseg); kse_fini(curkse); /* never returns */ @@ -1106,8 +1105,6 @@ kse_sched_multi(struct kse_mailbox *kmbx) curframe = curthread->curframe; curthread->curframe = NULL; - kse_wakeup_multi(curkse); - /* * The thread's current signal frame will only be NULL if it * is being resumed after being blocked in the kernel. In @@ -1130,6 +1127,7 @@ kse_sched_multi(struct kse_mailbox *kmbx) (__sighandler_t *)thr_resume_wrapper); } #endif + kse_wakeup_multi(curkse); /* * Continue the thread at its current frame: */ -- cgit v1.1