|
@@ -465,7 +465,7 @@ static int bio_integrity_verify(struct bio *bio)
|
|
|
|
|
|
if (ret) {
|
|
|
kunmap_atomic(kaddr, KM_USER0);
|
|
|
- break;
|
|
|
+ return ret;
|
|
|
}
|
|
|
|
|
|
sectors = bv->bv_len / bi->sector_size;
|
|
@@ -493,18 +493,13 @@ static void bio_integrity_verify_fn(struct work_struct *work)
|
|
|
struct bio_integrity_payload *bip =
|
|
|
container_of(work, struct bio_integrity_payload, bip_work);
|
|
|
struct bio *bio = bip->bip_bio;
|
|
|
- int error = bip->bip_error;
|
|
|
+ int error;
|
|
|
|
|
|
- if (bio_integrity_verify(bio)) {
|
|
|
- clear_bit(BIO_UPTODATE, &bio->bi_flags);
|
|
|
- error = -EIO;
|
|
|
- }
|
|
|
+ error = bio_integrity_verify(bio);
|
|
|
|
|
|
/* Restore original bio completion handler */
|
|
|
bio->bi_end_io = bip->bip_end_io;
|
|
|
-
|
|
|
- if (bio->bi_end_io)
|
|
|
- bio->bi_end_io(bio, error);
|
|
|
+ bio_endio(bio, error);
|
|
|
}
|
|
|
|
|
|
/**
|
|
@@ -525,7 +520,17 @@ void bio_integrity_endio(struct bio *bio, int error)
|
|
|
|
|
|
BUG_ON(bip->bip_bio != bio);
|
|
|
|
|
|
- bip->bip_error = error;
|
|
|
+ /* In case of an I/O error there is no point in verifying the
|
|
|
+ * integrity metadata. Restore original bio end_io handler
|
|
|
+ * and run it.
|
|
|
+ */
|
|
|
+ if (error) {
|
|
|
+ bio->bi_end_io = bip->bip_end_io;
|
|
|
+ bio_endio(bio, error);
|
|
|
+
|
|
|
+ return;
|
|
|
+ }
|
|
|
+
|
|
|
INIT_WORK(&bip->bip_work, bio_integrity_verify_fn);
|
|
|
queue_work(kintegrityd_wq, &bip->bip_work);
|
|
|
}
|