aboutsummaryrefslogtreecommitdiffstats
path: root/fs
diff options
context:
space:
mode:
Diffstat (limited to 'fs')
-rw-r--r--fs/btrfs/scrub.c11
1 files changed, 11 insertions, 0 deletions
diff --git a/fs/btrfs/scrub.c b/fs/btrfs/scrub.c
index b6d198f5181e..23d3f6e6a482 100644
--- a/fs/btrfs/scrub.c
+++ b/fs/btrfs/scrub.c
@@ -2904,6 +2904,7 @@ int btrfs_scrub_dev(struct btrfs_fs_info *fs_info, u64 devid, u64 start,
2904 struct scrub_ctx *sctx; 2904 struct scrub_ctx *sctx;
2905 int ret; 2905 int ret;
2906 struct btrfs_device *dev; 2906 struct btrfs_device *dev;
2907 struct rcu_string *name;
2907 2908
2908 if (btrfs_fs_closing(fs_info)) 2909 if (btrfs_fs_closing(fs_info))
2909 return -EINVAL; 2910 return -EINVAL;
@@ -2965,6 +2966,16 @@ int btrfs_scrub_dev(struct btrfs_fs_info *fs_info, u64 devid, u64 start,
2965 return -ENODEV; 2966 return -ENODEV;
2966 } 2967 }
2967 2968
2969 if (!is_dev_replace && !readonly && !dev->writeable) {
2970 mutex_unlock(&fs_info->fs_devices->device_list_mutex);
2971 rcu_read_lock();
2972 name = rcu_dereference(dev->name);
2973 btrfs_err(fs_info, "scrub: device %s is not writable",
2974 name->str);
2975 rcu_read_unlock();
2976 return -EROFS;
2977 }
2978
2968 mutex_lock(&fs_info->scrub_lock); 2979 mutex_lock(&fs_info->scrub_lock);
2969 if (!dev->in_fs_metadata || dev->is_tgtdev_for_dev_replace) { 2980 if (!dev->in_fs_metadata || dev->is_tgtdev_for_dev_replace) {
2970 mutex_unlock(&fs_info->scrub_lock); 2981 mutex_unlock(&fs_info->scrub_lock);