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:
parent
80814b8e35
commit
d1f04c2e23
@ -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);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user