diff options
author | Paolo Bonzini <pbonzini@redhat.com> | 2019-06-06 18:52:44 +0200 |
---|---|---|
committer | Paolo Bonzini <pbonzini@redhat.com> | 2019-06-18 11:47:38 +0200 |
commit | bf03d4f9334728bf7c8ffc7de787df48abd6340e (patch) | |
tree | 43104c3883abc622b5678b0878dc75b51b6dbd29 /arch/x86/kvm/x86.h | |
parent | c27e5b0d139b8728abd6b087cb0d3b2eae6ab079 (diff) | |
download | lwn-bf03d4f9334728bf7c8ffc7de787df48abd6340e.tar.gz lwn-bf03d4f9334728bf7c8ffc7de787df48abd6340e.zip |
KVM: x86: introduce is_pae_paging
Checking for 32-bit PAE is quite common around code that fiddles with
the PDPTRs. Add a function to compress all checks into a single
invocation.
Reviewed-by: Sean Christopherson <sean.j.christopherson@intel.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Diffstat (limited to 'arch/x86/kvm/x86.h')
-rw-r--r-- | arch/x86/kvm/x86.h | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/arch/x86/kvm/x86.h b/arch/x86/kvm/x86.h index 275b3b646023..e08a12892e8b 100644 --- a/arch/x86/kvm/x86.h +++ b/arch/x86/kvm/x86.h @@ -139,6 +139,11 @@ static inline int is_paging(struct kvm_vcpu *vcpu) return likely(kvm_read_cr0_bits(vcpu, X86_CR0_PG)); } +static inline bool is_pae_paging(struct kvm_vcpu *vcpu) +{ + return !is_long_mode(vcpu) && is_pae(vcpu) && is_paging(vcpu); +} + static inline u32 bit(int bitno) { return 1 << (bitno & 31); |