btrfs: add write protection to SET_FEATURES ioctl
authorDavid Sterba <dsterba@suse.cz>
Wed, 4 May 2016 09:32:00 +0000 (11:32 +0200)
committerDavid Sterba <dsterba@suse.com>
Fri, 6 May 2016 13:22:49 +0000 (15:22 +0200)
Perform the want_write check if we get far enough to do any writes.

Signed-off-by: David Sterba <dsterba@suse.com>
fs/btrfs/ioctl.c

index 798f58e7338e8222ec6c99646db497fec48d6e3e..1e8ce5247a810645bf5b265f1e1c56c5e6608b3b 100644 (file)
@@ -5406,9 +5406,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);
@@ -5427,7 +5433,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