From 8c86a69beb11982e649317ffae6803742f1d0bcc Mon Sep 17 00:00:00 2001 From: deischen Date: Fri, 18 Jul 2003 02:46:55 +0000 Subject: Cleanup thread accounting. Don't reset a threads timeslice when it blocks; it only gets reset when it yields. Properly set a thread's default stack guardsize. Reviewed by: davidxu --- lib/libkse/thread/thr_private.h | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) (limited to 'lib/libkse/thread/thr_private.h') diff --git a/lib/libkse/thread/thr_private.h b/lib/libkse/thread/thr_private.h index ccd4faf..21026b7 100644 --- a/lib/libkse/thread/thr_private.h +++ b/lib/libkse/thread/thr_private.h @@ -888,7 +888,7 @@ do { \ _pq_insert_tail(&(thrd)->kseg->kg_schedq.sq_runq, thrd) #define THR_RUNQ_REMOVE(thrd) \ _pq_remove(&(thrd)->kseg->kg_schedq.sq_runq, thrd) -#define THR_RUNQ_FIRST() \ +#define THR_RUNQ_FIRST(thrd) \ _pq_first(&(thrd)->kseg->kg_schedq.sq_runq) /* @@ -947,6 +947,9 @@ do { \ (void)_kse_critical_enter(); \ KSE_SCHED_LOCK((curthr)->kse, (curthr)->kseg); \ } while (0) +#define THR_UNLOCK_SWITCH(curthr) do { \ + KSE_SCHED_UNLOCK((curthr)->kse, (curthr)->kseg);\ +} while (0) #define THR_CRITICAL_ENTER(thr) (thr)->critical_count++ #define THR_CRITICAL_LEAVE(thr) do { \ @@ -989,7 +992,7 @@ SCLASS struct pthread_attr _pthread_attr_default SCLASS_PRESET({ SCHED_RR, 0, TIMESLICE_USEC, THR_DEFAULT_PRIORITY, THR_CREATE_RUNNING, PTHREAD_CREATE_JOINABLE, NULL, - NULL, NULL, THR_STACK_DEFAULT + NULL, NULL, THR_STACK_DEFAULT, /* guardsize */0 }); /* Default mutex attributes: */ -- cgit v1.1