summaryrefslogtreecommitdiff
path: root/lib/libpthread/uthread/uthread_fork.c
diff options
context:
space:
mode:
Diffstat (limited to 'lib/libpthread/uthread/uthread_fork.c')
-rw-r--r--lib/libpthread/uthread/uthread_fork.c11
1 files changed, 6 insertions, 5 deletions
diff --git a/lib/libpthread/uthread/uthread_fork.c b/lib/libpthread/uthread/uthread_fork.c
index 5f9054a332b..0271e822526 100644
--- a/lib/libpthread/uthread/uthread_fork.c
+++ b/lib/libpthread/uthread/uthread_fork.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: uthread_fork.c,v 1.9 2000/01/06 07:17:09 d Exp $ */
+/* $OpenBSD: uthread_fork.c,v 1.10 2001/08/21 19:24:53 fgsch Exp $ */
/*
* Copyright (c) 1995-1998 John Birrell <jb@cimlogic.com.au>
* All rights reserved.
@@ -44,6 +44,7 @@
pid_t
fork(void)
{
+ struct pthread *curthread = _get_curthread();
int i, flags;
pid_t ret;
pthread_t pthread;
@@ -63,7 +64,7 @@ fork(void)
_thread_sys_close(_thread_kern_pipe[1]);
/* Reset signals pending for the running thread: */
- sigemptyset(&_thread_run->sigpend);
+ sigemptyset(&curthread->sigpend);
/*
* Create a pipe that is written to by the signal handler to
@@ -117,7 +118,7 @@ fork(void)
TAILQ_REMOVE(&_thread_list, pthread, tle);
/* Make sure this isn't the running thread: */
- if (pthread != _thread_run) {
+ if (pthread != curthread) {
/* XXX should let gc do all this. */
if(pthread->stack != NULL)
_thread_stack_free(pthread->stack);
@@ -133,7 +134,7 @@ fork(void)
}
/* Restore the running thread */
- TAILQ_INSERT_HEAD(&_thread_list, _thread_run, tle);
+ TAILQ_INSERT_HEAD(&_thread_list, curthread, tle);
/* Re-init the dead thread list: */
TAILQ_INIT(&_dead_list);
@@ -143,7 +144,7 @@ fork(void)
TAILQ_INIT(&_workq);
/* Re-init the threads mutex queue: */
- TAILQ_INIT(&_thread_run->mutexq);
+ TAILQ_INIT(&curthread->mutexq);
/* No spinlocks yet: */
_spinblock_count = 0;