Commit 22dbb098 authored by Jens Axboe's avatar Jens Axboe
Browse files

io_uring/cancel: de-unionize file and user_data in struct io_cancel_data



By having them share the same space in struct io_cancel_data, it ends up
disallowing IORING_ASYNC_CANCEL_FD|IORING_ASYNC_CANCEL_USERDATA from
working. Eg you cannot match on both a file and user_data for
cancelation purposes. This obviously isn't a common use case as nobody
has reported this, but it does result in -ENOENT potentially being
returned when trying to match on both, rather than actually doing what
the API says it would.

Fixes: 4bf94615 ("io_uring: allow IORING_OP_ASYNC_CANCEL with 'fd' key")
Signed-off-by: default avatarJens Axboe <axboe@kernel.dk>
parent 2e02f9ef
Loading
Loading
Loading
Loading
+2 −4
Original line number Diff line number Diff line
@@ -6,10 +6,8 @@

struct io_cancel_data {
	struct io_ring_ctx *ctx;
	union {
	u64 data;
	struct file *file;
	};
	u8 opcode;
	u32 flags;
	int seq;