io_uring: remove IO_WQ_WORK_CB
IO_WQ_WORK_CB is used only for linked timeouts, which will be armed before the work setup (i.e. mm, override creds, etc). The setup shouldn't take long, so it's ok to arm it a bit later and get rid of IO_WQ_WORK_CB. Make io-wq call work->func() only once, callbacks will handle the rest. i.e. the linked timeout handler will do the actual issue. And as a bonus, it removes an extra indirect call. Signed-off-by: Pavel Begunkov <asml.silence@gmail.com> Signed-off-by: Jens Axboe <axboe@kernel.dk>
This commit is contained in:
Родитель
e85530ddda
Коммит
5eae861990
|
@ -479,9 +479,6 @@ next:
|
|||
worker->cur_work = work;
|
||||
spin_unlock_irq(&worker->lock);
|
||||
|
||||
if (work->flags & IO_WQ_WORK_CB)
|
||||
work->func(&work);
|
||||
|
||||
if (work->files && current->files != work->files) {
|
||||
task_lock(current);
|
||||
current->files = work->files;
|
||||
|
|
|
@ -7,7 +7,6 @@ enum {
|
|||
IO_WQ_WORK_CANCEL = 1,
|
||||
IO_WQ_WORK_HASHED = 4,
|
||||
IO_WQ_WORK_UNBOUND = 32,
|
||||
IO_WQ_WORK_CB = 128,
|
||||
IO_WQ_WORK_NO_CANCEL = 256,
|
||||
IO_WQ_WORK_CONCURRENT = 512,
|
||||
|
||||
|
|
|
@ -2549,7 +2549,7 @@ static void io_link_work_cb(struct io_wq_work **workptr)
|
|||
struct io_kiocb *link = work->data;
|
||||
|
||||
io_queue_linked_timeout(link);
|
||||
work->func = io_wq_submit_work;
|
||||
io_wq_submit_work(workptr);
|
||||
}
|
||||
|
||||
static void io_wq_assign_next(struct io_wq_work **workptr, struct io_kiocb *nxt)
|
||||
|
@ -2559,7 +2559,6 @@ static void io_wq_assign_next(struct io_wq_work **workptr, struct io_kiocb *nxt)
|
|||
io_prep_next_work(nxt, &link);
|
||||
*workptr = &nxt->work;
|
||||
if (link) {
|
||||
nxt->work.flags |= IO_WQ_WORK_CB;
|
||||
nxt->work.func = io_link_work_cb;
|
||||
nxt->work.data = link;
|
||||
}
|
||||
|
|
Загрузка…
Ссылка в новой задаче