aboutsummaryrefslogtreecommitdiffstats
path: root/arch/x86/kvm/mmu.h
diff options
context:
space:
mode:
authorXiao Guangrong <xiaoguangrong@cn.fujitsu.com>2011-07-11 15:23:20 -0400
committerAvi Kivity <avi@redhat.com>2011-07-24 04:50:26 -0400
commitbebb106a5afa32efdf5332ed4a40bf4d6d06b56e (patch)
treeb8da141e846c9d25fbe4c69b12582cada03726e3 /arch/x86/kvm/mmu.h
parentaf7cc7d1ee422a612f6785e347a893d44cc892ea (diff)
KVM: MMU: cache mmio info on page fault path
If the page fault is caused by mmio, we can cache the mmio info, later, we do not need to walk guest page table and quickly know it is a mmio fault while we emulate the mmio instruction Signed-off-by: Xiao Guangrong <xiaoguangrong@cn.fujitsu.com> Signed-off-by: Avi Kivity <avi@redhat.com>
Diffstat (limited to 'arch/x86/kvm/mmu.h')
-rw-r--r--arch/x86/kvm/mmu.h23
1 files changed, 23 insertions, 0 deletions
diff --git a/arch/x86/kvm/mmu.h b/arch/x86/kvm/mmu.h
index 7086ca85d3e7..05310b105dac 100644
--- a/arch/x86/kvm/mmu.h
+++ b/arch/x86/kvm/mmu.h
@@ -76,4 +76,27 @@ static inline int is_present_gpte(unsigned long pte)
76 return pte & PT_PRESENT_MASK; 76 return pte & PT_PRESENT_MASK;
77} 77}
78 78
79static inline int is_writable_pte(unsigned long pte)
80{
81 return pte & PT_WRITABLE_MASK;
82}
83
84static inline bool is_write_protection(struct kvm_vcpu *vcpu)
85{
86 return kvm_read_cr0_bits(vcpu, X86_CR0_WP);
87}
88
89static inline bool check_write_user_access(struct kvm_vcpu *vcpu,
90 bool write_fault, bool user_fault,
91 unsigned long pte)
92{
93 if (unlikely(write_fault && !is_writable_pte(pte)
94 && (user_fault || is_write_protection(vcpu))))
95 return false;
96
97 if (unlikely(user_fault && !(pte & PT_USER_MASK)))
98 return false;
99
100 return true;
101}
79#endif 102#endif