|
@@ -4992,7 +4992,7 @@ struct inode *btrfs_lookup_dentry(struct inode *dir, struct dentry *dentry)
|
|
|
return ERR_PTR(ret);
|
|
|
|
|
|
if (location.objectid == 0)
|
|
|
- return NULL;
|
|
|
+ return ERR_PTR(-ENOENT);
|
|
|
|
|
|
if (location.type == BTRFS_INODE_ITEM_KEY) {
|
|
|
inode = btrfs_iget(dir->i_sb, &location, root, NULL);
|
|
@@ -5056,10 +5056,17 @@ static void btrfs_dentry_release(struct dentry *dentry)
|
|
|
static struct dentry *btrfs_lookup(struct inode *dir, struct dentry *dentry,
|
|
|
unsigned int flags)
|
|
|
{
|
|
|
- struct dentry *ret;
|
|
|
+ struct inode *inode;
|
|
|
|
|
|
- ret = d_splice_alias(btrfs_lookup_dentry(dir, dentry), dentry);
|
|
|
- return ret;
|
|
|
+ inode = btrfs_lookup_dentry(dir, dentry);
|
|
|
+ if (IS_ERR(inode)) {
|
|
|
+ if (PTR_ERR(inode) == -ENOENT)
|
|
|
+ inode = NULL;
|
|
|
+ else
|
|
|
+ return ERR_CAST(inode);
|
|
|
+ }
|
|
|
+
|
|
|
+ return d_splice_alias(inode, dentry);
|
|
|
}
|
|
|
|
|
|
unsigned char btrfs_filetype_table[] = {
|