Commit 22eb2a3f authored by Pavel Begunkov's avatar Pavel Begunkov Committed by Jens Axboe

io_uring: refactor ctx slow data placement

Shove all slow path data at the end of ctx and get rid of extra
indention.
Signed-off-by: default avatarPavel Begunkov <asml.silence@gmail.com>
Link: https://lore.kernel.org/r/bcaf200298dd469af20787650550efc66d89bef2.1655310733.git.asml.silence@gmail.comSigned-off-by: default avatarJens Axboe <axboe@kernel.dk>
parent aff5b2df
...@@ -185,7 +185,6 @@ struct io_ring_ctx { ...@@ -185,7 +185,6 @@ struct io_ring_ctx {
struct list_head apoll_cache; struct list_head apoll_cache;
struct xarray personalities; struct xarray personalities;
u32 pers_next; u32 pers_next;
unsigned sq_thread_idle;
} ____cacheline_aligned_in_smp; } ____cacheline_aligned_in_smp;
/* IRQ completion list, under ->completion_lock */ /* IRQ completion list, under ->completion_lock */
...@@ -232,10 +231,20 @@ struct io_ring_ctx { ...@@ -232,10 +231,20 @@ struct io_ring_ctx {
struct list_head io_buffers_comp; struct list_head io_buffers_comp;
} ____cacheline_aligned_in_smp; } ____cacheline_aligned_in_smp;
/* timeouts */
struct {
spinlock_t timeout_lock;
atomic_t cq_timeouts;
struct list_head timeout_list;
struct list_head ltimeout_list;
unsigned cq_last_tm_flush;
} ____cacheline_aligned_in_smp;
/* Keep this last, we don't need it for the fast path */
struct io_restriction restrictions; struct io_restriction restrictions;
/* slow path rsrc auxilary data, used by update/register */ /* slow path rsrc auxilary data, used by update/register */
struct {
struct io_rsrc_node *rsrc_backup_node; struct io_rsrc_node *rsrc_backup_node;
struct io_mapped_ubuf *dummy_ubuf; struct io_mapped_ubuf *dummy_ubuf;
struct io_rsrc_data *file_data; struct io_rsrc_data *file_data;
...@@ -247,19 +256,7 @@ struct io_ring_ctx { ...@@ -247,19 +256,7 @@ struct io_ring_ctx {
spinlock_t rsrc_ref_lock; spinlock_t rsrc_ref_lock;
struct list_head io_buffers_pages; struct list_head io_buffers_pages;
};
/* timeouts */
struct {
spinlock_t timeout_lock;
atomic_t cq_timeouts;
struct list_head timeout_list;
struct list_head ltimeout_list;
unsigned cq_last_tm_flush;
} ____cacheline_aligned_in_smp;
/* Keep this last, we don't need it for the fast path */
struct {
#if defined(CONFIG_UNIX) #if defined(CONFIG_UNIX)
struct socket *ring_sock; struct socket *ring_sock;
#endif #endif
...@@ -282,7 +279,7 @@ struct io_ring_ctx { ...@@ -282,7 +279,7 @@ struct io_ring_ctx {
bool iowq_limits_set; bool iowq_limits_set;
struct list_head defer_list; struct list_head defer_list;
}; unsigned sq_thread_idle;
}; };
enum { enum {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment