diff options
author | Jianjian Huo <samuel.huo@gmail.com> | 2014-07-13 18:08:59 +0200 |
---|---|---|
committer | Kent Overstreet <kmo@daterainc.com> | 2014-08-05 00:23:04 +0200 |
commit | 789d21dbd9d8889e62c79ec19585fcc97e42ef07 (patch) | |
tree | b0b8e1f363d871b67fa9197da6b671e5a485d790 /drivers/md | |
parent | bcache: Correct printing of btree_gc_max_duration_ms (diff) | |
download | linux-789d21dbd9d8889e62c79ec19585fcc97e42ef07.tar.xz linux-789d21dbd9d8889e62c79ec19585fcc97e42ef07.zip |
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.c | 2 |
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, if (IS_ERR(bdev)) { if (bdev == ERR_PTR(-EBUSY)) { bdev = lookup_bdev(strim(path)); + mutex_lock(&bch_register_lock); if (!IS_ERR(bdev) && bch_is_open(bdev)) err = "device already registered"; else err = "device busy"; + mutex_unlock(&bch_register_lock); } goto err; } |