This adds the sqpoll support to the io-uring napi. Signed-off-by: Stefan Roesch <shr@xxxxxxxxxxxx> Suggested-by: Olivier Langlois <olivier@xxxxxxxxxxxxxx> --- io_uring/napi.c | 23 +++++++++++++++++++++++ io_uring/napi.h | 2 ++ io_uring/sqpoll.c | 4 ++++ 3 files changed, 29 insertions(+) diff --git a/io_uring/napi.c b/io_uring/napi.c index a085122cae8b..6933375e3737 100644 --- a/io_uring/napi.c +++ b/io_uring/napi.c @@ -237,4 +237,27 @@ void __io_napi_busy_loop(struct io_ring_ctx *ctx, struct io_wait_queue *iowq) } } +/* + * io_napi_sqpoll_busy_poll() - busy poll loop for sqpoll + * @ctx: pointer to io-uring context structure + * + * Splice of the napi list and execute the napi busy poll loop. + */ +int io_napi_sqpoll_busy_poll(struct io_ring_ctx *ctx) +{ + LIST_HEAD(napi_list); + int ret = 0; + + if (!READ_ONCE(ctx->napi_busy_poll_to)) + return 0; + + spin_lock(&ctx->napi_lock); + list_splice_init(&ctx->napi_list, &napi_list); + spin_unlock(&ctx->napi_lock); + + __io_napi_do_busy_loop(&napi_list, ctx->napi_prefer_busy_poll); + io_napi_merge_lists(ctx, &napi_list); + return ret; +} + #endif diff --git a/io_uring/napi.h b/io_uring/napi.h index 1bdf8442081f..0484dfd9a396 100644 --- a/io_uring/napi.h +++ b/io_uring/napi.h @@ -17,6 +17,7 @@ void __io_napi_add(struct io_ring_ctx *ctx, struct file *file); void __io_napi_adjust_timeout(struct io_ring_ctx *ctx, struct io_wait_queue *iowq, struct timespec64 *ts); void __io_napi_busy_loop(struct io_ring_ctx *ctx, struct io_wait_queue *iowq); +int io_napi_sqpoll_busy_poll(struct io_ring_ctx *ctx); static inline bool io_napi(struct io_ring_ctx *ctx) { @@ -77,6 +78,7 @@ static inline void io_napi_add(struct io_kiocb *req) #define io_napi_adjust_timeout(ctx, iowq, ts) do {} while (0) #define io_napi_busy_loop(ctx, iowq) do {} while (0) +#define io_napi_sqpoll_busy_poll(ctx) (0) #endif diff --git a/io_uring/sqpoll.c b/io_uring/sqpoll.c index 9db4bc1f521a..0c8d53ef134a 100644 --- a/io_uring/sqpoll.c +++ b/io_uring/sqpoll.c @@ -15,6 +15,7 @@ #include <uapi/linux/io_uring.h> #include "io_uring.h" +#include "napi.h" #include "sqpoll.h" #define IORING_SQPOLL_CAP_ENTRIES_VALUE 8 @@ -193,6 +194,9 @@ static int __io_sq_thread(struct io_ring_ctx *ctx, bool cap_entries) ret = io_submit_sqes(ctx, to_submit); mutex_unlock(&ctx->uring_lock); + if (io_napi(ctx)) + ret += io_napi_sqpoll_busy_poll(ctx); + if (to_submit && wq_has_sleeper(&ctx->sqo_sq_wait)) wake_up(&ctx->sqo_sq_wait); if (creds) -- 2.39.1