summaryrefslogtreecommitdiffstats
path: root/fs
diff options
context:
space:
mode:
authorEric W. Biederman <ebiederm@xmission.com>2019-01-30 08:54:12 -0500
committerDavid Sterba <dsterba@suse.com>2019-01-30 12:16:47 -0500
commit532b618bdf237250d6d4566536d4b6ce3d0a31fe (patch)
treef0dbc1ed55d132b859a62e0785cf4cd37261c64c /fs
parentc7cc64a98512ffc41df86d14a414eb3b09bf7481 (diff)
btrfs: On error always free subvol_name in btrfs_mount
The subvol_name is allocated in btrfs_parse_subvol_options and is consumed and freed in mount_subvol. Add a free to the error paths that don't call mount_subvol so that it is guaranteed that subvol_name is freed when an error happens. Fixes: 312c89fbca06 ("btrfs: cleanup btrfs_mount() using btrfs_mount_root()") Cc: stable@vger.kernel.org # v4.19+ Reviewed-by: Nikolay Borisov <nborisov@suse.com> Signed-off-by: "Eric W. Biederman" <ebiederm@xmission.com> Reviewed-by: David Sterba <dsterba@suse.com> Signed-off-by: David Sterba <dsterba@suse.com>
Diffstat (limited to 'fs')
-rw-r--r--fs/btrfs/super.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/fs/btrfs/super.c b/fs/btrfs/super.c
index 368a5b9e6c13..74023786a735 100644
--- a/fs/btrfs/super.c
+++ b/fs/btrfs/super.c
@@ -1677,6 +1677,7 @@ static struct dentry *btrfs_mount(struct file_system_type *fs_type, int flags,
1677 flags | SB_RDONLY, device_name, data); 1677 flags | SB_RDONLY, device_name, data);
1678 if (IS_ERR(mnt_root)) { 1678 if (IS_ERR(mnt_root)) {
1679 root = ERR_CAST(mnt_root); 1679 root = ERR_CAST(mnt_root);
1680 kfree(subvol_name);
1680 goto out; 1681 goto out;
1681 } 1682 }
1682 1683
@@ -1686,12 +1687,14 @@ static struct dentry *btrfs_mount(struct file_system_type *fs_type, int flags,
1686 if (error < 0) { 1687 if (error < 0) {
1687 root = ERR_PTR(error); 1688 root = ERR_PTR(error);
1688 mntput(mnt_root); 1689 mntput(mnt_root);
1690 kfree(subvol_name);
1689 goto out; 1691 goto out;
1690 } 1692 }
1691 } 1693 }
1692 } 1694 }
1693 if (IS_ERR(mnt_root)) { 1695 if (IS_ERR(mnt_root)) {
1694 root = ERR_CAST(mnt_root); 1696 root = ERR_CAST(mnt_root);
1697 kfree(subvol_name);
1695 goto out; 1698 goto out;
1696 } 1699 }
1697 1700