diff options
author | NeilBrown <neilb@suse.de> | 2011-10-30 21:59:44 -0400 |
---|---|---|
committer | NeilBrown <neilb@suse.de> | 2011-10-30 21:59:44 -0400 |
commit | 7fcc7c8acf0fba44d19a713207af7e58267c1179 (patch) | |
tree | ce4b03fa3dfc07fb19b4d6c3653ba41ec1f926db /drivers/md | |
parent | d890fa2b0586b6177b119643ff66932127d58afa (diff) |
md/raid10: Fix bug when activating a hot-spare.
This is a fairly serious bug in RAID10.
When a RAID10 array is degraded and a hot-spare is activated, the
spare does not take up the empty slot, but rather replaces the first
working device.
This is likely to make the array non-functional. It would normally
be possible to recover the data, but that would need care and is not
guaranteed.
This bug was introduced in commit
2bb77736ae5dca0a189829fbb7379d43364a9dac
which first appeared in 3.1.
Cc: stable@kernel.org
Signed-off-by: NeilBrown <neilb@suse.de>
Diffstat (limited to 'drivers/md')
-rw-r--r-- | drivers/md/raid10.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/md/raid10.c b/drivers/md/raid10.c index 132c18ef8665..c025a8276dc1 100644 --- a/drivers/md/raid10.c +++ b/drivers/md/raid10.c | |||
@@ -1355,7 +1355,7 @@ static int raid10_add_disk(struct mddev *mddev, struct md_rdev *rdev) | |||
1355 | struct mirror_info *p = &conf->mirrors[mirror]; | 1355 | struct mirror_info *p = &conf->mirrors[mirror]; |
1356 | if (p->recovery_disabled == mddev->recovery_disabled) | 1356 | if (p->recovery_disabled == mddev->recovery_disabled) |
1357 | continue; | 1357 | continue; |
1358 | if (!p->rdev) | 1358 | if (p->rdev) |
1359 | continue; | 1359 | continue; |
1360 | 1360 | ||
1361 | disk_stack_limits(mddev->gendisk, rdev->bdev, | 1361 | disk_stack_limits(mddev->gendisk, rdev->bdev, |