summaryrefslogtreecommitdiffstats
path: root/sys/kern/kern_fork.c
diff options
context:
space:
mode:
authortedu <tedu@openbsd.org>2008-05-11 23:54:40 +0000
committertedu <tedu@openbsd.org>2008-05-11 23:54:40 +0000
commit0c5bca190bd7b51928def75cadfcc7274c101a8d (patch)
tree92f4489126ebb569755a673032d3eb9e0628cad8 /sys/kern/kern_fork.c
parentshare signal handlers for rthreads. from philip guenther (diff)
downloadwireguard-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.c4
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);