|
@@ -7399,23 +7399,21 @@ static int remove_and_add_spares(struct mddev *mddev)
|
|
|
}
|
|
|
}
|
|
|
|
|
|
- if (mddev->degraded) {
|
|
|
- list_for_each_entry(rdev, &mddev->disks, same_set) {
|
|
|
- if (rdev->raid_disk >= 0 &&
|
|
|
- !test_bit(In_sync, &rdev->flags) &&
|
|
|
- !test_bit(Faulty, &rdev->flags))
|
|
|
+ list_for_each_entry(rdev, &mddev->disks, same_set) {
|
|
|
+ if (rdev->raid_disk >= 0 &&
|
|
|
+ !test_bit(In_sync, &rdev->flags) &&
|
|
|
+ !test_bit(Faulty, &rdev->flags))
|
|
|
+ spares++;
|
|
|
+ if (rdev->raid_disk < 0
|
|
|
+ && !test_bit(Faulty, &rdev->flags)) {
|
|
|
+ rdev->recovery_offset = 0;
|
|
|
+ if (mddev->pers->
|
|
|
+ hot_add_disk(mddev, rdev) == 0) {
|
|
|
+ if (sysfs_link_rdev(mddev, rdev))
|
|
|
+ /* failure here is OK */;
|
|
|
spares++;
|
|
|
- if (rdev->raid_disk < 0
|
|
|
- && !test_bit(Faulty, &rdev->flags)) {
|
|
|
- rdev->recovery_offset = 0;
|
|
|
- if (mddev->pers->
|
|
|
- hot_add_disk(mddev, rdev) == 0) {
|
|
|
- if (sysfs_link_rdev(mddev, rdev))
|
|
|
- /* failure here is OK */;
|
|
|
- spares++;
|
|
|
- md_new_event(mddev);
|
|
|
- set_bit(MD_CHANGE_DEVS, &mddev->flags);
|
|
|
- }
|
|
|
+ md_new_event(mddev);
|
|
|
+ set_bit(MD_CHANGE_DEVS, &mddev->flags);
|
|
|
}
|
|
|
}
|
|
|
}
|