diff options
author | Julian Stecklina <jsteckli@os.inf.tu-dresden.de> | 2012-12-05 09:26:19 -0500 |
---|---|---|
committer | Gleb Natapov <gleb@redhat.com> | 2012-12-05 11:00:07 -0500 |
commit | 66f7b72e117180d0007e7a65b8dc5bd1c8126e3b (patch) | |
tree | 215798d481c12903a48136631ab6978be440ed99 /arch/x86/kvm/svm.c | |
parent | 2b3c5cbc0d814437fe4d70cc11ed60550b95b29f (diff) |
KVM: x86: Make register state after reset conform to specification
VMX behaves now as SVM wrt to FPU initialization. Code has been moved to
generic code path. General-purpose registers are now cleared on reset and
INIT. SVM code properly initializes EDX.
Signed-off-by: Julian Stecklina <jsteckli@os.inf.tu-dresden.de>
Signed-off-by: Gleb Natapov <gleb@redhat.com>
Diffstat (limited to 'arch/x86/kvm/svm.c')
-rw-r--r-- | arch/x86/kvm/svm.c | 14 |
1 files changed, 6 insertions, 8 deletions
diff --git a/arch/x86/kvm/svm.c b/arch/x86/kvm/svm.c index dcb79527e7aa..d29d3cd1c156 100644 --- a/arch/x86/kvm/svm.c +++ b/arch/x86/kvm/svm.c | |||
@@ -20,6 +20,7 @@ | |||
20 | #include "mmu.h" | 20 | #include "mmu.h" |
21 | #include "kvm_cache_regs.h" | 21 | #include "kvm_cache_regs.h" |
22 | #include "x86.h" | 22 | #include "x86.h" |
23 | #include "cpuid.h" | ||
23 | 24 | ||
24 | #include <linux/module.h> | 25 | #include <linux/module.h> |
25 | #include <linux/mod_devicetable.h> | 26 | #include <linux/mod_devicetable.h> |
@@ -1193,6 +1194,8 @@ static void init_vmcb(struct vcpu_svm *svm) | |||
1193 | static int svm_vcpu_reset(struct kvm_vcpu *vcpu) | 1194 | static int svm_vcpu_reset(struct kvm_vcpu *vcpu) |
1194 | { | 1195 | { |
1195 | struct vcpu_svm *svm = to_svm(vcpu); | 1196 | struct vcpu_svm *svm = to_svm(vcpu); |
1197 | u32 dummy; | ||
1198 | u32 eax = 1; | ||
1196 | 1199 | ||
1197 | init_vmcb(svm); | 1200 | init_vmcb(svm); |
1198 | 1201 | ||
@@ -1201,8 +1204,9 @@ static int svm_vcpu_reset(struct kvm_vcpu *vcpu) | |||
1201 | svm->vmcb->save.cs.base = svm->vcpu.arch.sipi_vector << 12; | 1204 | svm->vmcb->save.cs.base = svm->vcpu.arch.sipi_vector << 12; |
1202 | svm->vmcb->save.cs.selector = svm->vcpu.arch.sipi_vector << 8; | 1205 | svm->vmcb->save.cs.selector = svm->vcpu.arch.sipi_vector << 8; |
1203 | } | 1206 | } |
1204 | vcpu->arch.regs_avail = ~0; | 1207 | |
1205 | vcpu->arch.regs_dirty = ~0; | 1208 | kvm_cpuid(vcpu, &eax, &dummy, &dummy, &dummy); |
1209 | kvm_register_write(vcpu, VCPU_REGS_RDX, eax); | ||
1206 | 1210 | ||
1207 | return 0; | 1211 | return 0; |
1208 | } | 1212 | } |
@@ -1259,10 +1263,6 @@ static struct kvm_vcpu *svm_create_vcpu(struct kvm *kvm, unsigned int id) | |||
1259 | svm->asid_generation = 0; | 1263 | svm->asid_generation = 0; |
1260 | init_vmcb(svm); | 1264 | init_vmcb(svm); |
1261 | 1265 | ||
1262 | err = fx_init(&svm->vcpu); | ||
1263 | if (err) | ||
1264 | goto free_page4; | ||
1265 | |||
1266 | svm->vcpu.arch.apic_base = 0xfee00000 | MSR_IA32_APICBASE_ENABLE; | 1266 | svm->vcpu.arch.apic_base = 0xfee00000 | MSR_IA32_APICBASE_ENABLE; |
1267 | if (kvm_vcpu_is_bsp(&svm->vcpu)) | 1267 | if (kvm_vcpu_is_bsp(&svm->vcpu)) |
1268 | svm->vcpu.arch.apic_base |= MSR_IA32_APICBASE_BSP; | 1268 | svm->vcpu.arch.apic_base |= MSR_IA32_APICBASE_BSP; |
@@ -1271,8 +1271,6 @@ static struct kvm_vcpu *svm_create_vcpu(struct kvm *kvm, unsigned int id) | |||
1271 | 1271 | ||
1272 | return &svm->vcpu; | 1272 | return &svm->vcpu; |
1273 | 1273 | ||
1274 | free_page4: | ||
1275 | __free_page(hsave_page); | ||
1276 | free_page3: | 1274 | free_page3: |
1277 | __free_pages(nested_msrpm_pages, MSRPM_ALLOC_ORDER); | 1275 | __free_pages(nested_msrpm_pages, MSRPM_ALLOC_ORDER); |
1278 | free_page2: | 1276 | free_page2: |