aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJoerg Roedel <joerg.roedel@amd.com>2008-01-31 08:57:37 -0500
committerAvi Kivity <avi@qumranet.com>2008-04-27 04:53:18 -0400
commitf2b4b7ddf633ffa24ce7c89c9e0d8a06463484e3 (patch)
treedb27a5a3cff2e60497ec60194a9f754372bf01e1
parent0aac03f07b37da96e00371e66973d5ffaae578a4 (diff)
KVM: make EFER_RESERVED_BITS configurable for architecture code
This patch give the SVM and VMX implementations the ability to add some bits the guest can set in its EFER register. Signed-off-by: Joerg Roedel <joerg.roedel@amd.com> Signed-off-by: Avi Kivity <avi@qumranet.com>
-rw-r--r--arch/x86/kvm/x86.c11
-rw-r--r--include/asm-x86/kvm_host.h1
2 files changed, 10 insertions, 2 deletions
diff --git a/arch/x86/kvm/x86.c b/arch/x86/kvm/x86.c
index 6b01552bd1f1..ec9265b354b0 100644
--- a/arch/x86/kvm/x86.c
+++ b/arch/x86/kvm/x86.c
@@ -41,7 +41,7 @@
41 | X86_CR4_OSXMMEXCPT | X86_CR4_VMXE)) 41 | X86_CR4_OSXMMEXCPT | X86_CR4_VMXE))
42 42
43#define CR8_RESERVED_BITS (~(unsigned long)X86_CR8_TPR) 43#define CR8_RESERVED_BITS (~(unsigned long)X86_CR8_TPR)
44#define EFER_RESERVED_BITS 0xfffffffffffff2fe 44static u64 __read_mostly efer_reserved_bits = 0xfffffffffffff2fe;
45 45
46#define VM_STAT(x) offsetof(struct kvm, stat.x), KVM_STAT_VM 46#define VM_STAT(x) offsetof(struct kvm, stat.x), KVM_STAT_VM
47#define VCPU_STAT(x) offsetof(struct kvm_vcpu, stat.x), KVM_STAT_VCPU 47#define VCPU_STAT(x) offsetof(struct kvm_vcpu, stat.x), KVM_STAT_VCPU
@@ -428,7 +428,7 @@ static u32 emulated_msrs[] = {
428 428
429static void set_efer(struct kvm_vcpu *vcpu, u64 efer) 429static void set_efer(struct kvm_vcpu *vcpu, u64 efer)
430{ 430{
431 if (efer & EFER_RESERVED_BITS) { 431 if (efer & efer_reserved_bits) {
432 printk(KERN_DEBUG "set_efer: 0x%llx #GP, reserved bits\n", 432 printk(KERN_DEBUG "set_efer: 0x%llx #GP, reserved bits\n",
433 efer); 433 efer);
434 kvm_inject_gp(vcpu, 0); 434 kvm_inject_gp(vcpu, 0);
@@ -452,6 +452,13 @@ static void set_efer(struct kvm_vcpu *vcpu, u64 efer)
452 452
453#endif 453#endif
454 454
455void kvm_enable_efer_bits(u64 mask)
456{
457 efer_reserved_bits &= ~mask;
458}
459EXPORT_SYMBOL_GPL(kvm_enable_efer_bits);
460
461
455/* 462/*
456 * Writes msr value into into the appropriate "register". 463 * Writes msr value into into the appropriate "register".
457 * Returns 0 on success, non-0 otherwise. 464 * Returns 0 on success, non-0 otherwise.
diff --git a/include/asm-x86/kvm_host.h b/include/asm-x86/kvm_host.h
index 28e8177ea4a0..274f153c8704 100644
--- a/include/asm-x86/kvm_host.h
+++ b/include/asm-x86/kvm_host.h
@@ -430,6 +430,7 @@ void realmode_lmsw(struct kvm_vcpu *vcpu, unsigned long msw,
430unsigned long realmode_get_cr(struct kvm_vcpu *vcpu, int cr); 430unsigned long realmode_get_cr(struct kvm_vcpu *vcpu, int cr);
431void realmode_set_cr(struct kvm_vcpu *vcpu, int cr, unsigned long value, 431void realmode_set_cr(struct kvm_vcpu *vcpu, int cr, unsigned long value,
432 unsigned long *rflags); 432 unsigned long *rflags);
433void kvm_enable_efer_bits(u64);
433int kvm_get_msr(struct kvm_vcpu *vcpu, u32 msr_index, u64 *data); 434int kvm_get_msr(struct kvm_vcpu *vcpu, u32 msr_index, u64 *data);
434int kvm_set_msr(struct kvm_vcpu *vcpu, u32 msr_index, u64 data); 435int kvm_set_msr(struct kvm_vcpu *vcpu, u32 msr_index, u64 data);
435 436