lists.openwall.net | lists / announce owl-users owl-dev john-users john-dev passwdqc-users yescrypt popa3d-users / oss-security kernel-hardening musl sabotage tlsify passwords / crypt-dev xvendor / Bugtraq Full-Disclosure linux-kernel linux-netdev linux-ext4 linux-hardening linux-cve-announce PHC | |
Open Source and information security mailing list archives
| ||
|
Message-ID: <2025050819-CVE-2025-37818-1c09@gregkh> Date: Thu, 8 May 2025 08:39:27 +0200 From: Greg Kroah-Hartman <gregkh@...uxfoundation.org> To: linux-cve-announce@...r.kernel.org Cc: Greg Kroah-Hartman <gregkh@...nel.org> Subject: CVE-2025-37818: LoongArch: Return NULL from huge_pte_offset() for invalid PMD From: Greg Kroah-Hartman <gregkh@...nel.org> 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. The Linux kernel CVE team has assigned CVE-2025-37818 to this issue. Affected and fixed versions =========================== Fixed in 6.1.136 with commit 34256805720993e37adf6127371a1265aea8376a Fixed in 6.6.89 with commit 2ca9380b12711afe95b3589bd82b59623b3c96b3 Fixed in 6.12.26 with commit 51424fd171cee6a33f01f7c66b8eb23ac42289d4 Fixed in 6.14.5 with commit b49f085cd671addbda4802d6b9382513f7dd0f30 Fixed in 6.15-rc4 with commit bd51834d1cf65a2c801295d230c220aeebf87a73 Please see https://www.kernel.org for a full list of currently supported kernel versions by the kernel community. Unaffected versions might change over time as fixes are backported to older supported kernel versions. The official CVE entry at https://cve.org/CVERecord/?id=CVE-2025-37818 will be updated if fixes are backported, please check that for the most up to date information about this issue. Affected files ============== The file(s) affected by this issue are: arch/loongarch/mm/hugetlbpage.c Mitigation ========== The Linux kernel CVE team recommends that you update to the latest stable kernel version for this, and many other bugfixes. Individual changes are never tested alone, but rather are part of a larger kernel release. Cherry-picking individual commits is not recommended or supported by the Linux kernel community at all. If however, updating to the latest release is impossible, the individual changes to resolve this issue can be found at these commits: https://git.kernel.org/stable/c/34256805720993e37adf6127371a1265aea8376a https://git.kernel.org/stable/c/2ca9380b12711afe95b3589bd82b59623b3c96b3 https://git.kernel.org/stable/c/51424fd171cee6a33f01f7c66b8eb23ac42289d4 https://git.kernel.org/stable/c/b49f085cd671addbda4802d6b9382513f7dd0f30 https://git.kernel.org/stable/c/bd51834d1cf65a2c801295d230c220aeebf87a73
Powered by blists - more mailing lists