Fix for Loss of Young/Dirty Bits During Pagemap Scan
CVE-2024-36943

Currently unrated

Key Information:

Vendor
WordPress
Status
Vendor
CVE Published:
30 May 2024

Summary

In the Linux kernel, the following vulnerability has been resolved:

fs/proc/task_mmu: fix loss of young/dirty bits during pagemap scan

make_uffd_wp_pte() was previously doing:

pte = ptep_get(ptep); ptep_modify_prot_start(ptep); pte = pte_mkuffd_wp(pte); ptep_modify_prot_commit(ptep, pte);

But if another thread accessed or dirtied the pte between the first 2 calls, this could lead to loss of that information. Since ptep_modify_prot_start() gets and clears atomically, the following is the correct pattern and prevents any possible race. Any access after the first call would see an invalid pte and cause a fault:

pte = ptep_modify_prot_start(ptep); pte = pte_mkuffd_wp(pte); ptep_modify_prot_commit(ptep, pte);

Affected Version(s)

Linux 52526ca7fdb905a768a93f8faa418e9b988fc34b < 74b3d66f91d9f539f99faad74d796fa9a389a015

Linux 52526ca7fdb905a768a93f8faa418e9b988fc34b

Linux 6.7

References

Timeline

  • Vulnerability published

  • Vulnerability Reserved

.
🍪 This website uses cookies, like every other website on the internet 😕 By using our website, you consent to the use of cookies.