Skip to content

Commit fe8f4ca

Browse files
Anuj Guptaaxboe
authored andcommitted
block: modify bio_integrity_map_user to accept iov_iter as argument
This patch refactors bio_integrity_map_user to accept iov_iter as argument. This is a prep patch. Signed-off-by: Anuj Gupta <[email protected]> Signed-off-by: Kanchan Joshi <[email protected]> Reviewed-by: Christoph Hellwig <[email protected]> Reviewed-by: Keith Busch <[email protected]> Link: https://lore.kernel.org/r/[email protected] Signed-off-by: Jens Axboe <[email protected]>
1 parent 0311419 commit fe8f4ca

File tree

3 files changed

+16
-11
lines changed

3 files changed

+16
-11
lines changed

block/bio-integrity.c

Lines changed: 5 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -302,16 +302,15 @@ static unsigned int bvec_from_pages(struct bio_vec *bvec, struct page **pages,
302302
return nr_bvecs;
303303
}
304304

305-
int bio_integrity_map_user(struct bio *bio, void __user *ubuf, ssize_t bytes)
305+
int bio_integrity_map_user(struct bio *bio, struct iov_iter *iter)
306306
{
307307
struct request_queue *q = bdev_get_queue(bio->bi_bdev);
308308
unsigned int align = blk_lim_dma_alignment_and_pad(&q->limits);
309309
struct page *stack_pages[UIO_FASTIOV], **pages = stack_pages;
310310
struct bio_vec stack_vec[UIO_FASTIOV], *bvec = stack_vec;
311+
size_t offset, bytes = iter->count;
311312
unsigned int direction, nr_bvecs;
312-
struct iov_iter iter;
313313
int ret, nr_vecs;
314-
size_t offset;
315314
bool copy;
316315

317316
if (bio_integrity(bio))
@@ -324,8 +323,7 @@ int bio_integrity_map_user(struct bio *bio, void __user *ubuf, ssize_t bytes)
324323
else
325324
direction = ITER_SOURCE;
326325

327-
iov_iter_ubuf(&iter, direction, ubuf, bytes);
328-
nr_vecs = iov_iter_npages(&iter, BIO_MAX_VECS + 1);
326+
nr_vecs = iov_iter_npages(iter, BIO_MAX_VECS + 1);
329327
if (nr_vecs > BIO_MAX_VECS)
330328
return -E2BIG;
331329
if (nr_vecs > UIO_FASTIOV) {
@@ -335,8 +333,8 @@ int bio_integrity_map_user(struct bio *bio, void __user *ubuf, ssize_t bytes)
335333
pages = NULL;
336334
}
337335

338-
copy = !iov_iter_is_aligned(&iter, align, align);
339-
ret = iov_iter_extract_pages(&iter, &pages, bytes, nr_vecs, 0, &offset);
336+
copy = !iov_iter_is_aligned(iter, align, align);
337+
ret = iov_iter_extract_pages(iter, &pages, bytes, nr_vecs, 0, &offset);
340338
if (unlikely(ret < 0))
341339
goto free_bvec;
342340

block/blk-integrity.c

Lines changed: 9 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -115,8 +115,16 @@ EXPORT_SYMBOL(blk_rq_map_integrity_sg);
115115
int blk_rq_integrity_map_user(struct request *rq, void __user *ubuf,
116116
ssize_t bytes)
117117
{
118-
int ret = bio_integrity_map_user(rq->bio, ubuf, bytes);
118+
int ret;
119+
struct iov_iter iter;
120+
unsigned int direction;
119121

122+
if (op_is_write(req_op(rq)))
123+
direction = ITER_DEST;
124+
else
125+
direction = ITER_SOURCE;
126+
iov_iter_ubuf(&iter, direction, ubuf, bytes);
127+
ret = bio_integrity_map_user(rq->bio, &iter);
120128
if (ret)
121129
return ret;
122130

include/linux/bio-integrity.h

Lines changed: 2 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -75,7 +75,7 @@ struct bio_integrity_payload *bio_integrity_alloc(struct bio *bio, gfp_t gfp,
7575
unsigned int nr);
7676
int bio_integrity_add_page(struct bio *bio, struct page *page, unsigned int len,
7777
unsigned int offset);
78-
int bio_integrity_map_user(struct bio *bio, void __user *ubuf, ssize_t len);
78+
int bio_integrity_map_user(struct bio *bio, struct iov_iter *iter);
7979
void bio_integrity_unmap_user(struct bio *bio);
8080
bool bio_integrity_prep(struct bio *bio);
8181
void bio_integrity_advance(struct bio *bio, unsigned int bytes_done);
@@ -101,8 +101,7 @@ static inline void bioset_integrity_free(struct bio_set *bs)
101101
{
102102
}
103103

104-
static inline int bio_integrity_map_user(struct bio *bio, void __user *ubuf,
105-
ssize_t len)
104+
static int bio_integrity_map_user(struct bio *bio, struct iov_iter *iter)
106105
{
107106
return -EINVAL;
108107
}

0 commit comments

Comments
 (0)