[PATCH 0/3 v3] Sync unmappings in vmalloc/ioremap areas
From: Joerg Roedel
Date: Fri Jul 19 2019 - 14:47:04 EST
Hi,
here is a small patch-set to sync unmappings in the
vmalloc/ioremap areas between page-tables in the system.
This is only needed x86-32 with !SHARED_KERNEL_PMD, which is
the case on a PAE kernel with PTI enabled.
On affected systems the missing sync causes old mappings to
persist in some page-tables, causing data corruption and
other undefined behavior.
Please review.
Thanks,
Joerg
Changes v2 -> v3:
- Moved the vmalloc_sync_all() call to the lazy vmap
purge function as requested by Andy Lutomirski
- Made sure that the code in vmalloc_sync_all()
really iterates over all pgds (pointed out by
Thomas Gleixner)
- Added a couple of comments
Changes v1 -> v2:
- Added correct Fixes-tags to all patches
Joerg Roedel (3):
x86/mm: Check for pfn instead of page in vmalloc_sync_one()
x86/mm: Sync also unmappings in vmalloc_sync_all()
mm/vmalloc: Sync unmappings in vunmap_page_range()
arch/x86/mm/fault.c | 15 ++++++---------
mm/vmalloc.c | 9 +++++++++
2 files changed, 15 insertions(+), 9 deletions(-)
--
2.17.1