Commit 18fbbfc2 authored by Al Viro's avatar Al Viro

omfs_lookup(): report IO errors, use d_splice_alias()

Signed-off-by: default avatarAl Viro <viro@zeniv.linux.org.uk>
parent 04bb1ba1
...@@ -305,11 +305,10 @@ static struct dentry *omfs_lookup(struct inode *dir, struct dentry *dentry, ...@@ -305,11 +305,10 @@ static struct dentry *omfs_lookup(struct inode *dir, struct dentry *dentry,
ino_t ino = be64_to_cpu(oi->i_head.h_self); ino_t ino = be64_to_cpu(oi->i_head.h_self);
brelse(bh); brelse(bh);
inode = omfs_iget(dir->i_sb, ino); inode = omfs_iget(dir->i_sb, ino);
if (IS_ERR(inode)) } else if (bh != ERR_PTR(-ENOENT)) {
return ERR_CAST(inode); inode = ERR_CAST(bh);
} }
d_add(dentry, inode); return d_splice_alias(inode, dentry);
return NULL;
} }
/* sanity check block's self pointer */ /* sanity check block's self pointer */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment