diff options
Diffstat (limited to 'drivers/kvm/vmx.c')
-rw-r--r-- | drivers/kvm/vmx.c | 140 |
1 files changed, 65 insertions, 75 deletions
diff --git a/drivers/kvm/vmx.c b/drivers/kvm/vmx.c index 5b77d9b7b1ac..cc7ee3d484fb 100644 --- a/drivers/kvm/vmx.c +++ b/drivers/kvm/vmx.c | |||
@@ -140,9 +140,8 @@ static inline u64 msr_efer_save_restore_bits(struct kvm_msr_entry msr) | |||
140 | return (u64)msr.data & EFER_SAVE_RESTORE_BITS; | 140 | return (u64)msr.data & EFER_SAVE_RESTORE_BITS; |
141 | } | 141 | } |
142 | 142 | ||
143 | static inline int msr_efer_need_save_restore(struct kvm_vcpu *vcpu) | 143 | static inline int msr_efer_need_save_restore(struct vcpu_vmx *vmx) |
144 | { | 144 | { |
145 | struct vcpu_vmx *vmx = to_vmx(vcpu); | ||
146 | int efer_offset = vmx->msr_offset_efer; | 145 | int efer_offset = vmx->msr_offset_efer; |
147 | return msr_efer_save_restore_bits(vmx->host_msrs[efer_offset]) != | 146 | return msr_efer_save_restore_bits(vmx->host_msrs[efer_offset]) != |
148 | msr_efer_save_restore_bits(vmx->guest_msrs[efer_offset]); | 147 | msr_efer_save_restore_bits(vmx->guest_msrs[efer_offset]); |
@@ -168,9 +167,8 @@ static inline int is_external_interrupt(u32 intr_info) | |||
168 | == (INTR_TYPE_EXT_INTR | INTR_INFO_VALID_MASK); | 167 | == (INTR_TYPE_EXT_INTR | INTR_INFO_VALID_MASK); |
169 | } | 168 | } |
170 | 169 | ||
171 | static int __find_msr_index(struct kvm_vcpu *vcpu, u32 msr) | 170 | static int __find_msr_index(struct vcpu_vmx *vmx, u32 msr) |
172 | { | 171 | { |
173 | struct vcpu_vmx *vmx = to_vmx(vcpu); | ||
174 | int i; | 172 | int i; |
175 | 173 | ||
176 | for (i = 0; i < vmx->nmsrs; ++i) | 174 | for (i = 0; i < vmx->nmsrs; ++i) |
@@ -179,12 +177,11 @@ static int __find_msr_index(struct kvm_vcpu *vcpu, u32 msr) | |||
179 | return -1; | 177 | return -1; |
180 | } | 178 | } |
181 | 179 | ||
182 | static struct kvm_msr_entry *find_msr_entry(struct kvm_vcpu *vcpu, u32 msr) | 180 | static struct kvm_msr_entry *find_msr_entry(struct vcpu_vmx *vmx, u32 msr) |
183 | { | 181 | { |
184 | struct vcpu_vmx *vmx = to_vmx(vcpu); | ||
185 | int i; | 182 | int i; |
186 | 183 | ||
187 | i = __find_msr_index(vcpu, msr); | 184 | i = __find_msr_index(vmx, msr); |
188 | if (i >= 0) | 185 | if (i >= 0) |
189 | return &vmx->guest_msrs[i]; | 186 | return &vmx->guest_msrs[i]; |
190 | return NULL; | 187 | return NULL; |
@@ -205,24 +202,24 @@ static void vmcs_clear(struct vmcs *vmcs) | |||
205 | 202 | ||
206 | static void __vcpu_clear(void *arg) | 203 | static void __vcpu_clear(void *arg) |
207 | { | 204 | { |
208 | struct kvm_vcpu *vcpu = arg; | 205 | struct vcpu_vmx *vmx = arg; |
209 | struct vcpu_vmx *vmx = to_vmx(vcpu); | ||
210 | int cpu = raw_smp_processor_id(); | 206 | int cpu = raw_smp_processor_id(); |
211 | 207 | ||
212 | if (vcpu->cpu == cpu) | 208 | if (vmx->vcpu.cpu == cpu) |
213 | vmcs_clear(vmx->vmcs); | 209 | vmcs_clear(vmx->vmcs); |
214 | if (per_cpu(current_vmcs, cpu) == vmx->vmcs) | 210 | if (per_cpu(current_vmcs, cpu) == vmx->vmcs) |
215 | per_cpu(current_vmcs, cpu) = NULL; | 211 | per_cpu(current_vmcs, cpu) = NULL; |
216 | rdtscll(vcpu->host_tsc); | 212 | rdtscll(vmx->vcpu.host_tsc); |
217 | } | 213 | } |
218 | 214 | ||
219 | static void vcpu_clear(struct kvm_vcpu *vcpu) | 215 | static void vcpu_clear(struct vcpu_vmx *vmx) |
220 | { | 216 | { |
221 | if (vcpu->cpu != raw_smp_processor_id() && vcpu->cpu != -1) | 217 | if (vmx->vcpu.cpu != raw_smp_processor_id() && vmx->vcpu.cpu != -1) |
222 | smp_call_function_single(vcpu->cpu, __vcpu_clear, vcpu, 0, 1); | 218 | smp_call_function_single(vmx->vcpu.cpu, __vcpu_clear, |
219 | vmx, 0, 1); | ||
223 | else | 220 | else |
224 | __vcpu_clear(vcpu); | 221 | __vcpu_clear(vmx); |
225 | to_vmx(vcpu)->launched = 0; | 222 | vmx->launched = 0; |
226 | } | 223 | } |
227 | 224 | ||
228 | static unsigned long vmcs_readl(unsigned long field) | 225 | static unsigned long vmcs_readl(unsigned long field) |
@@ -332,23 +329,20 @@ static void reload_tss(void) | |||
332 | #endif | 329 | #endif |
333 | } | 330 | } |
334 | 331 | ||
335 | static void load_transition_efer(struct kvm_vcpu *vcpu) | 332 | static void load_transition_efer(struct vcpu_vmx *vmx) |
336 | { | 333 | { |
337 | u64 trans_efer; | 334 | u64 trans_efer; |
338 | struct vcpu_vmx *vmx = to_vmx(vcpu); | ||
339 | int efer_offset = vmx->msr_offset_efer; | 335 | int efer_offset = vmx->msr_offset_efer; |
340 | 336 | ||
341 | trans_efer = vmx->host_msrs[efer_offset].data; | 337 | trans_efer = vmx->host_msrs[efer_offset].data; |
342 | trans_efer &= ~EFER_SAVE_RESTORE_BITS; | 338 | trans_efer &= ~EFER_SAVE_RESTORE_BITS; |
343 | trans_efer |= msr_efer_save_restore_bits(vmx->guest_msrs[efer_offset]); | 339 | trans_efer |= msr_efer_save_restore_bits(vmx->guest_msrs[efer_offset]); |
344 | wrmsrl(MSR_EFER, trans_efer); | 340 | wrmsrl(MSR_EFER, trans_efer); |
345 | vcpu->stat.efer_reload++; | 341 | vmx->vcpu.stat.efer_reload++; |
346 | } | 342 | } |
347 | 343 | ||
348 | static void vmx_save_host_state(struct kvm_vcpu *vcpu) | 344 | static void vmx_save_host_state(struct vcpu_vmx *vmx) |
349 | { | 345 | { |
350 | struct vcpu_vmx *vmx = to_vmx(vcpu); | ||
351 | |||
352 | if (vmx->host_state.loaded) | 346 | if (vmx->host_state.loaded) |
353 | return; | 347 | return; |
354 | 348 | ||
@@ -383,19 +377,18 @@ static void vmx_save_host_state(struct kvm_vcpu *vcpu) | |||
383 | #endif | 377 | #endif |
384 | 378 | ||
385 | #ifdef CONFIG_X86_64 | 379 | #ifdef CONFIG_X86_64 |
386 | if (is_long_mode(vcpu)) { | 380 | if (is_long_mode(&vmx->vcpu)) { |
387 | save_msrs(vmx->host_msrs + | 381 | save_msrs(vmx->host_msrs + |
388 | vmx->msr_offset_kernel_gs_base, 1); | 382 | vmx->msr_offset_kernel_gs_base, 1); |
389 | } | 383 | } |
390 | #endif | 384 | #endif |
391 | load_msrs(vmx->guest_msrs, vmx->save_nmsrs); | 385 | load_msrs(vmx->guest_msrs, vmx->save_nmsrs); |
392 | if (msr_efer_need_save_restore(vcpu)) | 386 | if (msr_efer_need_save_restore(vmx)) |
393 | load_transition_efer(vcpu); | 387 | load_transition_efer(vmx); |
394 | } | 388 | } |
395 | 389 | ||
396 | static void vmx_load_host_state(struct kvm_vcpu *vcpu) | 390 | static void vmx_load_host_state(struct vcpu_vmx *vmx) |
397 | { | 391 | { |
398 | struct vcpu_vmx *vmx = to_vmx(vcpu); | ||
399 | unsigned long flags; | 392 | unsigned long flags; |
400 | 393 | ||
401 | if (!vmx->host_state.loaded) | 394 | if (!vmx->host_state.loaded) |
@@ -420,7 +413,7 @@ static void vmx_load_host_state(struct kvm_vcpu *vcpu) | |||
420 | } | 413 | } |
421 | save_msrs(vmx->guest_msrs, vmx->save_nmsrs); | 414 | save_msrs(vmx->guest_msrs, vmx->save_nmsrs); |
422 | load_msrs(vmx->host_msrs, vmx->save_nmsrs); | 415 | load_msrs(vmx->host_msrs, vmx->save_nmsrs); |
423 | if (msr_efer_need_save_restore(vcpu)) | 416 | if (msr_efer_need_save_restore(vmx)) |
424 | load_msrs(vmx->host_msrs + vmx->msr_offset_efer, 1); | 417 | load_msrs(vmx->host_msrs + vmx->msr_offset_efer, 1); |
425 | } | 418 | } |
426 | 419 | ||
@@ -435,7 +428,7 @@ static void vmx_vcpu_load(struct kvm_vcpu *vcpu, int cpu) | |||
435 | u64 tsc_this, delta; | 428 | u64 tsc_this, delta; |
436 | 429 | ||
437 | if (vcpu->cpu != cpu) | 430 | if (vcpu->cpu != cpu) |
438 | vcpu_clear(vcpu); | 431 | vcpu_clear(vmx); |
439 | 432 | ||
440 | if (per_cpu(current_vmcs, cpu) != vmx->vmcs) { | 433 | if (per_cpu(current_vmcs, cpu) != vmx->vmcs) { |
441 | u8 error; | 434 | u8 error; |
@@ -476,7 +469,7 @@ static void vmx_vcpu_load(struct kvm_vcpu *vcpu, int cpu) | |||
476 | 469 | ||
477 | static void vmx_vcpu_put(struct kvm_vcpu *vcpu) | 470 | static void vmx_vcpu_put(struct kvm_vcpu *vcpu) |
478 | { | 471 | { |
479 | vmx_load_host_state(vcpu); | 472 | vmx_load_host_state(to_vmx(vcpu)); |
480 | kvm_put_guest_fpu(vcpu); | 473 | kvm_put_guest_fpu(vcpu); |
481 | } | 474 | } |
482 | 475 | ||
@@ -502,7 +495,7 @@ static void vmx_fpu_deactivate(struct kvm_vcpu *vcpu) | |||
502 | 495 | ||
503 | static void vmx_vcpu_decache(struct kvm_vcpu *vcpu) | 496 | static void vmx_vcpu_decache(struct kvm_vcpu *vcpu) |
504 | { | 497 | { |
505 | vcpu_clear(vcpu); | 498 | vcpu_clear(to_vmx(vcpu)); |
506 | } | 499 | } |
507 | 500 | ||
508 | static unsigned long vmx_get_rflags(struct kvm_vcpu *vcpu) | 501 | static unsigned long vmx_get_rflags(struct kvm_vcpu *vcpu) |
@@ -550,9 +543,8 @@ static void vmx_inject_gp(struct kvm_vcpu *vcpu, unsigned error_code) | |||
550 | /* | 543 | /* |
551 | * Swap MSR entry in host/guest MSR entry array. | 544 | * Swap MSR entry in host/guest MSR entry array. |
552 | */ | 545 | */ |
553 | void move_msr_up(struct kvm_vcpu *vcpu, int from, int to) | 546 | static void move_msr_up(struct vcpu_vmx *vmx, int from, int to) |
554 | { | 547 | { |
555 | struct vcpu_vmx *vmx = to_vmx(vcpu); | ||
556 | struct kvm_msr_entry tmp; | 548 | struct kvm_msr_entry tmp; |
557 | 549 | ||
558 | tmp = vmx->guest_msrs[to]; | 550 | tmp = vmx->guest_msrs[to]; |
@@ -568,44 +560,43 @@ void move_msr_up(struct kvm_vcpu *vcpu, int from, int to) | |||
568 | * msrs. Don't touch the 64-bit msrs if the guest is in legacy | 560 | * msrs. Don't touch the 64-bit msrs if the guest is in legacy |
569 | * mode, as fiddling with msrs is very expensive. | 561 | * mode, as fiddling with msrs is very expensive. |
570 | */ | 562 | */ |
571 | static void setup_msrs(struct kvm_vcpu *vcpu) | 563 | static void setup_msrs(struct vcpu_vmx *vmx) |
572 | { | 564 | { |
573 | struct vcpu_vmx *vmx = to_vmx(vcpu); | ||
574 | int save_nmsrs; | 565 | int save_nmsrs; |
575 | 566 | ||
576 | save_nmsrs = 0; | 567 | save_nmsrs = 0; |
577 | #ifdef CONFIG_X86_64 | 568 | #ifdef CONFIG_X86_64 |
578 | if (is_long_mode(vcpu)) { | 569 | if (is_long_mode(&vmx->vcpu)) { |
579 | int index; | 570 | int index; |
580 | 571 | ||
581 | index = __find_msr_index(vcpu, MSR_SYSCALL_MASK); | 572 | index = __find_msr_index(vmx, MSR_SYSCALL_MASK); |
582 | if (index >= 0) | 573 | if (index >= 0) |
583 | move_msr_up(vcpu, index, save_nmsrs++); | 574 | move_msr_up(vmx, index, save_nmsrs++); |
584 | index = __find_msr_index(vcpu, MSR_LSTAR); | 575 | index = __find_msr_index(vmx, MSR_LSTAR); |
585 | if (index >= 0) | 576 | if (index >= 0) |
586 | move_msr_up(vcpu, index, save_nmsrs++); | 577 | move_msr_up(vmx, index, save_nmsrs++); |
587 | index = __find_msr_index(vcpu, MSR_CSTAR); | 578 | index = __find_msr_index(vmx, MSR_CSTAR); |
588 | if (index >= 0) | 579 | if (index >= 0) |
589 | move_msr_up(vcpu, index, save_nmsrs++); | 580 | move_msr_up(vmx, index, save_nmsrs++); |
590 | index = __find_msr_index(vcpu, MSR_KERNEL_GS_BASE); | 581 | index = __find_msr_index(vmx, MSR_KERNEL_GS_BASE); |
591 | if (index >= 0) | 582 | if (index >= 0) |
592 | move_msr_up(vcpu, index, save_nmsrs++); | 583 | move_msr_up(vmx, index, save_nmsrs++); |
593 | /* | 584 | /* |
594 | * MSR_K6_STAR is only needed on long mode guests, and only | 585 | * MSR_K6_STAR is only needed on long mode guests, and only |
595 | * if efer.sce is enabled. | 586 | * if efer.sce is enabled. |
596 | */ | 587 | */ |
597 | index = __find_msr_index(vcpu, MSR_K6_STAR); | 588 | index = __find_msr_index(vmx, MSR_K6_STAR); |
598 | if ((index >= 0) && (vcpu->shadow_efer & EFER_SCE)) | 589 | if ((index >= 0) && (vmx->vcpu.shadow_efer & EFER_SCE)) |
599 | move_msr_up(vcpu, index, save_nmsrs++); | 590 | move_msr_up(vmx, index, save_nmsrs++); |
600 | } | 591 | } |
601 | #endif | 592 | #endif |
602 | vmx->save_nmsrs = save_nmsrs; | 593 | vmx->save_nmsrs = save_nmsrs; |
603 | 594 | ||
604 | #ifdef CONFIG_X86_64 | 595 | #ifdef CONFIG_X86_64 |
605 | vmx->msr_offset_kernel_gs_base = | 596 | vmx->msr_offset_kernel_gs_base = |
606 | __find_msr_index(vcpu, MSR_KERNEL_GS_BASE); | 597 | __find_msr_index(vmx, MSR_KERNEL_GS_BASE); |
607 | #endif | 598 | #endif |
608 | vmx->msr_offset_efer = __find_msr_index(vcpu, MSR_EFER); | 599 | vmx->msr_offset_efer = __find_msr_index(vmx, MSR_EFER); |
609 | } | 600 | } |
610 | 601 | ||
611 | /* | 602 | /* |
@@ -672,7 +663,7 @@ static int vmx_get_msr(struct kvm_vcpu *vcpu, u32 msr_index, u64 *pdata) | |||
672 | data = vmcs_readl(GUEST_SYSENTER_ESP); | 663 | data = vmcs_readl(GUEST_SYSENTER_ESP); |
673 | break; | 664 | break; |
674 | default: | 665 | default: |
675 | msr = find_msr_entry(vcpu, msr_index); | 666 | msr = find_msr_entry(to_vmx(vcpu), msr_index); |
676 | if (msr) { | 667 | if (msr) { |
677 | data = msr->data; | 668 | data = msr->data; |
678 | break; | 669 | break; |
@@ -700,7 +691,7 @@ static int vmx_set_msr(struct kvm_vcpu *vcpu, u32 msr_index, u64 data) | |||
700 | case MSR_EFER: | 691 | case MSR_EFER: |
701 | ret = kvm_set_msr_common(vcpu, msr_index, data); | 692 | ret = kvm_set_msr_common(vcpu, msr_index, data); |
702 | if (vmx->host_state.loaded) | 693 | if (vmx->host_state.loaded) |
703 | load_transition_efer(vcpu); | 694 | load_transition_efer(vmx); |
704 | break; | 695 | break; |
705 | case MSR_FS_BASE: | 696 | case MSR_FS_BASE: |
706 | vmcs_writel(GUEST_FS_BASE, data); | 697 | vmcs_writel(GUEST_FS_BASE, data); |
@@ -722,7 +713,7 @@ static int vmx_set_msr(struct kvm_vcpu *vcpu, u32 msr_index, u64 data) | |||
722 | guest_write_tsc(data); | 713 | guest_write_tsc(data); |
723 | break; | 714 | break; |
724 | default: | 715 | default: |
725 | msr = find_msr_entry(vcpu, msr_index); | 716 | msr = find_msr_entry(vmx, msr_index); |
726 | if (msr) { | 717 | if (msr) { |
727 | msr->data = data; | 718 | msr->data = data; |
728 | if (vmx->host_state.loaded) | 719 | if (vmx->host_state.loaded) |
@@ -1116,7 +1107,7 @@ static void enter_lmode(struct kvm_vcpu *vcpu) | |||
1116 | 1107 | ||
1117 | vcpu->shadow_efer |= EFER_LMA; | 1108 | vcpu->shadow_efer |= EFER_LMA; |
1118 | 1109 | ||
1119 | find_msr_entry(vcpu, MSR_EFER)->data |= EFER_LMA | EFER_LME; | 1110 | find_msr_entry(to_vmx(vcpu), MSR_EFER)->data |= EFER_LMA | EFER_LME; |
1120 | vmcs_write32(VM_ENTRY_CONTROLS, | 1111 | vmcs_write32(VM_ENTRY_CONTROLS, |
1121 | vmcs_read32(VM_ENTRY_CONTROLS) | 1112 | vmcs_read32(VM_ENTRY_CONTROLS) |
1122 | | VM_ENTRY_CONTROLS_IA32E_MASK); | 1113 | | VM_ENTRY_CONTROLS_IA32E_MASK); |
@@ -1186,7 +1177,8 @@ static void vmx_set_cr4(struct kvm_vcpu *vcpu, unsigned long cr4) | |||
1186 | 1177 | ||
1187 | static void vmx_set_efer(struct kvm_vcpu *vcpu, u64 efer) | 1178 | static void vmx_set_efer(struct kvm_vcpu *vcpu, u64 efer) |
1188 | { | 1179 | { |
1189 | struct kvm_msr_entry *msr = find_msr_entry(vcpu, MSR_EFER); | 1180 | struct vcpu_vmx *vmx = to_vmx(vcpu); |
1181 | struct kvm_msr_entry *msr = find_msr_entry(vmx, MSR_EFER); | ||
1190 | 1182 | ||
1191 | vcpu->shadow_efer = efer; | 1183 | vcpu->shadow_efer = efer; |
1192 | if (efer & EFER_LMA) { | 1184 | if (efer & EFER_LMA) { |
@@ -1202,7 +1194,7 @@ static void vmx_set_efer(struct kvm_vcpu *vcpu, u64 efer) | |||
1202 | 1194 | ||
1203 | msr->data = efer & ~EFER_LME; | 1195 | msr->data = efer & ~EFER_LME; |
1204 | } | 1196 | } |
1205 | setup_msrs(vcpu); | 1197 | setup_msrs(vmx); |
1206 | } | 1198 | } |
1207 | 1199 | ||
1208 | #endif | 1200 | #endif |
@@ -1364,9 +1356,8 @@ static void seg_setup(int seg) | |||
1364 | /* | 1356 | /* |
1365 | * Sets up the vmcs for emulated real mode. | 1357 | * Sets up the vmcs for emulated real mode. |
1366 | */ | 1358 | */ |
1367 | static int vmx_vcpu_setup(struct kvm_vcpu *vcpu) | 1359 | static int vmx_vcpu_setup(struct vcpu_vmx *vmx) |
1368 | { | 1360 | { |
1369 | struct vcpu_vmx *vmx = to_vmx(vcpu); | ||
1370 | u32 host_sysenter_cs; | 1361 | u32 host_sysenter_cs; |
1371 | u32 junk; | 1362 | u32 junk; |
1372 | unsigned long a; | 1363 | unsigned long a; |
@@ -1375,19 +1366,18 @@ static int vmx_vcpu_setup(struct kvm_vcpu *vcpu) | |||
1375 | int ret = 0; | 1366 | int ret = 0; |
1376 | unsigned long kvm_vmx_return; | 1367 | unsigned long kvm_vmx_return; |
1377 | 1368 | ||
1378 | if (!init_rmode_tss(vcpu->kvm)) { | 1369 | if (!init_rmode_tss(vmx->vcpu.kvm)) { |
1379 | ret = -ENOMEM; | 1370 | ret = -ENOMEM; |
1380 | goto out; | 1371 | goto out; |
1381 | } | 1372 | } |
1382 | 1373 | ||
1383 | memset(vcpu->regs, 0, sizeof(vcpu->regs)); | 1374 | vmx->vcpu.regs[VCPU_REGS_RDX] = get_rdx_init_val(); |
1384 | vcpu->regs[VCPU_REGS_RDX] = get_rdx_init_val(); | 1375 | vmx->vcpu.cr8 = 0; |
1385 | vcpu->cr8 = 0; | 1376 | vmx->vcpu.apic_base = 0xfee00000 | MSR_IA32_APICBASE_ENABLE; |
1386 | vcpu->apic_base = 0xfee00000 | MSR_IA32_APICBASE_ENABLE; | 1377 | if (vmx->vcpu.vcpu_id == 0) |
1387 | if (vcpu->vcpu_id == 0) | 1378 | vmx->vcpu.apic_base |= MSR_IA32_APICBASE_BSP; |
1388 | vcpu->apic_base |= MSR_IA32_APICBASE_BSP; | ||
1389 | 1379 | ||
1390 | fx_init(vcpu); | 1380 | fx_init(&vmx->vcpu); |
1391 | 1381 | ||
1392 | /* | 1382 | /* |
1393 | * GUEST_CS_BASE should really be 0xffff0000, but VT vm86 mode | 1383 | * GUEST_CS_BASE should really be 0xffff0000, but VT vm86 mode |
@@ -1512,7 +1502,7 @@ static int vmx_vcpu_setup(struct kvm_vcpu *vcpu) | |||
1512 | ++vmx->nmsrs; | 1502 | ++vmx->nmsrs; |
1513 | } | 1503 | } |
1514 | 1504 | ||
1515 | setup_msrs(vcpu); | 1505 | setup_msrs(vmx); |
1516 | 1506 | ||
1517 | vmcs_write32(VM_EXIT_CONTROLS, vmcs_config.vmexit_ctrl); | 1507 | vmcs_write32(VM_EXIT_CONTROLS, vmcs_config.vmexit_ctrl); |
1518 | 1508 | ||
@@ -1529,14 +1519,14 @@ static int vmx_vcpu_setup(struct kvm_vcpu *vcpu) | |||
1529 | vmcs_writel(CR0_GUEST_HOST_MASK, ~0UL); | 1519 | vmcs_writel(CR0_GUEST_HOST_MASK, ~0UL); |
1530 | vmcs_writel(CR4_GUEST_HOST_MASK, KVM_GUEST_CR4_MASK); | 1520 | vmcs_writel(CR4_GUEST_HOST_MASK, KVM_GUEST_CR4_MASK); |
1531 | 1521 | ||
1532 | vcpu->cr0 = 0x60000010; | 1522 | vmx->vcpu.cr0 = 0x60000010; |
1533 | vmx_set_cr0(vcpu, vcpu->cr0); // enter rmode | 1523 | vmx_set_cr0(&vmx->vcpu, vmx->vcpu.cr0); // enter rmode |
1534 | vmx_set_cr4(vcpu, 0); | 1524 | vmx_set_cr4(&vmx->vcpu, 0); |
1535 | #ifdef CONFIG_X86_64 | 1525 | #ifdef CONFIG_X86_64 |
1536 | vmx_set_efer(vcpu, 0); | 1526 | vmx_set_efer(&vmx->vcpu, 0); |
1537 | #endif | 1527 | #endif |
1538 | vmx_fpu_activate(vcpu); | 1528 | vmx_fpu_activate(&vmx->vcpu); |
1539 | update_exception_bitmap(vcpu); | 1529 | update_exception_bitmap(&vmx->vcpu); |
1540 | 1530 | ||
1541 | return 0; | 1531 | return 0; |
1542 | 1532 | ||
@@ -2129,7 +2119,7 @@ again: | |||
2129 | if (!vcpu->mmio_read_completed) | 2119 | if (!vcpu->mmio_read_completed) |
2130 | do_interrupt_requests(vcpu, kvm_run); | 2120 | do_interrupt_requests(vcpu, kvm_run); |
2131 | 2121 | ||
2132 | vmx_save_host_state(vcpu); | 2122 | vmx_save_host_state(vmx); |
2133 | kvm_load_guest_fpu(vcpu); | 2123 | kvm_load_guest_fpu(vcpu); |
2134 | 2124 | ||
2135 | /* | 2125 | /* |
@@ -2352,7 +2342,7 @@ static void vmx_free_vmcs(struct kvm_vcpu *vcpu) | |||
2352 | struct vcpu_vmx *vmx = to_vmx(vcpu); | 2342 | struct vcpu_vmx *vmx = to_vmx(vcpu); |
2353 | 2343 | ||
2354 | if (vmx->vmcs) { | 2344 | if (vmx->vmcs) { |
2355 | on_each_cpu(__vcpu_clear, vcpu, 0, 1); | 2345 | on_each_cpu(__vcpu_clear, vmx, 0, 1); |
2356 | free_vmcs(vmx->vmcs); | 2346 | free_vmcs(vmx->vmcs); |
2357 | vmx->vmcs = NULL; | 2347 | vmx->vmcs = NULL; |
2358 | } | 2348 | } |
@@ -2400,7 +2390,7 @@ static struct kvm_vcpu *vmx_create_vcpu(struct kvm *kvm, unsigned int id) | |||
2400 | 2390 | ||
2401 | cpu = get_cpu(); | 2391 | cpu = get_cpu(); |
2402 | vmx_vcpu_load(&vmx->vcpu, cpu); | 2392 | vmx_vcpu_load(&vmx->vcpu, cpu); |
2403 | err = vmx_vcpu_setup(&vmx->vcpu); | 2393 | err = vmx_vcpu_setup(vmx); |
2404 | vmx_vcpu_put(&vmx->vcpu); | 2394 | vmx_vcpu_put(&vmx->vcpu); |
2405 | put_cpu(); | 2395 | put_cpu(); |
2406 | if (err) | 2396 | if (err) |