On 1/12/25 16:14, Bui Quang Minh wrote:
...
@@ -2898,7 +2899,12 @@ static __cold void io_ring_exit_work(struct
work_struct *work)
if (ctx->flags & IORING_SETUP_DEFER_TASKRUN)
io_move_task_work_from_local(ctx);
- while (io_uring_try_cancel_requests(ctx, NULL, true))
+ /*
+ * Even if SQPOLL thread reaches this path, don't force
+ * iopoll here, let the io_uring_cancel_generic handle
+ * it.
Just curious, will sq_thread enter this io_ring_exit_work path?
AFAIK, yes. The SQPOLL thread is created with create_io_thread, this function creates a new task with CLONE_FILES. So all the open files is shared. There will be case that the parent closes its io_uring file and SQPOLL thread become the only owner of that file. So it can reach this path when terminating.
The function is run by a separate kthread, the sqpoll task doesn't
call it directly.