diff options
author | Jens Axboe <axboe@kernel.dk> | 2019-09-06 10:26:21 -0600 |
---|---|---|
committer | Jens Axboe <axboe@kernel.dk> | 2019-09-06 10:26:21 -0600 |
commit | ac90f249e15cd2a850daa9e36e15f81ce1ff6550 (patch) | |
tree | ae3942ae20234c0fdc5265d19a53fb865486a552 | |
parent | 75b28affdd6aed1c68073ef53907c7bd822aff84 (diff) | |
download | lwn-ac90f249e15cd2a850daa9e36e15f81ce1ff6550.tar.gz lwn-ac90f249e15cd2a850daa9e36e15f81ce1ff6550.zip |
io_uring: expose single mmap capability
After commit 75b28affdd6a we can get by with just a single mmap to
map both the sq and cq ring. However, userspace doesn't know that.
Add a features variable to io_uring_params, and notify userspace
that the kernel has this ability. This can then be used in liburing
(or in applications directly) to avoid the second mmap.
Signed-off-by: Jens Axboe <axboe@kernel.dk>
-rw-r--r-- | fs/io_uring.c | 2 | ||||
-rw-r--r-- | include/uapi/linux/io_uring.h | 8 |
2 files changed, 9 insertions, 1 deletions
diff --git a/fs/io_uring.c b/fs/io_uring.c index 17dfe57c57f8..be24596e90d7 100644 --- a/fs/io_uring.c +++ b/fs/io_uring.c @@ -3391,6 +3391,8 @@ static int io_uring_create(unsigned entries, struct io_uring_params *p) p->cq_off.ring_entries = offsetof(struct io_rings, cq_ring_entries); p->cq_off.overflow = offsetof(struct io_rings, cq_overflow); p->cq_off.cqes = offsetof(struct io_rings, cqes); + + p->features = IORING_FEAT_SINGLE_MMAP; return ret; err: io_ring_ctx_wait_and_kill(ctx); diff --git a/include/uapi/linux/io_uring.h b/include/uapi/linux/io_uring.h index 1e1652f25cc1..96ee9d94b73e 100644 --- a/include/uapi/linux/io_uring.h +++ b/include/uapi/linux/io_uring.h @@ -128,12 +128,18 @@ struct io_uring_params { __u32 flags; __u32 sq_thread_cpu; __u32 sq_thread_idle; - __u32 resv[5]; + __u32 features; + __u32 resv[4]; struct io_sqring_offsets sq_off; struct io_cqring_offsets cq_off; }; /* + * io_uring_params->features flags + */ +#define IORING_FEAT_SINGLE_MMAP (1U << 0) + +/* * io_uring_register(2) opcodes and arguments */ #define IORING_REGISTER_BUFFERS 0 |