dm mirror: fix read error on recovery after default leg failure
authorHeinz Mauelshagen <heinzm@redhat.com>
Mon, 10 Oct 2016 15:58:32 +0000 (17:58 +0200)
committerMike Snitzer <snitzer@redhat.com>
Fri, 14 Oct 2016 15:54:10 +0000 (11:54 -0400)
commitdcb2ff56417362c31f6b430c3c531a84581e8721
tree3fcab8dac06f6f5a2ee3c62c3e2577da403547e5
parent5c33677c87cbe44ae04df69c4a29c1750a9ec4e5
dm mirror: fix read error on recovery after default leg failure

If a default leg has failed, any read will cause a new operational
default leg to be selected and the read is resubmitted.  But until now
the read will return failure even though it was successful due to
resubmission.  The reason for this is bio->bi_error was not being
cleared before resubmitting the bio.

Fix by clearing bio->bi_error before resubmission.

Fixes: 4246a0b63bd8 ("block: add a bi_error field to struct bio")
Cc: stable@vger.kernel.org # 4.3+
Signed-off-by: Heinz Mauelshagen <heinzm@redhat.com>
Signed-off-by: Mike Snitzer <snitzer@redhat.com>
drivers/md/dm-raid1.c