aboutsummaryrefslogtreecommitdiffstats
path: root/fs/btrfs/inode.c
diff options
context:
space:
mode:
authorNaohiro Aota <naota@elisp.net>2013-06-06 05:56:34 -0400
committerChris Mason <chris.mason@fusionio.com>2013-06-08 15:07:53 -0400
commit6379ef9fb2482a92b5fe09f927d6ce1f989c0c6d (patch)
treef4bd8f1479d092f47d93570c4a8e50503d86a05a /fs/btrfs/inode.c
parent7b5ff90ed081787ec0765ceb4fe5ccf5677493a6 (diff)
btrfs: Drop inode if inode root is NULL
There is a path where btrfs_drop_inode() is called with its inode's root is NULL: In btrfs_new_inode(), when btrfs_set_inode_index() fails, iput() is called. We should handle this case before taking look at the root->root_item. Signed-off-by: Naohiro Aota <naota@elisp.net> Reviewed-by: Miao Xie <miaox@cn.fujitsu.com> Signed-off-by: Josef Bacik <jbacik@fusionio.com> Signed-off-by: Chris Mason <chris.mason@fusionio.com>
Diffstat (limited to 'fs/btrfs/inode.c')
-rw-r--r--fs/btrfs/inode.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/fs/btrfs/inode.c b/fs/btrfs/inode.c
index 23c596cd1b98..c931a4dbd031 100644
--- a/fs/btrfs/inode.c
+++ b/fs/btrfs/inode.c
@@ -8011,6 +8011,9 @@ int btrfs_drop_inode(struct inode *inode)
8011{ 8011{
8012 struct btrfs_root *root = BTRFS_I(inode)->root; 8012 struct btrfs_root *root = BTRFS_I(inode)->root;
8013 8013
8014 if (root == NULL)
8015 return 1;
8016
8014 /* the snap/subvol tree is on deleting */ 8017 /* the snap/subvol tree is on deleting */
8015 if (btrfs_root_refs(&root->root_item) == 0 && 8018 if (btrfs_root_refs(&root->root_item) == 0 &&
8016 root != root->fs_info->tree_root) 8019 root != root->fs_info->tree_root)