aboutsummaryrefslogtreecommitdiffstats
path: root/arch/x86/include
diff options
context:
space:
mode:
authorTakuya Yoshikawa <yoshikawa.takuya@oss.ntt.co.jp>2012-07-02 04:56:33 -0400
committerMarcelo Tosatti <mtosatti@redhat.com>2012-07-18 15:55:04 -0400
commitb3ae2096974b12c3af2ad1a4e7716b084949867f (patch)
tree38ca81ac607cec1c00d6961effb38992577114df /arch/x86/include
parent84504ef38673fa021b3d8f3da2b79cf878b33315 (diff)
KVM: Introduce kvm_unmap_hva_range() for kvm_mmu_notifier_invalidate_range_start()
When we tested KVM under memory pressure, with THP enabled on the host, we noticed that MMU notifier took a long time to invalidate huge pages. Since the invalidation was done with mmu_lock held, it not only wasted the CPU but also made the host harder to respond. This patch mitigates this by using kvm_handle_hva_range(). Signed-off-by: Takuya Yoshikawa <yoshikawa.takuya@oss.ntt.co.jp> Cc: Alexander Graf <agraf@suse.de> Cc: Paul Mackerras <paulus@samba.org> Signed-off-by: Marcelo Tosatti <mtosatti@redhat.com>
Diffstat (limited to 'arch/x86/include')
-rw-r--r--arch/x86/include/asm/kvm_host.h1
1 files changed, 1 insertions, 0 deletions
diff --git a/arch/x86/include/asm/kvm_host.h b/arch/x86/include/asm/kvm_host.h
index a3e9409e90b6..d4aab865606c 100644
--- a/arch/x86/include/asm/kvm_host.h
+++ b/arch/x86/include/asm/kvm_host.h
@@ -944,6 +944,7 @@ extern bool kvm_rebooting;
944 944
945#define KVM_ARCH_WANT_MMU_NOTIFIER 945#define KVM_ARCH_WANT_MMU_NOTIFIER
946int kvm_unmap_hva(struct kvm *kvm, unsigned long hva); 946int kvm_unmap_hva(struct kvm *kvm, unsigned long hva);
947int kvm_unmap_hva_range(struct kvm *kvm, unsigned long start, unsigned long end);
947int kvm_age_hva(struct kvm *kvm, unsigned long hva); 948int kvm_age_hva(struct kvm *kvm, unsigned long hva);
948int kvm_test_age_hva(struct kvm *kvm, unsigned long hva); 949int kvm_test_age_hva(struct kvm *kvm, unsigned long hva);
949void kvm_set_spte_hva(struct kvm *kvm, unsigned long hva, pte_t pte); 950void kvm_set_spte_hva(struct kvm *kvm, unsigned long hva, pte_t pte);