Commit fd9c7bc5 authored by Pavel Begunkov's avatar Pavel Begunkov Committed by Jens Axboe

io_uring: refactor hrtimer_try_to_cancel uses

Don't save return values of hrtimer_try_to_cancel() in a variable, but
use right away. It's in general safer to not have an intermediate
variable, which may be reused and passed out wrongly, but it be
contracted out. Also clean io_timeout_extract().
Signed-off-by: default avatarPavel Begunkov <asml.silence@gmail.com>
Link: https://lore.kernel.org/r/d2566ef7ce632e6882dc13e022a26249b3fd30b5.1618278933.git.asml.silence@gmail.comSigned-off-by: default avatarJens Axboe <axboe@kernel.dk>
parent 8c855885
...@@ -1270,10 +1270,8 @@ static void io_kill_timeout(struct io_kiocb *req, int status) ...@@ -1270,10 +1270,8 @@ static void io_kill_timeout(struct io_kiocb *req, int status)
__must_hold(&req->ctx->completion_lock) __must_hold(&req->ctx->completion_lock)
{ {
struct io_timeout_data *io = req->async_data; struct io_timeout_data *io = req->async_data;
int ret;
ret = hrtimer_try_to_cancel(&io->timer); if (hrtimer_try_to_cancel(&io->timer) != -1) {
if (ret != -1) {
atomic_set(&req->ctx->cq_timeouts, atomic_set(&req->ctx->cq_timeouts,
atomic_read(&req->ctx->cq_timeouts) + 1); atomic_read(&req->ctx->cq_timeouts) + 1);
list_del_init(&req->timeout.list); list_del_init(&req->timeout.list);
...@@ -1790,12 +1788,10 @@ static bool io_kill_linked_timeout(struct io_kiocb *req) ...@@ -1790,12 +1788,10 @@ static bool io_kill_linked_timeout(struct io_kiocb *req)
*/ */
if (link && (link->flags & REQ_F_LTIMEOUT_ACTIVE)) { if (link && (link->flags & REQ_F_LTIMEOUT_ACTIVE)) {
struct io_timeout_data *io = link->async_data; struct io_timeout_data *io = link->async_data;
int ret;
io_remove_next_linked(req); io_remove_next_linked(req);
link->timeout.head = NULL; link->timeout.head = NULL;
ret = hrtimer_try_to_cancel(&io->timer); if (hrtimer_try_to_cancel(&io->timer) != -1) {
if (ret != -1) {
io_cqring_fill_event(link, -ECANCELED, 0); io_cqring_fill_event(link, -ECANCELED, 0);
io_put_req_deferred(link, 1); io_put_req_deferred(link, 1);
return true; return true;
...@@ -5528,21 +5524,18 @@ static struct io_kiocb *io_timeout_extract(struct io_ring_ctx *ctx, ...@@ -5528,21 +5524,18 @@ static struct io_kiocb *io_timeout_extract(struct io_ring_ctx *ctx,
{ {
struct io_timeout_data *io; struct io_timeout_data *io;
struct io_kiocb *req; struct io_kiocb *req;
int ret = -ENOENT; bool found = false;
list_for_each_entry(req, &ctx->timeout_list, timeout.list) { list_for_each_entry(req, &ctx->timeout_list, timeout.list) {
if (user_data == req->user_data) { found = user_data == req->user_data;
ret = 0; if (found)
break; break;
}
} }
if (!found)
if (ret == -ENOENT) return ERR_PTR(-ENOENT);
return ERR_PTR(ret);
io = req->async_data; io = req->async_data;
ret = hrtimer_try_to_cancel(&io->timer); if (hrtimer_try_to_cancel(&io->timer) == -1)
if (ret == -1)
return ERR_PTR(-EALREADY); return ERR_PTR(-EALREADY);
list_del_init(&req->timeout.list); list_del_init(&req->timeout.list);
return req; return req;
......
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