summaryrefslogtreecommitdiffstats
path: root/drivers/md/raid10.c
diff options
context:
space:
mode:
authorNeilBrown <neilb@suse.de>2011-07-27 21:31:47 -0400
committerNeilBrown <neilb@suse.de>2011-07-27 21:31:47 -0400
commit34b343cff4354ab9864be83be88405fd53d928a0 (patch)
tree10d75ecac6091f955cbb8a60b79f443355ca4ea8 /drivers/md/raid10.c
parent6e0d2d0312fb20c1edac1b2c849068c1c7944abf (diff)
md: don't allow arrays to contain devices with bad blocks.
As no personality understand bad block lists yet, we must reject any device that is known to contain bad blocks. As the personalities get taught, these tests can be removed. This only applies to raid1/raid5/raid10. For linear/raid0/multipath/faulty the whole concept of bad blocks doesn't mean anything so there is no point adding the checks. Signed-off-by: NeilBrown <neilb@suse.de> Reviewed-by: Namhyung Kim <namhyung@gmail.com>
Diffstat (limited to 'drivers/md/raid10.c')
-rw-r--r--drivers/md/raid10.c8
1 files changed, 8 insertions, 0 deletions
diff --git a/drivers/md/raid10.c b/drivers/md/raid10.c
index 5def27c28be7..8aadd2f52dc8 100644
--- a/drivers/md/raid10.c
+++ b/drivers/md/raid10.c
@@ -1101,6 +1101,9 @@ static int raid10_add_disk(mddev_t *mddev, mdk_rdev_t *rdev)
1101 int first = 0; 1101 int first = 0;
1102 int last = conf->raid_disks - 1; 1102 int last = conf->raid_disks - 1;
1103 1103
1104 if (rdev->badblocks.count)
1105 return -EINVAL;
1106
1104 if (mddev->recovery_cp < MaxSector) 1107 if (mddev->recovery_cp < MaxSector)
1105 /* only hot-add to in-sync arrays, as recovery is 1108 /* only hot-add to in-sync arrays, as recovery is
1106 * very different from resync 1109 * very different from resync
@@ -2263,6 +2266,11 @@ static int run(mddev_t *mddev)
2263 (conf->raid_disks / conf->near_copies)); 2266 (conf->raid_disks / conf->near_copies));
2264 2267
2265 list_for_each_entry(rdev, &mddev->disks, same_set) { 2268 list_for_each_entry(rdev, &mddev->disks, same_set) {
2269
2270 if (rdev->badblocks.count) {
2271 printk(KERN_ERR "md/raid10: cannot handle bad blocks yet\n");
2272 goto out_free_conf;
2273 }
2266 disk_idx = rdev->raid_disk; 2274 disk_idx = rdev->raid_disk;
2267 if (disk_idx >= conf->raid_disks 2275 if (disk_idx >= conf->raid_disks
2268 || disk_idx < 0) 2276 || disk_idx < 0)