diff options
author | Andre Noll <maan@systemlinux.org> | 2009-06-18 08:49:23 +1000 |
---|---|---|
committer | NeilBrown <neilb@suse.de> | 2009-06-18 08:49:23 +1000 |
commit | 0894cc3066aaa3e75a99383c0d25feebf9b688ac (patch) | |
tree | 651664e6b288e36dc9553443e334e650139851c8 /drivers/md/multipath.c | |
parent | 8190e754e0723de7cecb80bdd9eb93911dfa04a1 (diff) | |
download | lwn-0894cc3066aaa3e75a99383c0d25feebf9b688ac.tar.gz lwn-0894cc3066aaa3e75a99383c0d25feebf9b688ac.zip |
md: Move check for bitmap presence to personality code.
If the superblock of a component device indicates the presence of a
bitmap but the corresponding raid personality does not support bitmaps
(raid0, linear, multipath, faulty), then something is seriously wrong
and we'd better refuse to run such an array.
Currently, this check is performed while the superblocks are examined,
i.e. before entering personality code. Therefore the generic md layer
must know which raid levels support bitmaps and which do not.
This patch avoids this layer violation without adding identical code
to various personalities. This is accomplished by introducing a new
public function to md.c, md_check_no_bitmap(), which replaces the
hard-coded checks in the superblock loading functions.
A call to md_check_no_bitmap() is added to the ->run method of each
personality which does not support bitmaps and assembly is aborted
if at least one component device contains a bitmap.
Signed-off-by: Andre Noll <maan@systemlinux.org>
Signed-off-by: NeilBrown <neilb@suse.de>
Diffstat (limited to 'drivers/md/multipath.c')
-rw-r--r-- | drivers/md/multipath.c | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/drivers/md/multipath.c b/drivers/md/multipath.c index c1ca63f278a9..cbe368fa6598 100644 --- a/drivers/md/multipath.c +++ b/drivers/md/multipath.c @@ -421,6 +421,9 @@ static int multipath_run (mddev_t *mddev) struct multipath_info *disk; mdk_rdev_t *rdev; + if (md_check_no_bitmap(mddev)) + return -EINVAL; + if (mddev->level != LEVEL_MULTIPATH) { printk("multipath: %s: raid level not set to multipath IO (%d)\n", mdname(mddev), mddev->level); |