aboutsummaryrefslogtreecommitdiffstats
path: root/arch/x86/kvm/x86.c
diff options
context:
space:
mode:
authorXiao Guangrong <xiaoguangrong@cn.fujitsu.com>2010-11-12 01:49:55 -0500
committerAvi Kivity <avi@redhat.com>2011-01-12 04:29:14 -0500
commitc4806acdcec020fe5bbb054ce9dc75aaecaf29dd (patch)
tree0fafeeb72efdb8985165fcab0a24ffcc5071653c /arch/x86/kvm/x86.c
parent060c2abe6c5e0f90418baf0a43b48d8d9a5521fb (diff)
KVM: MMU: fix apf prefault if nested guest is enabled
If apf is generated in L2 guest and is completed in L1 guest, it will prefault this apf in L1 guest's mmu context. Signed-off-by: Xiao Guangrong <xiaoguangrong@cn.fujitsu.com> Signed-off-by: Avi Kivity <avi@redhat.com>
Diffstat (limited to 'arch/x86/kvm/x86.c')
-rw-r--r--arch/x86/kvm/x86.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/arch/x86/kvm/x86.c b/arch/x86/kvm/x86.c
index 9b875ff05410..c673e726fbdb 100644
--- a/arch/x86/kvm/x86.c
+++ b/arch/x86/kvm/x86.c
@@ -6168,7 +6168,8 @@ void kvm_arch_async_page_ready(struct kvm_vcpu *vcpu, struct kvm_async_pf *work)
6168{ 6168{
6169 int r; 6169 int r;
6170 6170
6171 if (!vcpu->arch.mmu.direct_map || is_error_page(work->page)) 6171 if (!vcpu->arch.mmu.direct_map || !work->arch.direct_map ||
6172 is_error_page(work->page))
6172 return; 6173 return;
6173 6174
6174 r = kvm_mmu_reload(vcpu); 6175 r = kvm_mmu_reload(vcpu);