Commit 8a378fb0 authored by Jens Axboe's avatar Jens Axboe

io_uring: ensure io-wq context is always destroyed for tasks

If the task ends up doing no IO, the context list is empty and we don't
call into __io_uring_files_cancel() when the task exits. This can cause
a leak of the io-wq structures.

Ensure we always call __io_uring_files_cancel(), even if the task
context list is empty.

Fixes: 5aa75ed5 ("io_uring: tie async worker side to the task context")
Signed-off-by: default avatarJens Axboe <axboe@kernel.dk>
parent 0100e6bb
...@@ -8800,9 +8800,10 @@ void __io_uring_files_cancel(struct files_struct *files) ...@@ -8800,9 +8800,10 @@ void __io_uring_files_cancel(struct files_struct *files)
if (files) { if (files) {
io_uring_remove_task_files(tctx); io_uring_remove_task_files(tctx);
} else if (tctx->io_wq && current->flags & PF_EXITING) { if (tctx->io_wq) {
io_wq_destroy(tctx->io_wq); io_wq_destroy(tctx->io_wq);
tctx->io_wq = NULL; tctx->io_wq = NULL;
}
} }
} }
......
...@@ -43,7 +43,7 @@ static inline void io_uring_task_cancel(void) ...@@ -43,7 +43,7 @@ static inline void io_uring_task_cancel(void)
} }
static inline void io_uring_files_cancel(struct files_struct *files) static inline void io_uring_files_cancel(struct files_struct *files)
{ {
if (current->io_uring && !xa_empty(&current->io_uring->xa)) if (current->io_uring)
__io_uring_files_cancel(files); __io_uring_files_cancel(files);
} }
static inline void io_uring_free(struct task_struct *tsk) static inline void io_uring_free(struct task_struct *tsk)
......
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