[PATCH 0/3] KVM: arm64: Simplify pKVM memory transitions
From: Quentin Perret
Date: Fri Jan 10 2025 - 07:20:00 EST
Since its early days, pKVM has formalized memory 'transitions' (shares
and donations) using 'struct pkvm_mem_transition' and bunch of helpers
to manipulate it. The intention was for all transitions to use this
machinery to ensure we're checking things consistently. However, as
development progressed, it became clear that the rigidity of this model
made it really difficult to use in some use-cases which ended-up
side-stepping it entirely. That is the case for the
hyp_{un}pin_shared_mem() and host_{un}share_guest() paths upstream which
use lower level helpers directly, as well as for several other pKVM
features that should land upstream in the future (ex: when a guest
relinquishes a page during ballooning, when annotating a page that is
being DMA'd to, ...). On top of this, the pkvm_mem_transition machinery
requires a lot of boilerplate which makes the code hard to read, but
also adds layers of indirection that no compilers seems to see through,
hence leading to suboptimal generated code.
Given all the above, this series removes the pkvm_mem_transition
machinery from mem_protect.c, and converts all its users to use
__*_{check,set}_page_state_range() low-level helpers directly.
A few things to note:
- the existing helpers to request, ack, initiate and complete
transitions were mostly wrappers around
__*_{check,set}_page_state_range() anyways, so we're not losing that
much in terms of consistency
- the pkvm_mem_transition machinery did not suffice to avoid bugs such
as [1]. The pkvm selftest [2] should do a much better job at that
- see diffstat ;-)
This series depends on support for NP guest stage-2 for pKVM [3] as well
as the fix in [1]. I've pushed a branch with all the goodies applied [4]
if that can be useful.
Thanks,
Quentin
[1] https://lore.kernel.org/kvmarm/20241128154406.602875-1-qperret@xxxxxxxxxx/
[2] https://lore.kernel.org/kvmarm/20241129125800.992468-1-qperret@xxxxxxxxxx/
[3] https://lore.kernel.org/kvmarm/20241218194059.3670226-1-qperret@xxxxxxxxxx/
[4] https://android-kvm.googlesource.com/linux/+/refs/heads/qperret/no-mem-tx
Quentin Perret (3):
KVM: arm64: Drop pkvm_mem_transition for FF-A
KVM: arm64: Drop pkvm_mem_transition for host/hyp sharing
KVM: arm64: Drop pkvm_mem_transition for host/hyp donations
arch/arm64/kvm/hyp/nvhe/mem_protect.c | 640 +++-----------------------
1 file changed, 76 insertions(+), 564 deletions(-)
--
2.47.1.688.g23fc6f90ad-goog