aboutsummaryrefslogtreecommitdiffstats
path: root/fs/btrfs
diff options
context:
space:
mode:
authorChris Mason <chris.mason@oracle.com>2011-05-27 10:03:58 -0400
committerChris Mason <chris.mason@oracle.com>2011-05-27 10:03:58 -0400
commit174ba50915b08dcfd07c8b5fb795b46a165fa09a (patch)
tree94bc84b6e8bea05775373f90bd8eb7aa254a943f /fs/btrfs
parenta47d6b70e280401d553e7cac6f5750870de1ad21 (diff)
Btrfs: use the device_list_mutex during write_dev_supers
write_dev_supers was changed to use RCU to protect the list of devices, but it was then sleeping while it actually wrote the supers. This fixes it to just use the mutex, since we really don't any concurrency in write_dev_supers anyway. Signed-off-by: Chris Mason <chris.mason@oracle.com>
Diffstat (limited to 'fs/btrfs')
-rw-r--r--fs/btrfs/disk-io.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/fs/btrfs/disk-io.c b/fs/btrfs/disk-io.c
index b2588a552658..98b6a71decba 100644
--- a/fs/btrfs/disk-io.c
+++ b/fs/btrfs/disk-io.c
@@ -2310,7 +2310,7 @@ int write_all_supers(struct btrfs_root *root, int max_mirrors)
2310 sb = &root->fs_info->super_for_commit; 2310 sb = &root->fs_info->super_for_commit;
2311 dev_item = &sb->dev_item; 2311 dev_item = &sb->dev_item;
2312 2312
2313 rcu_read_lock(); 2313 mutex_lock(&root->fs_info->fs_devices->device_list_mutex);
2314 head = &root->fs_info->fs_devices->devices; 2314 head = &root->fs_info->fs_devices->devices;
2315 list_for_each_entry_rcu(dev, head, dev_list) { 2315 list_for_each_entry_rcu(dev, head, dev_list) {
2316 if (!dev->bdev) { 2316 if (!dev->bdev) {
@@ -2355,7 +2355,7 @@ int write_all_supers(struct btrfs_root *root, int max_mirrors)
2355 if (ret) 2355 if (ret)
2356 total_errors++; 2356 total_errors++;
2357 } 2357 }
2358 rcu_read_unlock(); 2358 mutex_unlock(&root->fs_info->fs_devices->device_list_mutex);
2359 if (total_errors > max_errors) { 2359 if (total_errors > max_errors) {
2360 printk(KERN_ERR "btrfs: %d errors while writing supers\n", 2360 printk(KERN_ERR "btrfs: %d errors while writing supers\n",
2361 total_errors); 2361 total_errors);