๐Ÿ” CVE Alert

CVE-2026-53207

UNKNOWN 0.0

mm/memory-failure: fix hugetlb_lock AA deadlock in get_huge_page_for_hwpoison

CVSS Score
0.0
EPSS Score
0.0%
EPSS Percentile
0th

In the Linux kernel, the following vulnerability has been resolved: mm/memory-failure: fix hugetlb_lock AA deadlock in get_huge_page_for_hwpoison Two concurrent madvise(MADV_HWPOISON) calls on the same hugetlb page can trigger a recursive spinlock self-deadlock (AA deadlock) on hugetlb_lock when racing with a concurrent unmap: thread#0 thread#1 -------- -------- madvise(folio, MADV_HWPOISON) -> poisons the folio successfully madvise(folio, MADV_HWPOISON) unmap(folio) try_memory_failure_hugetlb get_huge_page_for_hwpoison spin_lock_irq(&hugetlb_lock) <- held __get_huge_page_for_hwpoison hugetlb_update_hwpoison() -> MF_HUGETLB_FOLIO_PRE_POISONED goto out: folio_put() refcount: 1 -> 0 free_huge_folio() spin_lock_irqsave(&hugetlb_lock) -> AA DEADLOCK! The out: path in __get_huge_page_for_hwpoison() calls folio_put() to drop the GUP reference while the hugetlb_lock is still held by the hugetlb.c wrapper get_huge_page_for_hwpoison(). If concurrent unmap has released the page table mapping reference, folio_put() drops the folio refcount to zero, triggering free_huge_folio() which attempts to re-acquire the non-recursive hugetlb_lock. Fix this by moving hugetlb_lock acquisition from the hugetlb.c wrapper into get_huge_page_for_hwpoison(). Place spin_unlock_irq() before the folio_put() at the out: label so the folio is always released outside the lock. [[email protected]: fix race, rename label per Miaohe]

Vendor linux
Product linux
Ecosystems
Industries
Technology
Published Jun 25, 2026
Stay Ahead of the Next One

Get instant alerts for linux linux

Be the first to know when new unknown vulnerabilities affecting linux linux are published โ€” delivered to Slack, Telegram or Discord.

Get Free Alerts โ†’ Free ยท No credit card ยท 60 sec setup

Affected Versions

Linux / Linux
405ce051236cc65b30bbfe490b28ce60ae6aed85 < fc3ff42cb0cbf947e4600ae9761c3783760050e2 405ce051236cc65b30bbfe490b28ce60ae6aed85 < 77b73b54801ae7137479c141fd0473a491c1dc48 405ce051236cc65b30bbfe490b28ce60ae6aed85 < a33bfed648c10f5a1519981dbfad80841191edc8 405ce051236cc65b30bbfe490b28ce60ae6aed85 < dd77a83915b07e2b0205adb284f08b39ae31dc4b 405ce051236cc65b30bbfe490b28ce60ae6aed85 < bf7ba8f96c258c30393814491930ae4ecdc5fe5e 405ce051236cc65b30bbfe490b28ce60ae6aed85 < 3c2d42b8ee345b17a4ba56b0f6492d1ff4c1178e 62d1655b922958826b7ec22682c3141746f75064 5.15.54 < 5.16
Linux / Linux
5.18

References

NVD โ†— CVE.org โ†— EPSS Data โ†—
git.kernel.org: https://git.kernel.org/stable/c/fc3ff42cb0cbf947e4600ae9761c3783760050e2 git.kernel.org: https://git.kernel.org/stable/c/77b73b54801ae7137479c141fd0473a491c1dc48 git.kernel.org: https://git.kernel.org/stable/c/a33bfed648c10f5a1519981dbfad80841191edc8 git.kernel.org: https://git.kernel.org/stable/c/dd77a83915b07e2b0205adb284f08b39ae31dc4b git.kernel.org: https://git.kernel.org/stable/c/bf7ba8f96c258c30393814491930ae4ecdc5fe5e git.kernel.org: https://git.kernel.org/stable/c/3c2d42b8ee345b17a4ba56b0f6492d1ff4c1178e