diff options
author | majianpeng <majianpeng@gmail.com> | 2012-05-22 13:55:03 +1000 |
---|---|---|
committer | NeilBrown <neilb@suse.de> | 2012-05-22 13:55:03 +1000 |
commit | da8840a747c0dbf49506ec906757a6b87b9741e9 (patch) | |
tree | 127835ac03aaf4f3ecd188c665a9970047174c26 /drivers/md/raid1.c | |
parent | 4fa2f327681808f653711e14203a42cf4644bda0 (diff) | |
download | op-kernel-dev-da8840a747c0dbf49506ec906757a6b87b9741e9.zip op-kernel-dev-da8840a747c0dbf49506ec906757a6b87b9741e9.tar.gz |
md/raid1: allow fix_read_error to read from recovering device.
When attempting to fix a read error, it is acceptable to read from a
device that is recovering, provided the recovery has got past the
place we are reading from. This makes the test for "can we read from
here" the same as the test in read_balance.
Signed-off-by: majianpeng <majianpeng@gmail.com>
Signed-off-by: NeilBrown <neilb@suse.de>
Diffstat (limited to 'drivers/md/raid1.c')
-rw-r--r-- | drivers/md/raid1.c | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/drivers/md/raid1.c b/drivers/md/raid1.c index 71a7dc0..22cfc66 100644 --- a/drivers/md/raid1.c +++ b/drivers/md/raid1.c @@ -1859,7 +1859,9 @@ static void fix_read_error(struct r1conf *conf, int read_disk, rdev = conf->mirrors[d].rdev; if (rdev && - test_bit(In_sync, &rdev->flags) && + (test_bit(In_sync, &rdev->flags) || + (!test_bit(Faulty, &rdev->flags) && + rdev->recovery_offset >= sect + s)) && is_badblock(rdev, sect, s, &first_bad, &bad_sectors) == 0 && sync_page_io(rdev, sect, s<<9, |