Commit ae42f0b3 authored by Christoph Hellwig's avatar Christoph Hellwig Committed by Jens Axboe

block: don't pass a bio to bio_try_merge_hw_seg

There is no good reason to pass the bio to bio_try_merge_hw_seg.  Just
pass the current bvec and rename the function to bvec_try_merge_hw_page.
This will allow reusing this function for supporting multi-page integrity
payload bvecs.
Signed-off-by: default avatarChristoph Hellwig <hch@lst.de>
Reviewed-by: default avatarJinyoung Choi <j-young.choi@samsung.com>
Link: https://lore.kernel.org/r/20230724165433.117645-9-hch@lst.deSigned-off-by: default avatarJens Axboe <axboe@kernel.dk>
parent 858c708d
...@@ -934,11 +934,10 @@ static bool bvec_try_merge_page(struct bio_vec *bv, struct page *page, ...@@ -934,11 +934,10 @@ static bool bvec_try_merge_page(struct bio_vec *bv, struct page *page,
* size limit. This is not for normal read/write bios, but for passthrough * size limit. This is not for normal read/write bios, but for passthrough
* or Zone Append operations that we can't split. * or Zone Append operations that we can't split.
*/ */
static bool bio_try_merge_hw_seg(struct request_queue *q, struct bio *bio, static bool bvec_try_merge_hw_page(struct request_queue *q, struct bio_vec *bv,
struct page *page, unsigned len, struct page *page, unsigned len, unsigned offset,
unsigned offset, bool *same_page) bool *same_page)
{ {
struct bio_vec *bv = &bio->bi_io_vec[bio->bi_vcnt - 1];
unsigned long mask = queue_segment_boundary(q); unsigned long mask = queue_segment_boundary(q);
phys_addr_t addr1 = page_to_phys(bv->bv_page) + bv->bv_offset; phys_addr_t addr1 = page_to_phys(bv->bv_page) + bv->bv_offset;
phys_addr_t addr2 = page_to_phys(page) + offset + len - 1; phys_addr_t addr2 = page_to_phys(page) + offset + len - 1;
...@@ -967,8 +966,6 @@ int bio_add_hw_page(struct request_queue *q, struct bio *bio, ...@@ -967,8 +966,6 @@ int bio_add_hw_page(struct request_queue *q, struct bio *bio,
struct page *page, unsigned int len, unsigned int offset, struct page *page, unsigned int len, unsigned int offset,
unsigned int max_sectors, bool *same_page) unsigned int max_sectors, bool *same_page)
{ {
struct bio_vec *bvec;
if (WARN_ON_ONCE(bio_flagged(bio, BIO_CLONED))) if (WARN_ON_ONCE(bio_flagged(bio, BIO_CLONED)))
return 0; return 0;
...@@ -976,7 +973,9 @@ int bio_add_hw_page(struct request_queue *q, struct bio *bio, ...@@ -976,7 +973,9 @@ int bio_add_hw_page(struct request_queue *q, struct bio *bio,
return 0; return 0;
if (bio->bi_vcnt > 0) { if (bio->bi_vcnt > 0) {
if (bio_try_merge_hw_seg(q, bio, page, len, offset, struct bio_vec *bv = &bio->bi_io_vec[bio->bi_vcnt - 1];
if (bvec_try_merge_hw_page(q, bv, page, len, offset,
same_page)) { same_page)) {
bio->bi_iter.bi_size += len; bio->bi_iter.bi_size += len;
return len; return len;
...@@ -990,8 +989,7 @@ int bio_add_hw_page(struct request_queue *q, struct bio *bio, ...@@ -990,8 +989,7 @@ int bio_add_hw_page(struct request_queue *q, struct bio *bio,
* If the queue doesn't support SG gaps and adding this segment * If the queue doesn't support SG gaps and adding this segment
* would create a gap, disallow it. * would create a gap, disallow it.
*/ */
bvec = &bio->bi_io_vec[bio->bi_vcnt - 1]; if (bvec_gap_to_prev(&q->limits, bv, offset))
if (bvec_gap_to_prev(&q->limits, bvec, offset))
return 0; return 0;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment