diff options
| author | Dylan Yudaken <dylany@fb.com> | 2022-09-07 09:51:52 -0700 | 
|---|---|---|
| committer | Jens Axboe <axboe@kernel.dk> | 2022-09-21 10:30:43 -0600 | 
| commit | 4ab9d465071beb95e30e2712d4c65b6ab781865b (patch) | |
| tree | d6297abd331d430fedd6486859449185b8c74b92 /io_uring/kbuf.h | |
| parent | de97fcb30316410a2c46be102f074a454ecc6cf1 (diff) | |
io_uring: allow buffer recycling in READV
In commit 934447a603b2 ("io_uring: do not recycle buffer in READV") a
temporary fix was put in io_kbuf_recycle to simply never recycle READV
buffers.
Instead of that, rather treat READV with REQ_F_BUFFER_SELECTED the same as
a READ with REQ_F_BUFFER_SELECTED. Since READV requires iov_len of 1 they
are essentially the same.
In order to do this inside io_prep_rw() add some validation to check that
it is in fact only length 1, and also extract the length of the buffer at
prep time.
This allows removal of the io_iov_buffer_select codepaths as they are only
used from the READV op.
Signed-off-by: Dylan Yudaken <dylany@fb.com>
Link: https://lore.kernel.org/r/20220907165152.994979-1-dylany@fb.com
Signed-off-by: Jens Axboe <axboe@kernel.dk>
Diffstat (limited to 'io_uring/kbuf.h')
| -rw-r--r-- | io_uring/kbuf.h | 12 | 
1 files changed, 0 insertions, 12 deletions
| diff --git a/io_uring/kbuf.h b/io_uring/kbuf.h index 746fbf31a703..c23e15d7d3ca 100644 --- a/io_uring/kbuf.h +++ b/io_uring/kbuf.h @@ -86,18 +86,6 @@ static inline bool io_do_buffer_select(struct io_kiocb *req)  static inline void io_kbuf_recycle(struct io_kiocb *req, unsigned issue_flags)  { -	/* -	 * READV uses fields in `struct io_rw` (len/addr) to stash the selected -	 * buffer data. However if that buffer is recycled the original request -	 * data stored in addr is lost. Therefore forbid recycling for now. -	 */ -	if (req->opcode == IORING_OP_READV) { -		if ((req->flags & REQ_F_BUFFER_RING) && req->buf_list) { -			req->buf_list->head++; -			req->buf_list = NULL; -		} -		return; -	}  	if (req->flags & REQ_F_BUFFER_SELECTED)  		io_kbuf_recycle_legacy(req, issue_flags);  	if (req->flags & REQ_F_BUFFER_RING) | 
