From: Al Viro Date: Fri, 27 May 2011 11:03:15 +0000 (-0400) Subject: Lift the check for automount points into do_lookup() X-Git-Url: https://git.karo-electronics.de/?a=commitdiff_plain;h=d6e9bd256c88ce5f4b668249e363a74f51393daa;p=linux-beck.git Lift the check for automount points into do_lookup() Signed-off-by: Al Viro --- diff --git a/fs/namei.c b/fs/namei.c index 988081424098..1ab641f2e78e 100644 --- a/fs/namei.c +++ b/fs/namei.c @@ -945,9 +945,6 @@ static bool __follow_mount_rcu(struct nameidata *nd, struct path *path, path->dentry = mounted->mnt_root; nd->seq = read_seqcount_begin(&path->dentry->d_seq); } - - if (unlikely(path->dentry->d_flags & DCACHE_NEED_AUTOMOUNT)) - return false; return true; } @@ -1164,8 +1161,11 @@ static int do_lookup(struct nameidata *nd, struct qstr *name, } path->mnt = mnt; path->dentry = dentry; - if (likely(__follow_mount_rcu(nd, path, inode))) - return 0; + if (unlikely(!__follow_mount_rcu(nd, path, inode))) + goto unlazy; + if (unlikely(path->dentry->d_flags & DCACHE_NEED_AUTOMOUNT)) + goto unlazy; + return 0; unlazy: if (unlazy_walk(nd, dentry)) return -ECHILD;