Btrfs: fix btrfs_is_free_space_inode to recognize btree inode
For btree inode, its root is also 'tree root', so btree inode can be misunderstood as a free space inode. We should add one more check for btree inode. Signed-off-by: Liu Bo <liubo2009@cn.fujitsu.com> Signed-off-by: Josef Bacik <jbacik@fusionio.com>
This commit is contained in:
parent
c0901581ad
commit
51a8cf9d2d
@ -194,8 +194,10 @@ static inline void btrfs_i_size_write(struct inode *inode, u64 size)
|
|||||||
static inline bool btrfs_is_free_space_inode(struct btrfs_root *root,
|
static inline bool btrfs_is_free_space_inode(struct btrfs_root *root,
|
||||||
struct inode *inode)
|
struct inode *inode)
|
||||||
{
|
{
|
||||||
if (root == root->fs_info->tree_root ||
|
if (root == root->fs_info->tree_root &&
|
||||||
BTRFS_I(inode)->location.objectid == BTRFS_FREE_INO_OBJECTID)
|
btrfs_ino(inode) != BTRFS_BTREE_INODE_OBJECTID)
|
||||||
|
return true;
|
||||||
|
if (BTRFS_I(inode)->location.objectid == BTRFS_FREE_INO_OBJECTID)
|
||||||
return true;
|
return true;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user