diff options
author | 2008-05-11 23:54:40 +0000 | |
---|---|---|
committer | 2008-05-11 23:54:40 +0000 | |
commit | 0c5bca190bd7b51928def75cadfcc7274c101a8d (patch) | |
tree | 92f4489126ebb569755a673032d3eb9e0628cad8 /sys/kern/kern_fork.c | |
parent | share signal handlers for rthreads. from philip guenther (diff) | |
download | wireguard-openbsd-0c5bca190bd7b51928def75cadfcc7274c101a8d.tar.xz wireguard-openbsd-0c5bca190bd7b51928def75cadfcc7274c101a8d.zip |
set p_flag to 0 sooner, so we don't overwrite the thread flag. and correctly
free things when exiting a threaded proc. from philip guenther
Diffstat (limited to 'sys/kern/kern_fork.c')
-rw-r--r-- | sys/kern/kern_fork.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/sys/kern/kern_fork.c b/sys/kern/kern_fork.c index 7c741157d81..a7ba5624565 100644 --- a/sys/kern/kern_fork.c +++ b/sys/kern/kern_fork.c @@ -1,4 +1,4 @@ -/* $OpenBSD: kern_fork.c,v 1.94 2008/05/11 23:50:32 tedu Exp $ */ +/* $OpenBSD: kern_fork.c,v 1.95 2008/05/11 23:54:40 tedu Exp $ */ /* $NetBSD: kern_fork.c,v 1.29 1996/02/09 18:59:34 christos Exp $ */ /* @@ -224,6 +224,7 @@ fork1(struct proc *p1, int exitsig, int flags, void *stack, size_t stacksize, p2->p_stat = SIDL; /* protect against others */ p2->p_exitsig = exitsig; + p2->p_flag = 0; #ifdef RTHREADS if (flags & FORK_THREAD) { @@ -260,7 +261,6 @@ fork1(struct proc *p1, int exitsig, int flags, void *stack, size_t stacksize, * Increase reference counts on shared objects. * The p_stats and p_sigacts substructs are set in vm_fork. */ - p2->p_flag = 0; p2->p_emul = p1->p_emul; if (p1->p_flag & P_PROFIL) startprofclock(p2); |