diff --git a/fs/proc/base.c b/fs/proc/base.c index 98bfd18e61bc359f682f048e5f26f9221864a190..cb63dbc52e138498eeb6513a2a4bac7ea7dbbd72 100644 --- a/fs/proc/base.c +++ b/fs/proc/base.c @@ -2100,19 +2100,21 @@ static int pid_revalidate(struct dentry *dentry, unsigned int flags) { struct inode *inode; struct task_struct *task; + int ret = 0; - if (flags & LOOKUP_RCU) - return -ECHILD; - - inode = d_inode(dentry); - task = get_proc_task(inode); + rcu_read_lock(); + inode = d_inode_rcu(dentry); + if (!inode) + goto out; + task = pid_task(proc_pid(inode), PIDTYPE_PID); if (task) { pid_update_inode(task, inode); - put_task_struct(task); - return 1; + ret = 1; } - return 0; +out: + rcu_read_unlock(); + return ret; } static inline bool proc_inode_is_dead(struct inode *inode)