diff options
Diffstat (limited to 'kernel/pid.c')
| -rw-r--r-- | kernel/pid.c | 14 | 
1 files changed, 4 insertions, 10 deletions
diff --git a/kernel/pid.c b/kernel/pid.c index 731c4e528f4e..020dedbdf066 100644 --- a/kernel/pid.c +++ b/kernel/pid.c @@ -527,8 +527,11 @@ pid_t __task_pid_nr_ns(struct task_struct *task, enum pid_type type,  	if (!ns)  		ns = task_active_pid_ns(current);  	if (likely(pid_alive(task))) { -		if (type != PIDTYPE_PID) +		if (type != PIDTYPE_PID) { +			if (type == __PIDTYPE_TGID) +				type = PIDTYPE_PID;  			task = task->group_leader; +		}  		nr = pid_nr_ns(rcu_dereference(task->pids[type].pid), ns);  	}  	rcu_read_unlock(); @@ -537,12 +540,6 @@ pid_t __task_pid_nr_ns(struct task_struct *task, enum pid_type type,  }  EXPORT_SYMBOL(__task_pid_nr_ns); -pid_t task_tgid_nr_ns(struct task_struct *tsk, struct pid_namespace *ns) -{ -	return pid_nr_ns(task_tgid(tsk), ns); -} -EXPORT_SYMBOL(task_tgid_nr_ns); -  struct pid_namespace *task_active_pid_ns(struct task_struct *tsk)  {  	return ns_of_pid(task_pid(tsk)); @@ -575,13 +572,10 @@ struct pid *find_ge_pid(int nr, struct pid_namespace *ns)   */  void __init pidhash_init(void)  { -	unsigned int pidhash_size; -  	pid_hash = alloc_large_system_hash("PID", sizeof(*pid_hash), 0, 18,  					   HASH_EARLY | HASH_SMALL | HASH_ZERO,  					   &pidhash_shift, NULL,  					   0, 4096); -	pidhash_size = 1U << pidhash_shift;  }  void __init pidmap_init(void)  |