[RFC][v8][PATCH 3/10]: Make pid_max a pid_ns property

Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]
From: Sukadev Bhattiprolu
Date: Monday, October 12, 2009 - 9:50 pm

From: Serge Hallyn <serue@us.ibm.com>
Subject: [RFC][v8][PATCH 3/10]: Make pid_max a pid_ns property

Remove the pid_max global, and make it a property of the
pid_namespace.  When a pid_ns is created, it inherits
the parent's pid_ns.

Fixing up sysctl (trivial akin to ipc version, but
potentially tedious to get right for all CONFIG*
combinations) is left for later.

Changelog[v2]:
	- Port to newer kernel
	- Make pid_max a local variable in alloc_pidmap() to simplify code/patch

Signed-off-by: Serge Hallyn <serue@us.ibm.com>
Signed-off-by: Sukadev Bhattiprolu <sukadev@us.ibm.com>
---
 include/linux/pid_namespace.h |    1 +
 kernel/pid.c                  |    4 ++--
 kernel/pid_namespace.c        |    1 +
 kernel/sysctl.c               |    4 ++--
 4 files changed, 6 insertions(+), 4 deletions(-)

Index: linux-2.6/include/linux/pid_namespace.h
===================================================================
--- linux-2.6.orig/include/linux/pid_namespace.h	2009-09-09 19:06:21.000000000 -0700
+++ linux-2.6/include/linux/pid_namespace.h	2009-09-09 19:07:20.000000000 -0700
@@ -30,6 +30,7 @@ struct pid_namespace {
 #ifdef CONFIG_BSD_PROCESS_ACCT
 	struct bsd_acct_struct *bacct;
 #endif
+	int pid_max;
 };
 
 extern struct pid_namespace init_pid_ns;
Index: linux-2.6/kernel/pid.c
===================================================================
--- linux-2.6.orig/kernel/pid.c	2009-09-09 19:06:46.000000000 -0700
+++ linux-2.6/kernel/pid.c	2009-09-09 19:07:20.000000000 -0700
@@ -43,8 +43,6 @@ static struct hlist_head *pid_hash;
 static int pidhash_shift;
 struct pid init_struct_pid = INIT_STRUCT_PID;
 
-int pid_max = PID_MAX_DEFAULT;
-
 #define RESERVED_PIDS		300
 
 int pid_max_min = RESERVED_PIDS + 1;
@@ -78,6 +76,7 @@ struct pid_namespace init_pid_ns = {
 	.last_pid = 0,
 	.level = 0,
 	.child_reaper = &init_task,
+	.pid_max = PID_MAX_DEFAULT,
 };
 EXPORT_SYMBOL_GPL(init_pid_ns);
 
