CVE-2024-42233 Information
Description
In the Linux kernel the following vulnerability has been resolved:
filemap: replace pte_offset_map() with pte_offset_map_nolock()
The vmf->ptl in filemap_fault_recheck_pte_none() is still set from handle_pte_fault(). But at the same time we did a pte_unmap(vmf->pte). After a pte_unmap(vmf->pte) unmap and rcu_read_unlock() the page table may be racily changed and vmf->ptl maybe fails to protect the actual page table. Fix this by replacing pte_offset_map() with pte_offset_map_nolock().
As David said the PTL pointer might be stale so if we continue to use it infilemap_fault_recheck_pte_none() it might trigger UAF. Also if the PTL fails the issue fixed by commit 58f327f2ce80 (ilemap: avoid unnecessary major faults in filemap_fault()) might reappear.
Reference
https://git.kernel.org/stable/c/6a6c2aec1a89506595801b4cf7e8eef035f33748 https://git.kernel.org/stable/c/24be02a42181f0707be0498045c4c4b13273b16d
Share on: