|
@@ -2259,8 +2259,22 @@ out:
|
|
|
|
|
|
void proc_flush_task(struct task_struct *task)
|
|
void proc_flush_task(struct task_struct *task)
|
|
{
|
|
{
|
|
- proc_flush_task_mnt(proc_mnt, task->pid,
|
|
|
|
- thread_group_leader(task) ? 0 : task->tgid);
|
|
|
|
|
|
+ int i, leader;
|
|
|
|
+ struct pid *pid, *tgid;
|
|
|
|
+ struct upid *upid;
|
|
|
|
+
|
|
|
|
+ leader = thread_group_leader(task);
|
|
|
|
+ proc_flush_task_mnt(proc_mnt, task->pid, leader ? task->tgid : 0);
|
|
|
|
+ pid = task_pid(task);
|
|
|
|
+ if (pid->level == 0)
|
|
|
|
+ return;
|
|
|
|
+
|
|
|
|
+ tgid = task_tgid(task);
|
|
|
|
+ for (i = 1; i <= pid->level; i++) {
|
|
|
|
+ upid = &pid->numbers[i];
|
|
|
|
+ proc_flush_task_mnt(upid->ns->proc_mnt, upid->nr,
|
|
|
|
+ leader ? 0 : tgid->numbers[i].nr);
|
|
|
|
+ }
|
|
}
|
|
}
|
|
|
|
|
|
static struct dentry *proc_pid_instantiate(struct inode *dir,
|
|
static struct dentry *proc_pid_instantiate(struct inode *dir,
|