diff options
author | Jianjian Huo <samuel.huo@gmail.com> | 2014-07-13 12:08:59 -0400 |
---|---|---|
committer | Kent Overstreet <kmo@daterainc.com> | 2014-08-04 18:23:04 -0400 |
commit | 789d21dbd9d8889e62c79ec19585fcc97e42ef07 (patch) | |
tree | b0b8e1f363d871b67fa9197da6b671e5a485d790 /drivers/md/bcache | |
parent | 5b25abade29616d42d60f9bd5e6a5ad07f7314e3 (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/bcache')
-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, | |||
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 | } |