0f2452855d
This is based on a patch by Eric W. Biederman, who pointed out that pid namespaces are still fake, and we only have one ever active. So for the time being, we can modify any code which could access tsk->nsproxy->pid_ns during task exit to just use &init_pid_ns instead, and move the exit_task_namespaces call in do_exit() back above exit_notify(), so that an exiting nfs server has a valid tsk->sighand to work with. Long term, pulling pid_ns out of nsproxy might be the cleanest solution. Signed-off-by: Eric W. Biederman <ebiederm@xmission.com> [ Eric's patch fixed to take care of free_pid() too ] Signed-off-by: Serge E. Hallyn <serue@us.ibm.com> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
46 lines
943 B
C
46 lines
943 B
C
#ifndef _LINUX_PID_NS_H
|
|
#define _LINUX_PID_NS_H
|
|
|
|
#include <linux/sched.h>
|
|
#include <linux/mm.h>
|
|
#include <linux/threads.h>
|
|
#include <linux/pid.h>
|
|
#include <linux/nsproxy.h>
|
|
#include <linux/kref.h>
|
|
|
|
struct pidmap {
|
|
atomic_t nr_free;
|
|
void *page;
|
|
};
|
|
|
|
#define PIDMAP_ENTRIES ((PID_MAX_LIMIT + 8*PAGE_SIZE - 1)/PAGE_SIZE/8)
|
|
|
|
struct pid_namespace {
|
|
struct kref kref;
|
|
struct pidmap pidmap[PIDMAP_ENTRIES];
|
|
int last_pid;
|
|
struct task_struct *child_reaper;
|
|
};
|
|
|
|
extern struct pid_namespace init_pid_ns;
|
|
|
|
static inline void get_pid_ns(struct pid_namespace *ns)
|
|
{
|
|
kref_get(&ns->kref);
|
|
}
|
|
|
|
extern int copy_pid_ns(int flags, struct task_struct *tsk);
|
|
extern void free_pid_ns(struct kref *kref);
|
|
|
|
static inline void put_pid_ns(struct pid_namespace *ns)
|
|
{
|
|
kref_put(&ns->kref, free_pid_ns);
|
|
}
|
|
|
|
static inline struct task_struct *child_reaper(struct task_struct *tsk)
|
|
{
|
|
return init_pid_ns.child_reaper;
|
|
}
|
|
|
|
#endif /* _LINUX_PID_NS_H */
|