From 5702a380a53c99a00275cb7e2836033a7497bef8 Mon Sep 17 00:00:00 2001 From: julian Date: Wed, 11 Sep 2002 08:13:56 +0000 Subject: Completely redo thread states. Reviewed by: davidxu@freebsd.org --- sys/kern/kern_kthread.c | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) (limited to 'sys/kern/kern_kthread.c') diff --git a/sys/kern/kern_kthread.c b/sys/kern/kern_kthread.c index e8e2fea..08ef71f 100644 --- a/sys/kern/kern_kthread.c +++ b/sys/kern/kern_kthread.c @@ -76,6 +76,7 @@ kthread_create(void (*func)(void *), void *arg, { int error; va_list ap; + struct thread *td; struct proc *p2; if (!proc0.p_stats /* || proc0.p_stats->p_start.tv_sec == 0 */) @@ -103,13 +104,15 @@ kthread_create(void (*func)(void *), void *arg, va_end(ap); /* call the processes' main()... */ - cpu_set_fork_handler(FIRST_THREAD_IN_PROC(p2), func, arg); + td = FIRST_THREAD_IN_PROC(p2); + cpu_set_fork_handler(td, func, arg); + TD_SET_CAN_RUN(td); /* Delay putting it on the run queue until now. */ mtx_lock_spin(&sched_lock); p2->p_sflag |= PS_INMEM; if (!(flags & RFSTOPPED)) { - setrunqueue(FIRST_THREAD_IN_PROC(p2)); + setrunqueue(td); } mtx_unlock_spin(&sched_lock); -- cgit v1.1