[PATCH v2 0/3] arm/arm64: KVM: Add support for page aging
marc.zyngier at arm.com
Thu Mar 12 11:16:49 PDT 2015
So far, KVM/arm doesn't implement any support for page aging, leading
to rather bad performance when the system is swapping. This short
series implements the required hooks and fault handling to deal with
pages being marked old/young.
The three patches are fairly straightforward:
- First patch changes the range iterator to be able to return a value
- Second patch implements the actual page aging (clearing the AF bit
in the page tables, and relying on the normal faulting code to set
the bit again).
- Last patch optimizes the access fault path by only doing the minimum
to satisfy the fault.
The end result is a system that behaves visibly better under load, as
VM pages don't get evicted that easily.
Based on 4.0-rc3, tested on Seattle and X-Gene.
Also at git://git.kernel.org/pub/scm/linux/kernel/git/maz/arm-platforms.git kvm-arm64/page-aging
* From v1 :
- Removed all TLBIs from kvm_age_hva_handler, as the core KVM code
already does use quite a large hammer to nuke the TLBs on its own
- Don't mark old a page that is already old
- Rebased on top of 4.0-rc3
Marc Zyngier (3):
arm/arm64: KVM: Allow handle_hva_to_gpa to return a value
arm/arm64: KVM: Implement Stage-2 page aging
arm/arm64: KVM: Optimize handling of Access Flag faults
arch/arm/include/asm/kvm_arm.h | 1 +
arch/arm/include/asm/kvm_host.h | 13 +---
arch/arm/kvm/mmu.c | 134 +++++++++++++++++++++++++++++++++++---
arch/arm/kvm/trace.h | 48 ++++++++++++++
arch/arm64/include/asm/esr.h | 1 +
arch/arm64/include/asm/kvm_arm.h | 1 +
arch/arm64/include/asm/kvm_host.h | 13 +---
7 files changed, 179 insertions(+), 32 deletions(-)
More information about the linux-arm-kernel