[PATCH v3 0/9] Stage-2 huge mappings for pKVM np-guests
Vincent Donnefort
vdonnefort at google.com
Mon Apr 7 01:26:57 PDT 2025
Hi all,
This series adds support for stage-2 huge mappings (PMD_SIZE) to pKVM
np-guests, that is installing PMD-level mappings in the stage-2,
whenever the stage-1 is backed by either Hugetlbfs or THPs.
The last patch of that series is an optimization for CMOs using a shared
PMD_SIZE fixmap.
Changes since v2 https://lore.kernel.org/all/20250306110038.3733649-1-vdonnefort@google.com/
- Fix PUD_SIZE -> PMD_SIZE enforcement (Quentin)
- Rework pkvm_host_share_guest() to remove one hyp_page walk (Quentin)
- Remove one pgtable walk into __check_host_shared_guest() (Quentin)
- Return EBUSY on host_share_guest_count overflow
Changes since v1 https://lore.kernel.org/all/20250228102530.1229089-1-vdonnefort@google.com/
- WARN_ON() on !PAGE_ALIGNED size for guest CMOs (Quentin)
- check_range_allowed_memory() before accessing the Vmemmap (Quentin)
Quentin Perret (2):
KVM: arm64: Convert pkvm_mappings to interval tree
KVM: arm64: Add a range to pkvm_mappings
Vincent Donnefort (7):
KVM: arm64: Handle huge mappings for np-guest CMOs
KVM: arm64: Add a range to __pkvm_host_share_guest()
KVM: arm64: Add a range to __pkvm_host_unshare_guest()
KVM: arm64: Add a range to __pkvm_host_wrprotect_guest()
KVM: arm64: Add a range to __pkvm_host_test_clear_young_guest()
KVM: arm64: Stage-2 huge mappings for np-guests
KVM: arm64: np-guest CMOs with PMD_SIZE fixmap
arch/arm64/include/asm/kvm_pgtable.h | 7 +-
arch/arm64/include/asm/kvm_pkvm.h | 2 +
arch/arm64/kvm/hyp/include/nvhe/mem_protect.h | 8 +-
arch/arm64/kvm/hyp/include/nvhe/mm.h | 4 +-
arch/arm64/kvm/hyp/nvhe/hyp-main.c | 16 +-
arch/arm64/kvm/hyp/nvhe/mem_protect.c | 224 +++++++++++++-----
arch/arm64/kvm/hyp/nvhe/mm.c | 86 ++++++-
arch/arm64/kvm/hyp/nvhe/setup.c | 2 +-
arch/arm64/kvm/hyp/pgtable.c | 6 -
arch/arm64/kvm/mmu.c | 5 +-
arch/arm64/kvm/pkvm.c | 129 +++++-----
11 files changed, 330 insertions(+), 159 deletions(-)
base-commit: e48e99b6edf41c69c5528aa7ffb2daf3c59ee105
--
2.49.0.504.g3bcea36a83-goog
More information about the linux-arm-kernel
mailing list