CVE-2017-1000405

HIGH

Linux Kernel <4.14 - Privilege Escalation

Title source: llm

Description

The Linux Kernel versions 2.6.38 through 4.14 have a problematic use of pmd_mkdirty() in the touch_pmd() function inside the THP implementation. touch_pmd() can be reached by get_user_pages(). In such case, the pmd will become dirty. This scenario breaks the new can_follow_write_pmd()'s logic - pmd can become dirty without going through a COW cycle. This bug is not as severe as the original "Dirty cow" because an ext4 file (or any other regular file) cannot be mapped using THP. Nevertheless, it does allow us to overwrite read-only huge pages. For example, the zero huge page and sealed shmem files can be overwritten (since their mapping can be populated using THP). Note that after the first write page-fault to the zero page, it will be replaced with a new fresh (and zeroed) thp.

Exploits (3)

exploitdb WORKING POC
by anonymous · cdoslinux
https://www.exploit-db.com/exploits/44305
exploitdb WORKING POC
by Bindecy · cdoslinux
https://www.exploit-db.com/exploits/43199
nomisec WORKING POC 201 stars
by bindecy · poc
https://github.com/bindecy/HugeDirtyCowPOC

Scores

CVSS v3 7.0
EPSS 0.0726
EPSS Percentile 91.7%
Attack Vector LOCAL
CVSS:3.1/AV:L/AC:H/PR:L/UI:N/S:U/C:H/I:H/A:H

Details

CWE
CWE-362
Status published
Products (1)
linux/linux_kernel 3.2.87 - 3.3
Published Nov 30, 2017
Tracked Since Feb 18, 2026