aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/md
diff options
context:
space:
mode:
authorJianjian Huo <samuel.huo@gmail.com>2014-07-13 12:08:59 -0400
committerKent Overstreet <kmo@daterainc.com>2014-08-04 18:23:04 -0400
commit789d21dbd9d8889e62c79ec19585fcc97e42ef07 (patch)
treeb0b8e1f363d871b67fa9197da6b671e5a485d790 /drivers/md
parent5b25abade29616d42d60f9bd5e6a5ad07f7314e3 (diff)
bcache: add mutex lock for bch_is_open
Since bch_is_open will iterate linked list bch_cache_sets and uncached_devices, it needs bch_register_lock. Signed-off-by: Jianjian Huo <samuel.huo@gmail.com>
Diffstat (limited to 'drivers/md')
-rw-r--r--drivers/md/bcache/super.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/drivers/md/bcache/super.c b/drivers/md/bcache/super.c
index b6114d672413..60e75130a44c 100644
--- a/drivers/md/bcache/super.c
+++ b/drivers/md/bcache/super.c
@@ -1966,10 +1966,12 @@ static ssize_t register_bcache(struct kobject *k, struct kobj_attribute *attr,
1966 if (IS_ERR(bdev)) { 1966 if (IS_ERR(bdev)) {
1967 if (bdev == ERR_PTR(-EBUSY)) { 1967 if (bdev == ERR_PTR(-EBUSY)) {
1968 bdev = lookup_bdev(strim(path)); 1968 bdev = lookup_bdev(strim(path));
1969 mutex_lock(&bch_register_lock);
1969 if (!IS_ERR(bdev) && bch_is_open(bdev)) 1970 if (!IS_ERR(bdev) && bch_is_open(bdev))
1970 err = "device already registered"; 1971 err = "device already registered";
1971 else 1972 else
1972 err = "device busy"; 1973 err = "device busy";
1974 mutex_unlock(&bch_register_lock);
1973 } 1975 }
1974 goto err; 1976 goto err;
1975 } 1977 }