forked from luck/tmp_suning_uos_patched
md/raid10: attempt to fix read errors during resync/check
We already attempt to fix read errors found during normal IO and a 'repair' process. It is best to try to repair them at any time they are found, so move a test so that during sync and check a read error will be corrected by over-writing with good data. If both (all) devices have known bad blocks in the sync section we won't try to fix even though the bad blocks might not overlap. That should be considered later. Also if we hit a read error during recovery we don't try to fix it. It would only be possible to fix if there were at least three copies of data, which is not very common with RAID10. But it should still be considered later. Signed-off-by: NeilBrown <neilb@suse.de>
This commit is contained in:
parent
bd870a16c5
commit
f84ee364dd
@ -1541,11 +1541,12 @@ static void sync_request_write(mddev_t *mddev, r10bio_t *r10_bio)
|
|||||||
if (j == vcnt)
|
if (j == vcnt)
|
||||||
continue;
|
continue;
|
||||||
mddev->resync_mismatches += r10_bio->sectors;
|
mddev->resync_mismatches += r10_bio->sectors;
|
||||||
|
if (test_bit(MD_RECOVERY_CHECK, &mddev->recovery))
|
||||||
|
/* Don't fix anything. */
|
||||||
|
continue;
|
||||||
}
|
}
|
||||||
if (test_bit(MD_RECOVERY_CHECK, &mddev->recovery))
|
/* Ok, we need to write this bio, either to correct an
|
||||||
/* Don't fix anything. */
|
* inconsistency or to correct an unreadable block.
|
||||||
continue;
|
|
||||||
/* Ok, we need to write this bio
|
|
||||||
* First we need to fixup bv_offset, bv_len and
|
* First we need to fixup bv_offset, bv_len and
|
||||||
* bi_vecs, as the read request might have corrupted these
|
* bi_vecs, as the read request might have corrupted these
|
||||||
*/
|
*/
|
||||||
|
Loading…
Reference in New Issue
Block a user