diff options
| author | Nikolay Borisov <nborisov@suse.com> | 2019-05-14 13:54:39 +0300 | 
|---|---|---|
| committer | David Sterba <dsterba@suse.com> | 2019-07-01 13:34:54 +0200 | 
| commit | b0d9e1ea17fdd3c1a13e2f9dffe7d808d6c9641a (patch) | |
| tree | 0eea4c256f5920d4f112c2a3d391662cfffa956e /fs/btrfs/dev-replace.c | |
| parent | ddb93784692fd41d7f1e74cf8b441428b7e57a64 (diff) | |
| download | blackbird-op-linux-b0d9e1ea17fdd3c1a13e2f9dffe7d808d6c9641a.tar.gz blackbird-op-linux-b0d9e1ea17fdd3c1a13e2f9dffe7d808d6c9641a.zip | |
btrfs: Reduce critical section in btrfs_init_dev_replace_tgtdev
There is no point in holding btrfs_fs_devices::device_list_mutex
while initialising fields of the not-yet-published device. Instead,
hold the mutex only when the newly initialised device is being
published. I think holding device_list_mutex here is redundant
altogether, because at this point BTRFS_FS_EXCL_OP is set which
prevents device removal/addition/balance/resize to occur.
Reviewed-by: Johannes Thumshirn <jthumshirn@suse.de>
Signed-off-by: Nikolay Borisov <nborisov@suse.com>
Reviewed-by: David Sterba <dsterba@suse.com>
Signed-off-by: David Sterba <dsterba@suse.com>
Diffstat (limited to 'fs/btrfs/dev-replace.c')
| -rw-r--r-- | fs/btrfs/dev-replace.c | 3 | 
1 files changed, 2 insertions, 1 deletions
| diff --git a/fs/btrfs/dev-replace.c b/fs/btrfs/dev-replace.c index 1b83787176f9..2fa826b12d40 100644 --- a/fs/btrfs/dev-replace.c +++ b/fs/btrfs/dev-replace.c @@ -237,7 +237,6 @@ static int btrfs_init_dev_replace_tgtdev(struct btrfs_fs_info *fs_info,  	}  	rcu_assign_pointer(device->name, name); -	mutex_lock(&fs_info->fs_devices->device_list_mutex);  	set_bit(BTRFS_DEV_STATE_WRITEABLE, &device->dev_state);  	device->generation = 0;  	device->io_width = fs_info->sectorsize; @@ -256,6 +255,8 @@ static int btrfs_init_dev_replace_tgtdev(struct btrfs_fs_info *fs_info,  	device->dev_stats_valid = 1;  	set_blocksize(device->bdev, BTRFS_BDEV_BLOCKSIZE);  	device->fs_devices = fs_info->fs_devices; + +	mutex_lock(&fs_info->fs_devices->device_list_mutex);  	list_add(&device->dev_list, &fs_info->fs_devices->devices);  	fs_info->fs_devices->num_devices++;  	fs_info->fs_devices->open_devices++; | 

