dm: fix request-based dm error reporting
authorJunichi Nomura <j-nomura@ce.jp.nec.com>
Tue, 6 Oct 2015 04:19:54 +0000 (04:19 +0000)
committerMike Snitzer <snitzer@redhat.com>
Tue, 6 Oct 2015 14:08:16 +0000 (10:08 -0400)
commit50887bd139b83ce4489ed865a04bf1be5559c4ad
treef0d20f339872dfcb613b4418f752e3eae5578e12
parent042745ee53a0a7c1f5aff191a4a24213c6dcfb52
dm: fix request-based dm error reporting

end_clone_bio() is a endio callback for clone bio and should check
and save the clone's bi_error for error reporting.  However,
4246a0b63bd8 ("block: add a bi_error field to struct bio") changed
the function to check the original bio's bi_error, which is 0.

Without this fix, clone's error is ignored and reported to the
original request as success.  Thus data corruption will be observed.

Fixes: 4246a0b63bd8 ("block: add a bi_error field to struct bio")
Signed-off-by: Jun'ichi Nomura <j-nomura@ce.jp.nec.com>
Cc: Christoph Hellwig <hch@lst.de>
Signed-off-by: Mike Snitzer <snitzer@redhat.com>
drivers/md/dm.c