summaryrefslogtreecommitdiff
path: root/io_uring
diff options
context:
space:
mode:
authorJens Axboe <axboe@kernel.dk>2024-03-25 18:53:33 -0600
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2024-06-12 11:11:32 +0200
commit1319dbd64b73019c4e71a3a0747e186000900cf2 (patch)
tree79bee8b410739b5aa6dfa8a530ff960fb12cd5a1 /io_uring
parenta750b846c1365c290a7276c90ad26d8910bc0ab2 (diff)
downloadlinux-1319dbd64b73019c4e71a3a0747e186000900cf2.tar.gz
linux-1319dbd64b73019c4e71a3a0747e186000900cf2.tar.bz2
linux-1319dbd64b73019c4e71a3a0747e186000900cf2.zip
io_uring: use the right type for work_llist empty check
[ Upstream commit 22537c9f79417fed70b352d54d01d2586fee9521 ] io_task_work_pending() uses wq_list_empty() on ctx->work_llist, but it's not an io_wq_work_list, it's a struct llist_head. They both have ->first as head-of-list, and it turns out the checks are identical. But be proper and use the right helper. Fixes: dac6a0eae793 ("io_uring: ensure iopoll runs local task work as well") Signed-off-by: Jens Axboe <axboe@kernel.dk> Signed-off-by: Sasha Levin <sashal@kernel.org>
Diffstat (limited to 'io_uring')
-rw-r--r--io_uring/io_uring.h2
1 files changed, 1 insertions, 1 deletions
diff --git a/io_uring/io_uring.h b/io_uring/io_uring.h
index 411c883b37a9..19ac1b2f1ea4 100644
--- a/io_uring/io_uring.h
+++ b/io_uring/io_uring.h
@@ -304,7 +304,7 @@ static inline int io_run_task_work(void)
static inline bool io_task_work_pending(struct io_ring_ctx *ctx)
{
- return task_work_pending(current) || !wq_list_empty(&ctx->work_llist);
+ return task_work_pending(current) || !llist_empty(&ctx->work_llist);
}
static inline void io_tw_lock(struct io_ring_ctx *ctx, struct io_tw_state *ts)