summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorNeilBrown <neilb@suse.de>2010-09-08 16:48:17 +1000
committerNeilBrown <neilb@suse.de>2010-09-17 13:53:28 +1000
commitddcf3522cf03a147c867a2e0155761652dbd156a (patch)
treee5a47b7db19dc147df769b6cd8c82ac56964f6e1
parent126925c090155f13e90b9e7e8c4010e96027c00a (diff)
downloadop-kernel-dev-ddcf3522cf03a147c867a2e0155761652dbd156a.zip
op-kernel-dev-ddcf3522cf03a147c867a2e0155761652dbd156a.tar.gz
md: fix v1.x metadata update when a disk is missing.
If an array with 1.x metadata is assembled with the last disk missing, md doesn't properly record the fact that the disk was missing. This is unlikely to cause a real problem as the event count will be different to the count on the missing disk so it won't be included in the array. However it could still cause confusion. So make sure we clear all the relevant slots, not just the early ones. Signed-off-by: NeilBrown <neilb@suse.de>
-rw-r--r--drivers/md/md.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/drivers/md/md.c b/drivers/md/md.c
index bdd9bba..f20d13e 100644
--- a/drivers/md/md.c
+++ b/drivers/md/md.c
@@ -1643,7 +1643,9 @@ static void super_1_sync(mddev_t *mddev, mdk_rdev_t *rdev)
bmask = queue_logical_block_size(rdev->bdev->bd_disk->queue)-1;
if (rdev->sb_size & bmask)
rdev->sb_size = (rdev->sb_size | bmask) + 1;
- }
+ } else
+ max_dev = le32_to_cpu(sb->max_dev);
+
for (i=0; i<max_dev;i++)
sb->dev_roles[i] = cpu_to_le16(0xfffe);
OpenPOWER on IntegriCloud