[dm-devel] dm raid1: "mirror" target doesn't use all available legs on multiple failures
Mike Snitzer
snitzer at redhat.com
Mon Oct 10 20:41:27 UTC 2016
On Mon, Oct 10 2016 at 12:48pm -0400,
Heinz Mauelshagen <heinzm at redhat.com> wrote:
> In case legs of a "mirror" target fail, any read will cause a new,
> operational default leg to be selected and the read be resubmitted
> to it. If that new default leg fails the read too, no other still
> accessible legs are used to resubmit the read again thus failing
> the io.
>
> Fix by allowing the read to get resubmitted until there's no
> operational legs any more.
>
> Resolves: rhbz1383444
>
> Signed-off-by: Heinz Mauelshagen <heinzm at redhat.com>
Nothing seems to be checking bio_record->details.bi_bdev anymore.
(The one you've removed really seems like a complete hack to begin with)
Shouldn't this patch go further by removing the other 2 places that set
bio_record->details.bi_bdev = NULL; ?
> ---
> drivers/md/dm-raid1.c | 11 -----------
> 1 file changed, 11 deletions(-)
>
> diff --git a/drivers/md/dm-raid1.c b/drivers/md/dm-raid1.c
> index 7a6254d..dd31019 100644
> --- a/drivers/md/dm-raid1.c
> +++ b/drivers/md/dm-raid1.c
> @@ -1266,16 +1266,6 @@ static int mirror_end_io(struct dm_target *ti, struct bio *bio, int error)
> goto out;
>
> if (unlikely(error)) {
> - if (!bio_record->details.bi_bdev) {
> - /*
> - * There wasn't enough memory to record necessary
> - * information for a retry or there was no other
> - * mirror in-sync.
> - */
> - DMERR_LIMIT("Mirror read failed.");
> - return -EIO;
> - }
> -
> m = bio_record->m;
>
> DMERR("Mirror read failed from %s. Trying alternative device.",
> @@ -1291,7 +1281,6 @@ static int mirror_end_io(struct dm_target *ti, struct bio *bio, int error)
> bd = &bio_record->details;
>
> dm_bio_restore(bd, bio);
> - bio_record->details.bi_bdev = NULL;
> bio->bi_error = 0;
>
> queue_bio(ms, bio, rw);
> --
> 2.7.4
>
More information about the dm-devel
mailing list