block: factor out a bvec_set_page helper
authorChristoph Hellwig <hch@lst.de>
Fri, 3 Feb 2023 15:06:12 +0000 (16:06 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Sat, 23 Sep 2023 09:11:08 +0000 (11:11 +0200)
[ Upstream commit d58cdfae6a22e5079656c487aad669597a0635c8 ]

Add a helper to initialize a bvec based of a page pointer.  This will help
removing various open code bvec initializations.

Signed-off-by: Christoph Hellwig <hch@lst.de>
Reviewed-by: Chaitanya Kulkarni <kch@nvidia.com>
Reviewed-by: Johannes Thumshirn <johannes.thumshirn@wdc.com>
Link: https://lore.kernel.org/r/20230203150634.3199647-2-hch@lst.de
Signed-off-by: Jens Axboe <axboe@kernel.dk>
Stable-dep-of: 1f0bbf28940c ("nvmet-tcp: pass iov_len instead of sg->length to bvec_set_page()")
Signed-off-by: Sasha Levin <sashal@kernel.org>
block/bio-integrity.c
block/bio.c
include/linux/bvec.h

index 91ffee6..4533eb4 100644 (file)
@@ -124,23 +124,18 @@ int bio_integrity_add_page(struct bio *bio, struct page *page,
                           unsigned int len, unsigned int offset)
 {
        struct bio_integrity_payload *bip = bio_integrity(bio);
-       struct bio_vec *iv;
 
        if (bip->bip_vcnt >= bip->bip_max_vcnt) {
                printk(KERN_ERR "%s: bip_vec full\n", __func__);
                return 0;
        }
 
-       iv = bip->bip_vec + bip->bip_vcnt;
-
        if (bip->bip_vcnt &&
            bvec_gap_to_prev(&bdev_get_queue(bio->bi_bdev)->limits,
                             &bip->bip_vec[bip->bip_vcnt - 1], offset))
                return 0;
 
-       iv->bv_page = page;
-       iv->bv_len = len;
-       iv->bv_offset = offset;
+       bvec_set_page(&bip->bip_vec[bip->bip_vcnt], page, len, offset);
        bip->bip_vcnt++;
 
        return len;
index d5cd825..9ec72a7 100644 (file)
@@ -976,10 +976,7 @@ int bio_add_hw_page(struct request_queue *q, struct bio *bio,
        if (bio->bi_vcnt >= queue_max_segments(q))
                return 0;
 
-       bvec = &bio->bi_io_vec[bio->bi_vcnt];
-       bvec->bv_page = page;
-       bvec->bv_len = len;
-       bvec->bv_offset = offset;
+       bvec_set_page(&bio->bi_io_vec[bio->bi_vcnt], page, len, offset);
        bio->bi_vcnt++;
        bio->bi_iter.bi_size += len;
        return len;
@@ -1055,15 +1052,10 @@ EXPORT_SYMBOL_GPL(bio_add_zone_append_page);
 void __bio_add_page(struct bio *bio, struct page *page,
                unsigned int len, unsigned int off)
 {
-       struct bio_vec *bv = &bio->bi_io_vec[bio->bi_vcnt];
-
        WARN_ON_ONCE(bio_flagged(bio, BIO_CLONED));
        WARN_ON_ONCE(bio_full(bio, len));
 
-       bv->bv_page = page;
-       bv->bv_offset = off;
-       bv->bv_len = len;
-
+       bvec_set_page(&bio->bi_io_vec[bio->bi_vcnt], page, len, off);
        bio->bi_iter.bi_size += len;
        bio->bi_vcnt++;
 }
index 35c25df..9e3dac5 100644 (file)
@@ -35,6 +35,21 @@ struct bio_vec {
        unsigned int    bv_offset;
 };
 
+/**
+ * bvec_set_page - initialize a bvec based off a struct page
+ * @bv:                bvec to initialize
+ * @page:      page the bvec should point to
+ * @len:       length of the bvec
+ * @offset:    offset into the page
+ */
+static inline void bvec_set_page(struct bio_vec *bv, struct page *page,
+               unsigned int len, unsigned int offset)
+{
+       bv->bv_page = page;
+       bv->bv_len = len;
+       bv->bv_offset = offset;
+}
+
 struct bvec_iter {
        sector_t                bi_sector;      /* device address in 512 byte
                                                   sectors */