CVE 7.8 HIGH

io-wq: check that the predecessor is hashed in io_wq_remove_pending()_CVE-2026-46274

7.8 / 10
HIGH
CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H

Description

In the Linux kernel, the following vulnerability has been resolved:

io-wq: check that the predecessor is hashed in io_wq_remove_pending()

io_wq_remove_pending() needs to fix up wq->hash_tail[] if the cancelled
work was the tail of its hash bucket. When doing this, it checks whether
the preceding entry in acct->work_list has the same hash value, but
never checks that the predecessor is hashed at all. io_get_work_hash()
is simply atomic_read(&work->flags) >> IO_WQ_HASH_SHIFT, and the hash
bits are never set for non-hashed work, so it returns 0. Thus, when a
hashed bucket-0 work is cancelled while a non-hashed work is its list
predecessor, the check spuriously passes and a pointer to the non-hashed
io_kiocb is stored in wq->hash_tail[0].

Because non-hashed work is dequeued via the fast path in
io_get_next_work(), which never touches hash_tail[], the stale pointer
is never cleared. Therefore, after the non-hashed io_kiocb completes and
is freed back to req_cachep, wq->hash_tail[0] is a dangling pointer. The
io_wq is per-task (tctx->io_wq) and survives ring open/close, so the
dangling pointer persists for the lifetime of the task; the next hashed
bucket-0 enqueue dereferences it in io_wq_insert_work() and
wq_list_add_after() writes through freed memory.

Add the missing io_wq_is_hashed() check so a non-hashed predecessor
never inherits a hash_tail[] slot.

Basic Information

ID CVE-2026-46274
Source Linux
Published Jun 8, 2026 at 14:30
Modified Jun 14, 2026 at 04:29

Affected Product

Vendor Linux
Product Linux
Version 204361a77f4018627addd4a06877448f088ddfc0
Affected Versions Linux Linux 204361a77f4018627addd4a06877448f088ddfc0
Linux Linux 204361a77f4018627addd4a06877448f088ddfc0
Linux Linux 204361a77f4018627addd4a06877448f088ddfc0
Linux Linux 204361a77f4018627addd4a06877448f088ddfc0
Linux Linux 204361a77f4018627addd4a06877448f088ddfc0
Linux Linux 13f35a2c0fd5c6a4fcd8903542b053bcc914fcf5
Linux Linux 5.8.6
Linux Linux 5.9

References

💭 Join the Security Discussion

🔒 Your email address will not be published. Required fields are marked *

⚠️ Please be respectful and constructive in your comments. Security discussions should remain professional.