Btrfs: open_ctree: Fix possible memory leak
authorchandan <chandan@linux.vnet.ibm.com>
Mon, 5 Oct 2015 16:44:25 +0000 (22:14 +0530)
committerChris Mason <clm@fb.com>
Tue, 6 Oct 2015 13:55:22 +0000 (06:55 -0700)
After reading one of chunk or tree root tree's root node from disk, if the
root node does not have EXTENT_BUFFER_UPTODATE flag set, we fail to release
the memory used by the root node. Fix this.

Signed-off-by: Chandan Rajendra <chandan@linux.vnet.ibm.com>
fs/btrfs/disk-io.c

index aa59871885da6d5623891c0e2de0599dd2727cda..807f6854acaa4f9d51e51db98abee1342505360d 100644 (file)
@@ -2842,6 +2842,8 @@ int open_ctree(struct super_block *sb,
            !extent_buffer_uptodate(chunk_root->node)) {
                printk(KERN_ERR "BTRFS: failed to read chunk root on %s\n",
                       sb->s_id);
+               if (!IS_ERR(chunk_root->node))
+                       free_extent_buffer(chunk_root->node);
                chunk_root->node = NULL;
                goto fail_tree_roots;
        }
@@ -2880,6 +2882,8 @@ retry_root_backup:
            !extent_buffer_uptodate(tree_root->node)) {
                printk(KERN_WARNING "BTRFS: failed to read tree root on %s\n",
                       sb->s_id);
+               if (!IS_ERR(tree_root->node))
+                       free_extent_buffer(tree_root->node);
                tree_root->node = NULL;
                goto recovery_tree_root;
        }