CVE-2025-37818
Published: May 8, 2025
Modified: May 11, 2026
Description
In the Linux kernel, the following vulnerability has been resolved: LoongArch: Return NULL from huge_pte_offset() for invalid PMD LoongArch's huge_pte_offset() currently returns a pointer to a PMD slot even if the underlying entry points to invalid_pte_table (indicating no mapping). Callers like smaps_hugetlb_range() fetch this invalid entry value (the address of invalid_pte_table) via this pointer. The generic is_swap_pte() check then incorrectly identifies this address as a swap entry on LoongArch, because it satisfies the "!pte_present() && !pte_none()" conditions. This misinterpretation, combined with a coincidental match by is_migration_entry() on the address bits, leads to kernel crashes in pfn_swap_entry_to_page(). Fix this at the architecture level by modifying huge_pte_offset() to check the PMD entry's content using pmd_none() before returning. If the entry is invalid (i.e., it points to invalid_pte_table), return NULL instead of the pointer to the slot.
| Vendor | Product | Versions |
|---|---|---|
Linux | Linux | affected fa96b57c149061f71a70bd6582d995f6424fbbf4 - < 34256805720993e37adf6127371a1265aea8376aaffected fa96b57c149061f71a70bd6582d995f6424fbbf4 - < 2ca9380b12711afe95b3589bd82b59623b3c96b3affected fa96b57c149061f71a70bd6582d995f6424fbbf4 - < 51424fd171cee6a33f01f7c66b8eb23ac42289d4affected fa96b57c149061f71a70bd6582d995f6424fbbf4 - < b49f085cd671addbda4802d6b9382513f7dd0f30affected fa96b57c149061f71a70bd6582d995f6424fbbf4 - < bd51834d1cf65a2c801295d230c220aeebf87a73 |
Linux | Linux | affected 5.19unaffected 0 - < 5.19unaffected 6.1.136 - <= 6.1.*unaffected 6.6.89 - <= 6.6.*unaffected 6.12.26 - <= 6.12.*+2 more versions |
References
Security Training
Train your team to recognize and prevent security threats with our comprehensive security awareness program.
Start TrainingVulnerability Scanning
Discover vulnerabilities in your applications and infrastructure before attackers do.
Scan Now