mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-17 02:15:57 +00:00
io_uring/poll: move poll execution helpers higher up
In preparation for calling __io_poll_execute() higher up, move the functions to avoid forward declarations. No functional changes in this patch. Signed-off-by: Jens Axboe <axboe@kernel.dk>
This commit is contained in:
parent
c79f52f065
commit
e84b01a880
@ -228,6 +228,26 @@ enum {
|
|||||||
IOU_POLL_REISSUE = 3,
|
IOU_POLL_REISSUE = 3,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static void __io_poll_execute(struct io_kiocb *req, int mask)
|
||||||
|
{
|
||||||
|
unsigned flags = 0;
|
||||||
|
|
||||||
|
io_req_set_res(req, mask, 0);
|
||||||
|
req->io_task_work.func = io_poll_task_func;
|
||||||
|
|
||||||
|
trace_io_uring_task_add(req, mask);
|
||||||
|
|
||||||
|
if (!(req->flags & REQ_F_POLL_NO_LAZY))
|
||||||
|
flags = IOU_F_TWQ_LAZY_WAKE;
|
||||||
|
__io_req_task_work_add(req, flags);
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline void io_poll_execute(struct io_kiocb *req, int res)
|
||||||
|
{
|
||||||
|
if (io_poll_get_ownership(req))
|
||||||
|
__io_poll_execute(req, res);
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* All poll tw should go through this. Checks for poll events, manages
|
* All poll tw should go through this. Checks for poll events, manages
|
||||||
* references, does rewait, etc.
|
* references, does rewait, etc.
|
||||||
@ -364,26 +384,6 @@ void io_poll_task_func(struct io_kiocb *req, struct io_tw_state *ts)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void __io_poll_execute(struct io_kiocb *req, int mask)
|
|
||||||
{
|
|
||||||
unsigned flags = 0;
|
|
||||||
|
|
||||||
io_req_set_res(req, mask, 0);
|
|
||||||
req->io_task_work.func = io_poll_task_func;
|
|
||||||
|
|
||||||
trace_io_uring_task_add(req, mask);
|
|
||||||
|
|
||||||
if (!(req->flags & REQ_F_POLL_NO_LAZY))
|
|
||||||
flags = IOU_F_TWQ_LAZY_WAKE;
|
|
||||||
__io_req_task_work_add(req, flags);
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void io_poll_execute(struct io_kiocb *req, int res)
|
|
||||||
{
|
|
||||||
if (io_poll_get_ownership(req))
|
|
||||||
__io_poll_execute(req, res);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void io_poll_cancel_req(struct io_kiocb *req)
|
static void io_poll_cancel_req(struct io_kiocb *req)
|
||||||
{
|
{
|
||||||
io_poll_mark_cancelled(req);
|
io_poll_mark_cancelled(req);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user