Commit 3d8f874b authored by Ming Lei's avatar Ming Lei Committed by Jens Axboe

io_uring: fail NOP if non-zero op flags is passed in

The NOP op flags should have been checked from beginning like any other
opcode, otherwise NOP may not be extended with the op flags.

Given both liburing and Rust io-uring crate always zeros SQE op flags, just
ignore users which play raw NOP uring interface without zeroing SQE, because
NOP is just for test purpose. Then we can save one NOP2 opcode.
Suggested-by: default avatarJens Axboe <axboe@kernel.dk>
Fixes: 2b188cc1 ("Add io_uring IO interface")
Cc: stable@vger.kernel.org
Signed-off-by: default avatarMing Lei <ming.lei@redhat.com>
Link: https://lore.kernel.org/r/20240510035031.78874-2-ming.lei@redhat.comSigned-off-by: default avatarJens Axboe <axboe@kernel.dk>
parent d3da8e98
...@@ -12,6 +12,8 @@ ...@@ -12,6 +12,8 @@
int io_nop_prep(struct io_kiocb *req, const struct io_uring_sqe *sqe) int io_nop_prep(struct io_kiocb *req, const struct io_uring_sqe *sqe)
{ {
if (READ_ONCE(sqe->rw_flags))
return -EINVAL;
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