diff options
Diffstat (limited to 'arch/x86/kvm/paging_tmpl.h')
-rw-r--r-- | arch/x86/kvm/paging_tmpl.h | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/arch/x86/kvm/paging_tmpl.h b/arch/x86/kvm/paging_tmpl.h index 8ebc3a5560ce..bf39d0f3efa9 100644 --- a/arch/x86/kvm/paging_tmpl.h +++ b/arch/x86/kvm/paging_tmpl.h | |||
@@ -744,9 +744,9 @@ static int FNAME(page_fault)(struct kvm_vcpu *vcpu, gva_t addr, u32 error_code, | |||
744 | &walker, user_fault, &vcpu->arch.write_fault_to_shadow_pgtable); | 744 | &walker, user_fault, &vcpu->arch.write_fault_to_shadow_pgtable); |
745 | 745 | ||
746 | if (walker.level >= PT_DIRECTORY_LEVEL && !is_self_change_mapping) { | 746 | if (walker.level >= PT_DIRECTORY_LEVEL && !is_self_change_mapping) { |
747 | force_pt_level = mapping_level_dirty_bitmap(vcpu, walker.gfn); | 747 | level = mapping_level(vcpu, walker.gfn, &force_pt_level); |
748 | if (!force_pt_level) { | 748 | if (likely(!force_pt_level)) { |
749 | level = min(walker.level, mapping_level(vcpu, walker.gfn)); | 749 | level = min(walker.level, level); |
750 | walker.gfn = walker.gfn & ~(KVM_PAGES_PER_HPAGE(level) - 1); | 750 | walker.gfn = walker.gfn & ~(KVM_PAGES_PER_HPAGE(level) - 1); |
751 | } | 751 | } |
752 | } else | 752 | } else |