summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAl Viro <viro@zeniv.linux.org.uk>2016-04-28 17:19:43 +0200
committerAl Viro <viro@zeniv.linux.org.uk>2016-05-03 01:51:16 +0200
commit12fa5e240419237d848abe3d40809eabe9e8f4ca (patch)
treea3a0aedac1936092415ac811eabaae8e97d724f2
parentatomic_open(): reorder and clean up a bit (diff)
downloadlinux-12fa5e240419237d848abe3d40809eabe9e8f4ca.tar.xz
linux-12fa5e240419237d848abe3d40809eabe9e8f4ca.zip
lookup_open(): expand the call of real_lookup()
... and lose the duplicate IS_DEADDIR() - we'd already checked that. Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
-rw-r--r--fs/namei.c13
1 files changed, 10 insertions, 3 deletions
diff --git a/fs/namei.c b/fs/namei.c
index 8d62a89d7bff..b9dde8490318 100644
--- a/fs/namei.c
+++ b/fs/namei.c
@@ -2969,9 +2969,16 @@ static int lookup_open(struct nameidata *nd, struct path *path,
no_open:
if (need_lookup) {
- dentry = lookup_real(dir_inode, dentry, nd->flags);
- if (IS_ERR(dentry))
- return PTR_ERR(dentry);
+ struct dentry *res = dir_inode->i_op->lookup(dir_inode, dentry,
+ nd->flags);
+ if (unlikely(res)) {
+ if (IS_ERR(res)) {
+ error = PTR_ERR(res);
+ goto out_dput;
+ }
+ dput(dentry);
+ dentry = res;
+ }
}
/* Negative dentry, just create the file */