@@ -151,6 +150,7 @@ static int alloc_pidmap(struct pid_names
 {
 	int i, offset, max_scan, pid, last = pid_ns->last_pid;
 	int rc = -EAGAIN;
+	int pid_max = pid_ns->pid_max;
 	struct pidmap *map;
 
 	pid = last + 1;
Index: linux-2.6/kernel/pid_namespace.c
===================================================================
--- linux-2.6.orig/kernel/pid_namespace.c	2009-09-09 19:06:21.000000000 -0700
+++ linux-2.6/kernel/pid_namespace.c	2009-09-09 19:07:20.000000000 -0700
@@ -87,6 +87,7 @@ static struct pid_namespace *create_pid_
 
 	kref_init(&ns->kref);
 	ns->level = level;
+	ns->pid_max = parent_pid_ns->pid_max;
 	ns->parent = get_pid_ns(parent_pid_ns);
 
 	set_bit(0, ns->pidmap[0].page);
Index: linux-2.6/kernel/sysctl.c
===================================================================
--- linux-2.6.orig/kernel/sysctl.c	2009-09-09 19:06:21.000000000 -0700
+++ linux-2.6/kernel/sysctl.c	2009-09-09 19:07:20.000000000 -0700
@@ -55,6 +55,7 @@
 
 #include <asm/uaccess.h>
 #include <asm/processor.h>
+#include <linux/pid_namespace.h>
 
 #ifdef CONFIG_X86
 #include <asm/nmi.h>
@@ -78,7 +79,6 @@ extern int max_threads;
 extern int core_uses_pid;
 extern int suid_dumpable;
 extern char core_pattern[];
-extern int pid_max;
 extern int min_free_kbytes;
 extern int pid_max_min, pid_max_max;
 extern int sysctl_drop_caches;
@@ -670,7 +670,7 @@ static struct ctl_table kern_table[] = {
 	{
 		.ctl_name	= KERN_PIDMAX,
 		.procname	= "pid_max",
-		.data		= &pid_max,
+		.data		= &init_pid_ns.pid_max,
 		.maxlen		= sizeof (int),
 		.mode		= 0644,
 		.proc_handler	= &proc_dointvec_minmax,
--
Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]

Messages in current thread:
[RFC][v8][PATCH 0/10] Implement clone3() system call, Sukadev Bhattiprolu, (Mon Oct 12, 9:49 pm)
[RFC][v8][PATCH 1/10]: Factor out code to allocate pidmap page, Sukadev Bhattiprolu, (Mon Oct 12, 9:49 pm)
[RFC][v8][PATCH 2/10]: Have alloc_pidmap() return actual e ..., Sukadev Bhattiprolu, (Mon Oct 12, 9:50 pm)
[RFC][v8][PATCH 3/10]: Make pid_max a pid_ns property, Sukadev Bhattiprolu, (Mon Oct 12, 9:50 pm)
[RFC][v8][PATCH 4/10]: Add target_pid parameter to alloc_p ..., Sukadev Bhattiprolu, (Mon Oct 12, 9:51 pm)
[RFC][v8][PATCH 5/10]: Add target_pids parameter to alloc_ ..., Sukadev Bhattiprolu, (Mon Oct 12, 9:51 pm)
[RFC][v8][PATCH 6/10]: Add target_pids parameter to copy_p ..., Sukadev Bhattiprolu, (Mon Oct 12, 9:52 pm)
[RFC][v8][PATCH 7/10]: Check invalid clone flags, Sukadev Bhattiprolu, (Mon Oct 12, 9:52 pm)
[RFC][v8][PATCH 8/10]: Define do_fork_with_pids(), Sukadev Bhattiprolu, (Mon Oct 12, 9:52 pm)
[RFC][v8][PATCH 9/10]: Define clone3() syscall, Sukadev Bhattiprolu, (Mon Oct 12, 9:54 pm)
[RFC][v8][PATCH 10/10]: Document clone3() syscall, Sukadev Bhattiprolu, (Mon Oct 12, 9:55 pm)
Re: [RFC][v8][PATCH 3/10]: Make pid_max a pid_ns property, Alexey Dobriyan, (Mon Oct 12, 10:19 pm)
Re: [RFC][v8][PATCH 3/10]: Make pid_max a pid_ns property, Pavel Emelyanov, (Tue Oct 13, 6:09 am)
Re: [RFC][v8][PATCH 3/10]: Make pid_max a pid_ns property, Serge E. Hallyn, (Tue Oct 13, 8:24 am)
Re: [RFC][v8][PATCH 3/10]: Make pid_max a pid_ns property, Pavel Emelyanov, (Tue Oct 13, 9:10 am)
Re: [RFC][v8][PATCH 3/10]: Make pid_max a pid_ns property, Serge E. Hallyn, (Tue Oct 13, 9:28 am)
Re: [RFC][v8][PATCH 7/10]: Check invalid clone flags, Oren Laadan, (Tue Oct 13, 11:35 am)
Re: [RFC][v8][PATCH 9/10]: Define clone3() syscall, Oren Laadan, (Tue Oct 13, 11:46 am)
Re: [RFC][v8][PATCH 0/10] Implement clone3() system call, Roland McGrath, (Tue Oct 13, 1:50 pm)
Re: [RFC][v8][PATCH 0/10] Implement clone3() system call, Sukadev Bhattiprolu, (Tue Oct 13, 4:27 pm)
Re: [RFC][v8][PATCH 7/10]: Check invalid clone flags, Sukadev Bhattiprolu, (Tue Oct 13, 4:38 pm)
Re: [RFC][v8][PATCH 0/10] Implement clone3() system call, H. Peter Anvin, (Tue Oct 13, 4:49 pm)
Re: [RFC][v8][PATCH 0/10] Implement clone3() system call, Roland McGrath, (Tue Oct 13, 4:53 pm)
Re: [RFC][v8][PATCH 0/10] Implement clone3() system call, H. Peter Anvin, (Tue Oct 13, 6:13 pm)
Re: [RFC][v8][PATCH 0/10] Implement clone3() system call, H. Peter Anvin, (Tue Oct 13, 7:24 pm)
Re: [RFC][v8][PATCH 0/10] Implement clone3() system call, Sukadev Bhattiprolu, (Tue Oct 13, 9:36 pm)
Re: [RFC][v8][PATCH 0/10] Implement clone3() system call, H. Peter Anvin, (Tue Oct 13, 9:38 pm)
Re: [RFC][v8][PATCH 0/10] Implement clone3() system call, Sukadev Bhattiprolu, (Tue Oct 13, 9:40 pm)
Re: [RFC][v8][PATCH 0/10] Implement clone3() system call, H. Peter Anvin, (Tue Oct 13, 9:50 pm)
Re: [RFC][v8][PATCH 10/10]: Document clone3() syscall, Arnd Bergmann, (Wed Oct 14, 5:26 am)
Re: [RFC][v8][PATCH 0/10] Implement clone3() system call, Serge E. Hallyn, (Wed Oct 14, 9:07 am)
Re: [RFC][v8][PATCH 10/10]: Document clone3() syscall, Sukadev Bhattiprolu, (Wed Oct 14, 11:39 am)
Re: [RFC][v8][PATCH 0/10] Implement clone3() system call, Sukadev Bhattiprolu, (Wed Oct 14, 3:36 pm)
Re: [RFC][v8][PATCH 0/10] Implement clone3() system call, H. Peter Anvin, (Wed Oct 14, 3:49 pm)
Re: [RFC][v8][PATCH 0/10] Implement clone3() system call, Sukadev Bhattiprolu, (Wed Oct 14, 5:17 pm)
Re: [RFC][v8][PATCH 4/10]: Add target_pid parameter to all ..., Sukadev Bhattiprolu, (Wed Oct 14, 5:24 pm)
Re: [RFC][v8][PATCH 9/10]: Define clone3() syscall, Sukadev Bhattiprolu, (Thu Oct 15, 9:20 pm)
Re: [RFC][v8][PATCH 9/10]: Define clone3() syscall, Michael Kerrisk, (Thu Oct 15, 11:25 pm)
Re: [RFC][v8][PATCH 9/10]: Define clone3() syscall, Sukadev Bhattiprolu, (Fri Oct 16, 11:06 am)
Re: [RFC][v8][PATCH 0/10] Implement clone3() system call, Daniel Lezcano, (Fri Oct 16, 12:22 pm)
Re: [RFC][v8][PATCH 0/10] Implement clone3() system call, Sukadev Bhattiprolu, (Fri Oct 16, 12:44 pm)
Re: [RFC][v8][PATCH 9/10]: Define clone3() syscall, Matt Helsley, (Mon Oct 19, 10:44 am)
Re: [RFC][v8][PATCH 0/10] Implement clone3() system call, Daniel Lezcano, (Mon Oct 19, 1:34 pm)
Re: [RFC][v8][PATCH 9/10]: Define clone3() syscall, H. Peter Anvin, (Mon Oct 19, 2:31 pm)
Re: [RFC][v8][PATCH 10/10]: Document clone3() syscall, Pavel Machek, (Mon Oct 19, 2:36 pm)
Re: [RFC][v8][PATCH 9/10]: Define clone3() syscall, Matt Helsley, (Mon Oct 19, 4:50 pm)
Re: [RFC][v8][PATCH 0/10] Implement clone3() system call, Eric W. Biederman, (Mon Oct 19, 8:33 pm)
Re: [RFC][v8][PATCH 0/10] Implement clone3() system call, Sukadev Bhattiprolu, (Mon Oct 19, 9:03 pm)
Re: [RFC][v8][PATCH 0/10] Implement clone3() system call, Eric W. Biederman, (Tue Oct 20, 3:46 am)
Re: [RFC][v8][PATCH 0/10] Implement clone3() system call, Serge E. Hallyn, (Tue Oct 20, 7:09 am)
Re: [RFC][v8][PATCH 0/10] Implement clone3() system call, Serge E. Hallyn, (Tue Oct 20, 7:16 am)
Re: [RFC][v8][PATCH 0/10] Implement clone3() system call, Sukadev Bhattiprolu, (Tue Oct 20, 11:33 am)
Re: [RFC][v8][PATCH 0/10] Implement clone3() system call, Eric W. Biederman, (Tue Oct 20, 12:26 pm)
Re: [RFC][v8][PATCH 9/10]: Define clone3() syscall, Michael Kerrisk, (Tue Oct 20, 9:26 pm)
Re: [RFC][v8][PATCH 0/10] Implement clone3() system call, Sukadev Bhattiprolu, (Tue Oct 20, 11:20 pm)
Re: [RFC][v8][PATCH 10/10]: Document clone3() syscall, Arnd Bergmann, (Wed Oct 21, 1:37 am)
Re: [RFC][v8][PATCH 0/10] Implement clone3() system call, Eric W. Biederman, (Wed Oct 21, 2:16 am)
Re: [RFC][v8][PATCH 10/10]: Document clone3() syscall, Pavel Machek, (Wed Oct 21, 2:33 am)
Re: [RFC][v8][PATCH 9/10]: Define clone3() syscall, H. Peter Anvin, (Wed Oct 21, 6:03 am)
Re: [RFC][v8][PATCH 10/10]: Document clone3() syscall, Arnd Bergmann, (Wed Oct 21, 6:26 am)
Re: [RFC][v8][PATCH 0/10] Implement clone3() system call, Daniel Lezcano, (Wed Oct 21, 8:53 am)
Re: [RFC][v8][PATCH 10/10]: Document clone3() syscall, Sukadev Bhattiprolu, (Wed Oct 21, 11:27 am)
Re: [RFC][v8][PATCH 0/10] Implement clone3() system call, Sukadev Bhattiprolu, (Wed Oct 21, 11:52 am)
Re: [RFC][v8][PATCH 9/10]: Define clone3() syscall, Sukadev Bhattiprolu, (Wed Oct 21, 12:44 pm)
Re: [RFC][v8][PATCH 0/10] Implement clone3() system call, Eric W. Biederman, (Wed Oct 21, 2:11 pm)
Re: [RFC][v8][PATCH 9/10]: Define clone3() syscall, H. Peter Anvin, (Wed Oct 21, 3:03 pm)
Re: [RFC][v8][PATCH 9/10]: Define clone3() syscall, Michael Kerrisk, (Thu Oct 22, 3:26 am)
Re: [RFC][v8][PATCH 9/10]: Define clone3() syscall, Michael Kerrisk, (Thu Oct 22, 3:40 am)
Re: [RFC][v8][PATCH 0/10] Implement clone3() system call, Daniel Lezcano, (Thu Oct 22, 4:22 am)
Re: [RFC][v8][PATCH 9/10]: Define clone3() syscall, H. Peter Anvin, (Thu Oct 22, 4:38 am)
Re: [RFC][v8][PATCH 9/10]: Define clone3() syscall, Michael Kerrisk, (Thu Oct 22, 5:14 am)
Re: [RFC][v8][PATCH 9/10]: Define clone3() syscall, H. Peter Anvin, (Thu Oct 22, 5:19 am)
Re: [RFC][v8][PATCH 9/10]: Define clone3() syscall, Matt Helsley, (Thu Oct 22, 6:57 am)
Re: [RFC][v8][PATCH 9/10]: Define clone3() syscall, Sukadev Bhattiprolu, (Thu Oct 22, 11:10 am)
Re: [RFC][v8][PATCH 0/10] Implement clone3() system call, Sukadev Bhattiprolu, (Thu Oct 22, 5:42 pm)
Re: [RFC][v8][PATCH 0/10] Implement clone3() system call, Eric W. Biederman, (Thu Oct 22, 6:03 pm)
Re: [RFC][v8][PATCH 0/10] Implement clone3() system call, Sukadev Bhattiprolu, (Thu Oct 22, 10:30 pm)
Re: [RFC][v8][PATCH 0/10] Implement clone3() system call, Eric W. Biederman, (Thu Oct 22, 10:44 pm)
Re: [RFC][v8][PATCH 0/10] Implement clone3() system call, Sukadev Bhattiprolu, (Fri Oct 23, 12:21 pm)
Re: [RFC][v8][PATCH 0/10] Implement clone3() system call, Sukadev Bhattiprolu, (Fri Oct 23, 1:48 pm)
Re: [RFC][v8][PATCH 0/10] Implement clone3() system call, Eric W. Biederman, (Fri Oct 23, 4:12 pm)
Re: [RFC][v8][PATCH 0/10] Implement clone3() system call, Eric W. Biederman, (Fri Oct 23, 4:26 pm)
Re: [RFC][v8][PATCH 0/10] Implement clone3() system call, Sukadev Bhattiprolu, (Fri Oct 23, 8:38 pm)