diff options
| author | Julian Elischer <julian@FreeBSD.org> | 2002-09-11 08:13:56 +0000 |
|---|---|---|
| committer | Julian Elischer <julian@FreeBSD.org> | 2002-09-11 08:13:56 +0000 |
| commit | 71fad9fdeefd5d874768802125f98ea6450cfa5c (patch) | |
| tree | 10514ece7d621a24c034e4c778c793b9ea2d9675 /sys/kern/kern_kthread.c | |
| parent | 527eee2d404ad5415be0b17e0403d29f3ea924c3 (diff) | |
Notes
Diffstat (limited to 'sys/kern/kern_kthread.c')
| -rw-r--r-- | sys/kern/kern_kthread.c | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/sys/kern/kern_kthread.c b/sys/kern/kern_kthread.c index e8e2feaa9c0a..08ef71f8b31c 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); |
