diff options
Diffstat (limited to 'kernel')
-rw-r--r-- | kernel/exit.c | 6 | ||||
-rw-r--r-- | kernel/fork.c | 8 | ||||
-rw-r--r-- | kernel/sys.c | 7 | ||||
-rw-r--r-- | kernel/sysctl.c | 2 | ||||
-rw-r--r-- | kernel/timer.c | 2 |
5 files changed, 8 insertions, 17 deletions
diff --git a/kernel/exit.c b/kernel/exit.c index 2567de3487bd..81345ba4b253 100644 --- a/kernel/exit.c +++ b/kernel/exit.c | |||
@@ -1174,7 +1174,7 @@ static int wait_task_zombie(struct task_struct *p, int noreap, | |||
1174 | { | 1174 | { |
1175 | unsigned long state; | 1175 | unsigned long state; |
1176 | int retval, status, traced; | 1176 | int retval, status, traced; |
1177 | pid_t pid = task_pid_nr_ns(p, current->nsproxy->pid_ns); | 1177 | pid_t pid = task_pid_vnr(p); |
1178 | 1178 | ||
1179 | if (unlikely(noreap)) { | 1179 | if (unlikely(noreap)) { |
1180 | uid_t uid = p->uid; | 1180 | uid_t uid = p->uid; |
@@ -1369,7 +1369,7 @@ unlock_sig: | |||
1369 | * possibly take page faults for user memory. | 1369 | * possibly take page faults for user memory. |
1370 | */ | 1370 | */ |
1371 | get_task_struct(p); | 1371 | get_task_struct(p); |
1372 | pid = task_pid_nr_ns(p, current->nsproxy->pid_ns); | 1372 | pid = task_pid_vnr(p); |
1373 | why = (p->ptrace & PT_PTRACED) ? CLD_TRAPPED : CLD_STOPPED; | 1373 | why = (p->ptrace & PT_PTRACED) ? CLD_TRAPPED : CLD_STOPPED; |
1374 | read_unlock(&tasklist_lock); | 1374 | read_unlock(&tasklist_lock); |
1375 | 1375 | ||
@@ -1428,7 +1428,7 @@ static int wait_task_continued(struct task_struct *p, int noreap, | |||
1428 | p->signal->flags &= ~SIGNAL_STOP_CONTINUED; | 1428 | p->signal->flags &= ~SIGNAL_STOP_CONTINUED; |
1429 | spin_unlock_irq(&p->sighand->siglock); | 1429 | spin_unlock_irq(&p->sighand->siglock); |
1430 | 1430 | ||
1431 | pid = task_pid_nr_ns(p, current->nsproxy->pid_ns); | 1431 | pid = task_pid_vnr(p); |
1432 | uid = p->uid; | 1432 | uid = p->uid; |
1433 | get_task_struct(p); | 1433 | get_task_struct(p); |
1434 | read_unlock(&tasklist_lock); | 1434 | read_unlock(&tasklist_lock); |
diff --git a/kernel/fork.c b/kernel/fork.c index ca54d9704644..31a2bad63a08 100644 --- a/kernel/fork.c +++ b/kernel/fork.c | |||
@@ -1488,13 +1488,7 @@ long do_fork(unsigned long clone_flags, | |||
1488 | if (!IS_ERR(p)) { | 1488 | if (!IS_ERR(p)) { |
1489 | struct completion vfork; | 1489 | struct completion vfork; |
1490 | 1490 | ||
1491 | /* | 1491 | nr = task_pid_vnr(p); |
1492 | * this is enough to call pid_nr_ns here, but this if | ||
1493 | * improves optimisation of regular fork() | ||
1494 | */ | ||
1495 | nr = (clone_flags & CLONE_NEWPID) ? | ||
1496 | task_pid_nr_ns(p, current->nsproxy->pid_ns) : | ||
1497 | task_pid_vnr(p); | ||
1498 | 1492 | ||
1499 | if (clone_flags & CLONE_PARENT_SETTID) | 1493 | if (clone_flags & CLONE_PARENT_SETTID) |
1500 | put_user(nr, parent_tidptr); | 1494 | put_user(nr, parent_tidptr); |
diff --git a/kernel/sys.c b/kernel/sys.c index 5a61f8071b8e..a626116af5db 100644 --- a/kernel/sys.c +++ b/kernel/sys.c | |||
@@ -991,17 +991,14 @@ asmlinkage long sys_getpgid(pid_t pid) | |||
991 | else { | 991 | else { |
992 | int retval; | 992 | int retval; |
993 | struct task_struct *p; | 993 | struct task_struct *p; |
994 | struct pid_namespace *ns; | ||
995 | |||
996 | ns = current->nsproxy->pid_ns; | ||
997 | 994 | ||
998 | read_lock(&tasklist_lock); | 995 | read_lock(&tasklist_lock); |
999 | p = find_task_by_pid_ns(pid, ns); | 996 | p = find_task_by_vpid(pid); |
1000 | retval = -ESRCH; | 997 | retval = -ESRCH; |
1001 | if (p) { | 998 | if (p) { |
1002 | retval = security_task_getpgid(p); | 999 | retval = security_task_getpgid(p); |
1003 | if (!retval) | 1000 | if (!retval) |
1004 | retval = task_pgrp_nr_ns(p, ns); | 1001 | retval = task_pgrp_vnr(p); |
1005 | } | 1002 | } |
1006 | read_unlock(&tasklist_lock); | 1003 | read_unlock(&tasklist_lock); |
1007 | return retval; | 1004 | return retval; |
diff --git a/kernel/sysctl.c b/kernel/sysctl.c index 9dadc9d88a03..89d963ffbb01 100644 --- a/kernel/sysctl.c +++ b/kernel/sysctl.c | |||
@@ -2488,7 +2488,7 @@ static int proc_do_cad_pid(struct ctl_table *table, int write, struct file *filp | |||
2488 | pid_t tmp; | 2488 | pid_t tmp; |
2489 | int r; | 2489 | int r; |
2490 | 2490 | ||
2491 | tmp = pid_nr_ns(cad_pid, current->nsproxy->pid_ns); | 2491 | tmp = pid_vnr(cad_pid); |
2492 | 2492 | ||
2493 | r = __do_proc_dointvec(&tmp, table, write, filp, buffer, | 2493 | r = __do_proc_dointvec(&tmp, table, write, filp, buffer, |
2494 | lenp, ppos, NULL, NULL); | 2494 | lenp, ppos, NULL, NULL); |
diff --git a/kernel/timer.c b/kernel/timer.c index 70b29b59343f..1c4183cd8bdb 100644 --- a/kernel/timer.c +++ b/kernel/timer.c | |||
@@ -979,7 +979,7 @@ asmlinkage long sys_getppid(void) | |||
979 | int pid; | 979 | int pid; |
980 | 980 | ||
981 | rcu_read_lock(); | 981 | rcu_read_lock(); |
982 | pid = task_tgid_nr_ns(current->real_parent, current->nsproxy->pid_ns); | 982 | pid = task_tgid_vnr(current->real_parent); |
983 | rcu_read_unlock(); | 983 | rcu_read_unlock(); |
984 | 984 | ||
985 | return pid; | 985 | return pid; |