block: set BIO_NO_PAGE_REF in bio_iov_bvec_set
authorChristoph Hellwig <hch@lst.de>
Tue, 2 Feb 2021 17:19:26 +0000 (18:19 +0100)
committerJens Axboe <axboe@kernel.dk>
Mon, 8 Feb 2021 15:33:16 +0000 (08:33 -0700)
bio_iov_bvec_set assigns the foreign bvec, so setting the NO_PAGE_REF
directly there seems like the best fit.

Signed-off-by: Christoph Hellwig <hch@lst.de>
Signed-off-by: Jens Axboe <axboe@kernel.dk>
block/bio.c

index dd3b2a0..f753201 100644 (file)
@@ -941,6 +941,7 @@ static int bio_iov_bvec_set(struct bio *bio, struct iov_iter *iter)
        bio->bi_io_vec = (struct bio_vec *)iter->bvec;
        bio->bi_iter.bi_bvec_done = iter->iov_offset;
        bio->bi_iter.bi_size = iter->count;
+       bio_set_flag(bio, BIO_NO_PAGE_REF);
 
        iov_iter_advance(iter, iter->count);
        return 0;
@@ -1078,9 +1079,7 @@ int bio_iov_iter_get_pages(struct bio *bio, struct iov_iter *iter)
        if (iov_iter_is_bvec(iter)) {
                if (WARN_ON_ONCE(bio_op(bio) == REQ_OP_ZONE_APPEND))
                        return -EINVAL;
-               bio_iov_bvec_set(bio, iter);
-               bio_set_flag(bio, BIO_NO_PAGE_REF);
-               return 0;
+               return bio_iov_bvec_set(bio, iter);
        }
 
        do {