提交 b52ecf8c 编写于 作者: P Pavel Begunkov 提交者: Jens Axboe

io_uring: move ctx->flags from SQ cacheline

ctx->flags are heavily used by both, completion and submission sides, so
move it out from the ctx fields related to submissions. Instead, place
it together with ctx->refs, because it's already cacheline-aligned and
so pads lots of space, and both almost never change. Also, in most
occasions they are accessed together as refs are taken at submission
time and put back during completion.

Do same with ctx->rings, where the pointer itself is never modified
apart from ring init/free.

Note: in percpu mode, struct percpu_ref doesn't modify the struct itself
but takes indirection with ref->percpu_count_ptr.
Signed-off-by: NPavel Begunkov <asml.silence@gmail.com>
Link: https://lore.kernel.org/r/4c48c173e63d35591383ba2b87e8b8e8dfdbd23d.1623709150.git.asml.silence@gmail.comSigned-off-by: NJens Axboe <axboe@kernel.dk>
上级 c7af47cf
...@@ -341,17 +341,19 @@ struct io_submit_state { ...@@ -341,17 +341,19 @@ struct io_submit_state {
}; };
struct io_ring_ctx { struct io_ring_ctx {
/* const or read-mostly hot data */
struct { struct {
struct percpu_ref refs; struct percpu_ref refs;
} ____cacheline_aligned_in_smp;
struct { struct io_rings *rings;
unsigned int flags; unsigned int flags;
unsigned int compat: 1; unsigned int compat: 1;
unsigned int drain_next: 1; unsigned int drain_next: 1;
unsigned int eventfd_async: 1; unsigned int eventfd_async: 1;
unsigned int restricted: 1; unsigned int restricted: 1;
} ____cacheline_aligned_in_smp;
struct {
/* /*
* Ring buffer of indices into array of io_uring_sqe, which is * Ring buffer of indices into array of io_uring_sqe, which is
* mmapped by the application using the IORING_OFF_SQES offset. * mmapped by the application using the IORING_OFF_SQES offset.
...@@ -386,8 +388,6 @@ struct io_ring_ctx { ...@@ -386,8 +388,6 @@ struct io_ring_ctx {
struct list_head locked_free_list; struct list_head locked_free_list;
unsigned int locked_free_nr; unsigned int locked_free_nr;
struct io_rings *rings;
const struct cred *sq_creds; /* cred used for __io_sq_thread() */ const struct cred *sq_creds; /* cred used for __io_sq_thread() */
struct io_sq_data *sq_data; /* if using sq thread polling */ struct io_sq_data *sq_data; /* if using sq thread polling */
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册