diff options
| author | Thomas Hellstrom (VMware) <[email protected]> | 2020-03-24 18:47:47 +0100 | 
|---|---|---|
| committer | Thomas Hellstrom (VMware) <[email protected]> | 2020-03-24 18:47:47 +0100 | 
| commit | 327e9fd489727aa83e13c80ae517f46cdbe8979e (patch) | |
| tree | f1414b4e0469b58003fa2a4b5e8bf5fbbe8f5947 /tools/perf/scripts/python/bin/export-to-postgresql-report | |
| parent | 2484ca9b6a20451debb789d0a89af6f15de99826 (diff) | |
mm: Split huge pages on write-notify or COW
The functions wp_huge_pmd() and wp_huge_pud() currently relies on the
huge_fault() callback to split huge page table entries if needed.
However for module users that requires export of the split_huge_xxx()
functionality which may be undesired. Instead split pre-existing huge
page-table entries on VM_FAULT_FALLBACK return.
We currently only do COW and write-notify on the PTE level, so if the
huge_fault() handler returns VM_FAULT_FALLBACK on wp faults,
split the huge pages and page-table entries. Also do this for huge PUDs
if there is no huge_fault() handler and the vma is not anonymous, similar
to how it's done for PMDs.
Note that fs/dax.c still does the splitting in the huge_fault() handler,
but as huge_fault() A follow-up patch can remove the dax.c split_huge_pmd()
if needed.
Cc: Andrew Morton <[email protected]>
Cc: Michal Hocko <[email protected]>
Cc: "Matthew Wilcox (Oracle)" <[email protected]>
Cc: "Kirill A. Shutemov" <[email protected]>
Cc: Ralph Campbell <[email protected]>
Cc: "Jérôme Glisse" <[email protected]>
Cc: "Christian König" <[email protected]>
Cc: Dan Williams <[email protected]>
Signed-off-by: Thomas Hellstrom (VMware) <[email protected]>
Acked-by: Christian König <[email protected]>
Acked-by: Andrew Morton <[email protected]>
Diffstat (limited to 'tools/perf/scripts/python/bin/export-to-postgresql-report')
0 files changed, 0 insertions, 0 deletions