CVE-2025-40329

Linux Kernel - Deadlock in drm_sched_entity_kill_jobs_cb

Title source: llm
STIX 2.1

Description

In the Linux kernel, the following vulnerability has been resolved: drm/sched: Fix deadlock in drm_sched_entity_kill_jobs_cb The Mesa issue referenced below pointed out a possible deadlock: [ 1231.611031] Possible interrupt unsafe locking scenario: [ 1231.611033] CPU0 CPU1 [ 1231.611034] ---- ---- [ 1231.611035] lock(&xa->xa_lock#17); [ 1231.611038] local_irq_disable(); [ 1231.611039] lock(&fence->lock); [ 1231.611041] lock(&xa->xa_lock#17); [ 1231.611044] <Interrupt> [ 1231.611045] lock(&fence->lock); [ 1231.611047] *** DEADLOCK *** In this example, CPU0 would be any function accessing job->dependencies through the xa_* functions that don't disable interrupts (eg: drm_sched_job_add_dependency(), drm_sched_entity_kill_jobs_cb()). CPU1 is executing drm_sched_entity_kill_jobs_cb() as a fence signalling callback so in an interrupt context. It will deadlock when trying to grab the xa_lock which is already held by CPU0. Replacing all xa_* usage by their xa_*_irq counterparts would fix this issue, but Christian pointed out another issue: dma_fence_signal takes fence.lock and so does dma_fence_add_callback. dma_fence_signal() // locks f1.lock -> drm_sched_entity_kill_jobs_cb() -> foreach dependencies -> dma_fence_add_callback() // locks f2.lock This will deadlock if f1 and f2 share the same spinlock. To fix both issues, the code iterating on dependencies and re-arming them is moved out to drm_sched_entity_kill_jobs_work(). [phasta: commit message nits]

Scores

EPSS 0.0004
EPSS Percentile 11.2%

Details

Status published
Products (13)
linux/Kernel 6.13.0 - 6.17.8linux
linux/Kernel 6.2.0 - 6.6.117linux
linux/Kernel 6.7.0 - 6.12.58linux
Linux/Linux < 6.2
Linux/Linux 2fdb8a8f07c2f1353770a324fd19b8114e4329ac - 0d63031ee4a57be0252cb9a4e09ae921c75cece9
Linux/Linux 2fdb8a8f07c2f1353770a324fd19b8114e4329ac - 3e8ada4fd838e3fd2cca94000dac054f3a347c01
Linux/Linux 2fdb8a8f07c2f1353770a324fd19b8114e4329ac - 487df8b698345dd5a91346335f05170ed5f29d4e
Linux/Linux 2fdb8a8f07c2f1353770a324fd19b8114e4329ac - 70150b9443dddf02157d821c68abf438f55a2e8e
Linux/Linux 6.12.58 - 6.12.*
Linux/Linux 6.17.8 - 6.17.*
... and 3 more
Published Dec 09, 2025
Tracked Since Feb 18, 2026