CVE-2026-43292

MEDIUM

mm/vmalloc: prevent RCU stalls in kasan_release_vmalloc_node

Title source: cna
STIX 2.1

Description

In the Linux kernel, the following vulnerability has been resolved: mm/vmalloc: prevent RCU stalls in kasan_release_vmalloc_node When CONFIG_PAGE_OWNER is enabled, freeing KASAN shadow pages during vmalloc cleanup triggers expensive stack unwinding that acquires RCU read locks. Processing a large purge_list without rescheduling can cause the task to hold CPU for extended periods (10+ seconds), leading to RCU stalls and potential OOM conditions. The issue manifests in purge_vmap_node() -> kasan_release_vmalloc_node() where iterating through hundreds or thousands of vmap_area entries and freeing their associated shadow pages causes: rcu: INFO: rcu_preempt detected stalls on CPUs/tasks: rcu: Tasks blocked on level-0 rcu_node (CPUs 0-1): P6229/1:b..l ... task:kworker/0:17 state:R running task stack:28840 pid:6229 ... kasan_release_vmalloc_node+0x1ba/0xad0 mm/vmalloc.c:2299 purge_vmap_node+0x1ba/0xad0 mm/vmalloc.c:2299 Each call to kasan_release_vmalloc() can free many pages, and with page_owner tracking, each free triggers save_stack() which performs stack unwinding under RCU read lock. Without yielding, this creates an unbounded RCU critical section. Add periodic cond_resched() calls within the loop to allow: - RCU grace periods to complete - Other tasks to run - Scheduler to preempt when needed The fix uses need_resched() for immediate response under load, with a batch count of 32 as a guaranteed upper bound to prevent worst-case stalls even under light load.

Scores

CVSS v3 5.5
EPSS 0.0001
EPSS Percentile 2.2%
Attack Vector LOCAL
CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:N/I:N/A:H

Details

Status published
Products (15)
Linux/Linux < 6.9
Linux/Linux 1da177e4c3f41524e886b7f1b8a0c1fc7321cac2 - 1afe45f89d54b7183768ebbbbf14238ec187ab5c
Linux/Linux 1da177e4c3f41524e886b7f1b8a0c1fc7321cac2 - 2efa9c02c9b4c0d6866aa445f11056809b25ca28
Linux/Linux 1da177e4c3f41524e886b7f1b8a0c1fc7321cac2 - 5747435e0fd474c24530ef1a6822f47e7d264b27
Linux/Linux 1da177e4c3f41524e886b7f1b8a0c1fc7321cac2 - b351fbe71091f7c8676c8ba597653d08b6719447
Linux/Linux 282631cb2447318e2a55b41a665dbe8571c46d70 - 1afe45f89d54b7183768ebbbbf14238ec187ab5c
Linux/Linux 282631cb2447318e2a55b41a665dbe8571c46d70 - 2efa9c02c9b4c0d6866aa445f11056809b25ca28
Linux/Linux 282631cb2447318e2a55b41a665dbe8571c46d70 - 5747435e0fd474c24530ef1a6822f47e7d264b27
Linux/Linux 282631cb2447318e2a55b41a665dbe8571c46d70 - b351fbe71091f7c8676c8ba597653d08b6719447
Linux/Linux 6.12.75 - 6.12.*
... and 5 more
Published May 08, 2026
Tracked Since May 08, 2026