aboutsummaryrefslogtreecommitdiffstats
path: root/include/linux/syscalls.h
diff options
context:
space:
mode:
authorJens Axboe <axboe@kernel.dk>2019-01-09 11:16:05 -0500
committerJens Axboe <axboe@kernel.dk>2019-02-28 10:24:23 -0500
commitedafccee56ff31678a091ddb7219aba9b28bc3cb (patch)
tree7cbbdbd1fe256674ac278111bd556b6f25f23264 /include/linux/syscalls.h
parent6d0c48aede85e38316d0251564cab39cbc2422f6 (diff)
io_uring: add support for pre-mapped user IO buffers
If we have fixed user buffers, we can map them into the kernel when we setup the io_uring. That avoids the need to do get_user_pages() for each and every IO. To utilize this feature, the application must call io_uring_register() after having setup an io_uring instance, passing in IORING_REGISTER_BUFFERS as the opcode. The argument must be a pointer to an iovec array, and the nr_args should contain how many iovecs the application wishes to map. If successful, these buffers are now mapped into the kernel, eligible for IO. To use these fixed buffers, the application must use the IORING_OP_READ_FIXED and IORING_OP_WRITE_FIXED opcodes, and then set sqe->index to the desired buffer index. sqe->addr..sqe->addr+seq->len must point to somewhere inside the indexed buffer. The application may register buffers throughout the lifetime of the io_uring instance. It can call io_uring_register() with IORING_UNREGISTER_BUFFERS as the opcode to unregister the current set of buffers, and then register a new set. The application need not unregister buffers explicitly before shutting down the io_uring instance. It's perfectly valid to setup a larger buffer, and then sometimes only use parts of it for an IO. As long as the range is within the originally mapped region, it will work just fine. For now, buffers must not be file backed. If file backed buffers are passed in, the registration will fail with -1/EOPNOTSUPP. This restriction may be relaxed in the future. RLIMIT_MEMLOCK is used to check how much memory we can pin. A somewhat arbitrary 1G per buffer size is also imposed. Reviewed-by: Hannes Reinecke <hare@suse.com> Signed-off-by: Jens Axboe <axboe@kernel.dk>
Diffstat (limited to 'include/linux/syscalls.h')
-rw-r--r--include/linux/syscalls.h2
1 files changed, 2 insertions, 0 deletions
diff --git a/include/linux/syscalls.h b/include/linux/syscalls.h
index 3072dbaa7869..3681c05ac538 100644
--- a/include/linux/syscalls.h
+++ b/include/linux/syscalls.h
@@ -315,6 +315,8 @@ asmlinkage long sys_io_uring_setup(u32 entries,
315asmlinkage long sys_io_uring_enter(unsigned int fd, u32 to_submit, 315asmlinkage long sys_io_uring_enter(unsigned int fd, u32 to_submit,
316 u32 min_complete, u32 flags, 316 u32 min_complete, u32 flags,
317 const sigset_t __user *sig, size_t sigsz); 317 const sigset_t __user *sig, size_t sigsz);
318asmlinkage long sys_io_uring_register(unsigned int fd, unsigned int op,
319 void __user *arg, unsigned int nr_args);
318 320
319/* fs/xattr.c */ 321/* fs/xattr.c */
320asmlinkage long sys_setxattr(const char __user *path, const char __user *name, 322asmlinkage long sys_setxattr(const char __user *path, const char __user *name,