diff options
author | Jens Axboe <axboe@kernel.dk> | 2023-01-04 23:49:54 +0300 |
---|---|---|
committer | Jens Axboe <axboe@kernel.dk> | 2023-01-04 23:49:54 +0300 |
commit | 59b745bb4e0bd445366c45b8df6b51b69134f4f5 (patch) | |
tree | 8b7cfdd6c89ecbd48ef41398226cdc42e205dd38 | |
parent | f26cc9593581bd734c846bf827401350b36dc3c9 (diff) | |
download | linux-59b745bb4e0bd445366c45b8df6b51b69134f4f5.tar.xz |
io_uring: move 'poll_multi_queue' bool in io_ring_ctx
The cacheline section holding this variable has two gaps, where one is
caused by this bool not packing well with structs. This causes it to
blow into the next cacheline. Move the variable, shrinking io_ring_ctx
by a full cacheline in size.
Signed-off-by: Jens Axboe <axboe@kernel.dk>
-rw-r--r-- | include/linux/io_uring_types.h | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/include/linux/io_uring_types.h b/include/linux/io_uring_types.h index dcd8a563ab52..128a67a40065 100644 --- a/include/linux/io_uring_types.h +++ b/include/linux/io_uring_types.h @@ -292,6 +292,8 @@ struct io_ring_ctx { struct { spinlock_t completion_lock; + bool poll_multi_queue; + /* * ->iopoll_list is protected by the ctx->uring_lock for * io_uring instances that don't use IORING_SETUP_SQPOLL. @@ -300,7 +302,6 @@ struct io_ring_ctx { */ struct io_wq_work_list iopoll_list; struct io_hash_table cancel_table; - bool poll_multi_queue; struct llist_head work_llist; |