diff options
author | Eric W. Biederman <ebiederm@xmission.com> | 2019-01-30 08:54:12 -0500 |
---|---|---|
committer | David Sterba <dsterba@suse.com> | 2019-01-30 12:16:47 -0500 |
commit | 532b618bdf237250d6d4566536d4b6ce3d0a31fe (patch) | |
tree | f0dbc1ed55d132b859a62e0785cf4cd37261c64c /fs | |
parent | c7cc64a98512ffc41df86d14a414eb3b09bf7481 (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.c | 3 |
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 | ||