Module Name:    src
Committed By:   matt
Date:           Tue Jan 18 23:56:49 UTC 2011

Modified Files:
        src/sys/arch/sparc64/sparc64: vm_machdep.c
        src/sys/arch/x86/x86: vm_machdep.c
        src/sys/kern: kern_fork.c

Log Message:
Copy PK_32 to p2->p_flag instead of doing it in the cpu_proc_fork hook.


To generate a diff of this commit:
cvs rdiff -u -r1.93 -r1.94 src/sys/arch/sparc64/sparc64/vm_machdep.c
cvs rdiff -u -r1.10 -r1.11 src/sys/arch/x86/x86/vm_machdep.c
cvs rdiff -u -r1.178 -r1.179 src/sys/kern/kern_fork.c

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/sys/arch/sparc64/sparc64/vm_machdep.c
diff -u src/sys/arch/sparc64/sparc64/vm_machdep.c:1.93 src/sys/arch/sparc64/sparc64/vm_machdep.c:1.94
--- src/sys/arch/sparc64/sparc64/vm_machdep.c:1.93	Fri Jan 14 02:06:32 2011
+++ src/sys/arch/sparc64/sparc64/vm_machdep.c	Tue Jan 18 23:56:49 2011
@@ -1,4 +1,4 @@
-/*	$NetBSD: vm_machdep.c,v 1.93 2011/01/14 02:06:32 rmind Exp $ */
+/*	$NetBSD: vm_machdep.c,v 1.94 2011/01/18 23:56:49 matt Exp $ */
 
 /*
  * Copyright (c) 1996-2002 Eduardo Horvath.  All rights reserved.
@@ -50,7 +50,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: vm_machdep.c,v 1.93 2011/01/14 02:06:32 rmind Exp $");
+__KERNEL_RCSID(0, "$NetBSD: vm_machdep.c,v 1.94 2011/01/18 23:56:49 matt Exp $");
 
 #include "opt_multiprocessor.h"
 
@@ -242,9 +242,6 @@
 	} else
 		l2->l_md.md_fpstate = NULL;
 
-	if (l1->l_proc->p_flag & PK_32)
-		l2->l_proc->p_flag |= PK_32;
-
 	/*
 	 * Setup (kernel) stack frame that will by-pass the child
 	 * out of the kernel. (The trap frame invariably resides at

Index: src/sys/arch/x86/x86/vm_machdep.c
diff -u src/sys/arch/x86/x86/vm_machdep.c:1.10 src/sys/arch/x86/x86/vm_machdep.c:1.11
--- src/sys/arch/x86/x86/vm_machdep.c:1.10	Wed Jul  7 01:20:50 2010
+++ src/sys/arch/x86/x86/vm_machdep.c	Tue Jan 18 23:56:48 2011
@@ -1,4 +1,4 @@
-/*	$NetBSD: vm_machdep.c,v 1.10 2010/07/07 01:20:50 chs Exp $	*/
+/*	$NetBSD: vm_machdep.c,v 1.11 2011/01/18 23:56:48 matt Exp $	*/
 
 /*-
  * Copyright (c) 1982, 1986 The Regents of the University of California.
@@ -80,7 +80,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: vm_machdep.c,v 1.10 2010/07/07 01:20:50 chs Exp $");
+__KERNEL_RCSID(0, "$NetBSD: vm_machdep.c,v 1.11 2011/01/18 23:56:48 matt Exp $");
 
 #include "opt_mtrr.h"
 
@@ -119,8 +119,6 @@
 {
 
 	p2->p_md.md_flags = p1->p_md.md_flags;
-	if (p1->p_flag & PK_32)
-		p2->p_flag |= PK_32;
 }
 
 /*

Index: src/sys/kern/kern_fork.c
diff -u src/sys/kern/kern_fork.c:1.178 src/sys/kern/kern_fork.c:1.179
--- src/sys/kern/kern_fork.c:1.178	Wed Jul  7 01:30:37 2010
+++ src/sys/kern/kern_fork.c	Tue Jan 18 23:56:49 2011
@@ -1,4 +1,4 @@
-/*	$NetBSD: kern_fork.c,v 1.178 2010/07/07 01:30:37 chs Exp $	*/
+/*	$NetBSD: kern_fork.c,v 1.179 2011/01/18 23:56:49 matt Exp $	*/
 
 /*-
  * Copyright (c) 1999, 2001, 2004, 2006, 2007, 2008 The NetBSD Foundation, Inc.
@@ -67,7 +67,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: kern_fork.c,v 1.178 2010/07/07 01:30:37 chs Exp $");
+__KERNEL_RCSID(0, "$NetBSD: kern_fork.c,v 1.179 2011/01/18 23:56:49 matt Exp $");
 
 #include "opt_ktrace.h"
 
@@ -297,9 +297,11 @@
 	 * Increase reference counts on shared objects.
 	 * Inherit flags we want to keep.  The flags related to SIGCHLD
 	 * handling are important in order to keep a consistent behaviour
-	 * for the child after the fork.
+	 * for the child after the fork.  If we are a 32-bit process, the
+	 * child will be too.
 	 */
-	p2->p_flag = p1->p_flag & (PK_SUGID | PK_NOCLDWAIT | PK_CLDSIGIGN);
+	p2->p_flag =
+	    p1->p_flag & (PK_SUGID | PK_NOCLDWAIT | PK_CLDSIGIGN | PK_32);
 	p2->p_emul = p1->p_emul;
 	p2->p_execsw = p1->p_execsw;
 

Reply via email to