aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/md/raid1.c
diff options
context:
space:
mode:
authorNeilBrown <neilb@suse.de>2011-07-26 21:00:36 -0400
committerNeilBrown <neilb@suse.de>2011-07-26 21:00:36 -0400
commit5389042ffa36976caa45a79af16081d759001fa7 (patch)
treeeb303de141a50f41ccac438e734b65dbfe25825e /drivers/md/raid1.c
parenta478a069b6adf186373a6648c54fc5f1d3c2f8eb (diff)
md: change managed of recovery_disabled.
If we hit a read error while recovering a mirror, we want to abort the recovery without necessarily failing the disk - as having a disk this a read error is better than not having an array at all. Currently this is managed with a per-array flag "recovery_disabled" and is only implemented for RAID1. For RAID10 we will need finer grained control as we might want to disable recovery for individual devices separately. So push more of the decision making into the personality. 'recovery_disabled' is now a 'cookie' which is copied when the personality want to disable recovery and is changed when a device is added to the array as this is used as a trigger to 'try recovery again'. This will allow RAID10 to get the control that it needs. Signed-off-by: NeilBrown <neilb@suse.de>
Diffstat (limited to 'drivers/md/raid1.c')
-rw-r--r--drivers/md/raid1.c7
1 files changed, 5 insertions, 2 deletions
diff --git a/drivers/md/raid1.c b/drivers/md/raid1.c
index 1d79a041db09..44069b38d6dd 100644
--- a/drivers/md/raid1.c
+++ b/drivers/md/raid1.c
@@ -956,7 +956,7 @@ static void error(mddev_t *mddev, mdk_rdev_t *rdev)
956 * However don't try a recovery from this drive as 956 * However don't try a recovery from this drive as
957 * it is very likely to fail. 957 * it is very likely to fail.
958 */ 958 */
959 mddev->recovery_disabled = 1; 959 conf->recovery_disabled = mddev->recovery_disabled;
960 return; 960 return;
961 } 961 }
962 if (test_and_clear_bit(In_sync, &rdev->flags)) { 962 if (test_and_clear_bit(In_sync, &rdev->flags)) {
@@ -1052,6 +1052,9 @@ static int raid1_add_disk(mddev_t *mddev, mdk_rdev_t *rdev)
1052 int first = 0; 1052 int first = 0;
1053 int last = mddev->raid_disks - 1; 1053 int last = mddev->raid_disks - 1;
1054 1054
1055 if (mddev->recovery_disabled == conf->recovery_disabled)
1056 return -EBUSY;
1057
1055 if (rdev->raid_disk >= 0) 1058 if (rdev->raid_disk >= 0)
1056 first = last = rdev->raid_disk; 1059 first = last = rdev->raid_disk;
1057 1060
@@ -1107,7 +1110,7 @@ static int raid1_remove_disk(mddev_t *mddev, int number)
1107 * is not possible. 1110 * is not possible.
1108 */ 1111 */
1109 if (!test_bit(Faulty, &rdev->flags) && 1112 if (!test_bit(Faulty, &rdev->flags) &&
1110 !mddev->recovery_disabled && 1113 mddev->recovery_disabled != conf->recovery_disabled &&
1111 mddev->degraded < conf->raid_disks) { 1114 mddev->degraded < conf->raid_disks) {
1112 err = -EBUSY; 1115 err = -EBUSY;
1113 goto abort; 1116 goto abort;