]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
btrfs: add write protection to SET_FEATURES ioctl
authorDavid Sterba <dsterba@suse.cz>
Wed, 4 May 2016 09:32:00 +0000 (11:32 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 8 Jun 2016 01:18:55 +0000 (18:18 -0700)
commit 7ab19625a911f7568ec85302e3aa7a64186006c8 upstream.

Perform the want_write check if we get far enough to do any writes.

Signed-off-by: David Sterba <dsterba@suse.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
fs/btrfs/ioctl.c

index ea21e588a8392da923bab64656826abed1a675d4..14e291422ab11393dee9e2a1345ec284983aab17 100644 (file)
@@ -5397,9 +5397,15 @@ static int btrfs_ioctl_set_features(struct file *file, void __user *arg)
        if (ret)
                return ret;
 
+       ret = mnt_want_write_file(file);
+       if (ret)
+               return ret;
+
        trans = btrfs_start_transaction(root, 0);
-       if (IS_ERR(trans))
-               return PTR_ERR(trans);
+       if (IS_ERR(trans)) {
+               ret = PTR_ERR(trans);
+               goto out_drop_write;
+       }
 
        spin_lock(&root->fs_info->super_lock);
        newflags = btrfs_super_compat_flags(super_block);
@@ -5418,7 +5424,11 @@ static int btrfs_ioctl_set_features(struct file *file, void __user *arg)
        btrfs_set_super_incompat_flags(super_block, newflags);
        spin_unlock(&root->fs_info->super_lock);
 
-       return btrfs_commit_transaction(trans, root);
+       ret = btrfs_commit_transaction(trans, root);
+out_drop_write:
+       mnt_drop_write_file(file);
+
+       return ret;
 }
 
 long btrfs_ioctl(struct file *file, unsigned int