bio-integrity: cleanup adding integrity pages to bip's bvec.

bio_integrity_add_page() returns the add length if successful, else 0,
just as bio_add_page.  Simply check return value checking in
bio_integrity_prep to not deal with a > 0 but < len case that can't
happen.

Cc: Christoph Hellwig <hch@lst.de>
Cc: Martin K. Petersen <martin.petersen@oracle.com>

Reviewed-by: Christoph Hellwig <hch@lst.de>
Signed-off-by: Jinyoung Choi <j-young.choi@samsung.com>
Tested-by: "Martin K. Petersen" <martin.petersen@oracle.com>
Reviewed-by: "Martin K. Petersen" <martin.petersen@oracle.com>
Link: https://lore.kernel.org/r/20230803025058epcms2p5a4d0db5da2ad967668932d463661c633@epcms2p5
Signed-off-by: Jens Axboe <axboe@kernel.dk>
This commit is contained in:
Jinyoung Choi 2023-08-03 11:50:58 +09:00 committed by Jens Axboe
parent 80814b8e35
commit d1f04c2e23

View File

@ -252,27 +252,18 @@ bool bio_integrity_prep(struct bio *bio)
/* Map it */ /* Map it */
offset = offset_in_page(buf); offset = offset_in_page(buf);
for (i = 0 ; i < nr_pages ; i++) { for (i = 0; i < nr_pages && len > 0; i++) {
int ret;
bytes = PAGE_SIZE - offset; bytes = PAGE_SIZE - offset;
if (len <= 0)
break;
if (bytes > len) if (bytes > len)
bytes = len; bytes = len;
ret = bio_integrity_add_page(bio, virt_to_page(buf), if (bio_integrity_add_page(bio, virt_to_page(buf),
bytes, offset); bytes, offset) < bytes) {
if (ret == 0) {
printk(KERN_ERR "could not attach integrity payload\n"); printk(KERN_ERR "could not attach integrity payload\n");
goto err_end_io; goto err_end_io;
} }
if (ret < bytes)
break;
buf += bytes; buf += bytes;
len -= bytes; len -= bytes;
offset = 0; offset = 0;
@ -291,7 +282,6 @@ err_end_io:
bio->bi_status = BLK_STS_RESOURCE; bio->bi_status = BLK_STS_RESOURCE;
bio_endio(bio); bio_endio(bio);
return false; return false;
} }
EXPORT_SYMBOL(bio_integrity_prep); EXPORT_SYMBOL(bio_integrity_prep);