CVE-2025-37818
Severity CVSS v4.0:
Pending analysis
Type:
Unavailable / Other
Publication date:
08/05/2025
Last modified:
08/05/2025
Description
In the Linux kernel, the following vulnerability has been resolved:<br />
<br />
LoongArch: Return NULL from huge_pte_offset() for invalid PMD<br />
<br />
LoongArch&#39;s huge_pte_offset() currently returns a pointer to a PMD slot<br />
even if the underlying entry points to invalid_pte_table (indicating no<br />
mapping). Callers like smaps_hugetlb_range() fetch this invalid entry<br />
value (the address of invalid_pte_table) via this pointer.<br />
<br />
The generic is_swap_pte() check then incorrectly identifies this address<br />
as a swap entry on LoongArch, because it satisfies the "!pte_present()<br />
&& !pte_none()" conditions. This misinterpretation, combined with a<br />
coincidental match by is_migration_entry() on the address bits, leads to<br />
kernel crashes in pfn_swap_entry_to_page().<br />
<br />
Fix this at the architecture level by modifying huge_pte_offset() to<br />
check the PMD entry&#39;s content using pmd_none() before returning. If the<br />
entry is invalid (i.e., it points to invalid_pte_table), return NULL<br />
instead of the pointer to the slot.
Impact
References to Advisories, Solutions, and Tools
- https://git.kernel.org/stable/c/2ca9380b12711afe95b3589bd82b59623b3c96b3
- https://git.kernel.org/stable/c/34256805720993e37adf6127371a1265aea8376a
- https://git.kernel.org/stable/c/51424fd171cee6a33f01f7c66b8eb23ac42289d4
- https://git.kernel.org/stable/c/b49f085cd671addbda4802d6b9382513f7dd0f30
- https://git.kernel.org/stable/c/bd51834d1cf65a2c801295d230c220aeebf87a73