diff options
Diffstat (limited to 'arch/x86/kvm/vmx.c')
-rw-r--r-- | arch/x86/kvm/vmx.c | 72 |
1 files changed, 36 insertions, 36 deletions
diff --git a/arch/x86/kvm/vmx.c b/arch/x86/kvm/vmx.c index 63ca692fa673..0caaf56eb459 100644 --- a/arch/x86/kvm/vmx.c +++ b/arch/x86/kvm/vmx.c | |||
@@ -7314,21 +7314,21 @@ static bool nested_vmx_exit_handled_io(struct kvm_vcpu *vcpu, | |||
7314 | else if (port < 0x10000) | 7314 | else if (port < 0x10000) |
7315 | bitmap = vmcs12->io_bitmap_b; | 7315 | bitmap = vmcs12->io_bitmap_b; |
7316 | else | 7316 | else |
7317 | return 1; | 7317 | return true; |
7318 | bitmap += (port & 0x7fff) / 8; | 7318 | bitmap += (port & 0x7fff) / 8; |
7319 | 7319 | ||
7320 | if (last_bitmap != bitmap) | 7320 | if (last_bitmap != bitmap) |
7321 | if (kvm_read_guest(vcpu->kvm, bitmap, &b, 1)) | 7321 | if (kvm_read_guest(vcpu->kvm, bitmap, &b, 1)) |
7322 | return 1; | 7322 | return true; |
7323 | if (b & (1 << (port & 7))) | 7323 | if (b & (1 << (port & 7))) |
7324 | return 1; | 7324 | return true; |
7325 | 7325 | ||
7326 | port++; | 7326 | port++; |
7327 | size--; | 7327 | size--; |
7328 | last_bitmap = bitmap; | 7328 | last_bitmap = bitmap; |
7329 | } | 7329 | } |
7330 | 7330 | ||
7331 | return 0; | 7331 | return false; |
7332 | } | 7332 | } |
7333 | 7333 | ||
7334 | /* | 7334 | /* |
@@ -7344,7 +7344,7 @@ static bool nested_vmx_exit_handled_msr(struct kvm_vcpu *vcpu, | |||
7344 | gpa_t bitmap; | 7344 | gpa_t bitmap; |
7345 | 7345 | ||
7346 | if (!nested_cpu_has(vmcs12, CPU_BASED_USE_MSR_BITMAPS)) | 7346 | if (!nested_cpu_has(vmcs12, CPU_BASED_USE_MSR_BITMAPS)) |
7347 | return 1; | 7347 | return true; |
7348 | 7348 | ||
7349 | /* | 7349 | /* |
7350 | * The MSR_BITMAP page is divided into four 1024-byte bitmaps, | 7350 | * The MSR_BITMAP page is divided into four 1024-byte bitmaps, |
@@ -7363,10 +7363,10 @@ static bool nested_vmx_exit_handled_msr(struct kvm_vcpu *vcpu, | |||
7363 | if (msr_index < 1024*8) { | 7363 | if (msr_index < 1024*8) { |
7364 | unsigned char b; | 7364 | unsigned char b; |
7365 | if (kvm_read_guest(vcpu->kvm, bitmap + msr_index/8, &b, 1)) | 7365 | if (kvm_read_guest(vcpu->kvm, bitmap + msr_index/8, &b, 1)) |
7366 | return 1; | 7366 | return true; |
7367 | return 1 & (b >> (msr_index & 7)); | 7367 | return 1 & (b >> (msr_index & 7)); |
7368 | } else | 7368 | } else |
7369 | return 1; /* let L1 handle the wrong parameter */ | 7369 | return true; /* let L1 handle the wrong parameter */ |
7370 | } | 7370 | } |
7371 | 7371 | ||
7372 | /* | 7372 | /* |
@@ -7388,7 +7388,7 @@ static bool nested_vmx_exit_handled_cr(struct kvm_vcpu *vcpu, | |||
7388 | case 0: | 7388 | case 0: |
7389 | if (vmcs12->cr0_guest_host_mask & | 7389 | if (vmcs12->cr0_guest_host_mask & |
7390 | (val ^ vmcs12->cr0_read_shadow)) | 7390 | (val ^ vmcs12->cr0_read_shadow)) |
7391 | return 1; | 7391 | return true; |
7392 | break; | 7392 | break; |
7393 | case 3: | 7393 | case 3: |
7394 | if ((vmcs12->cr3_target_count >= 1 && | 7394 | if ((vmcs12->cr3_target_count >= 1 && |
@@ -7399,37 +7399,37 @@ static bool nested_vmx_exit_handled_cr(struct kvm_vcpu *vcpu, | |||
7399 | vmcs12->cr3_target_value2 == val) || | 7399 | vmcs12->cr3_target_value2 == val) || |
7400 | (vmcs12->cr3_target_count >= 4 && | 7400 | (vmcs12->cr3_target_count >= 4 && |
7401 | vmcs12->cr3_target_value3 == val)) | 7401 | vmcs12->cr3_target_value3 == val)) |
7402 | return 0; | 7402 | return false; |
7403 | if (nested_cpu_has(vmcs12, CPU_BASED_CR3_LOAD_EXITING)) | 7403 | if (nested_cpu_has(vmcs12, CPU_BASED_CR3_LOAD_EXITING)) |
7404 | return 1; | 7404 | return true; |
7405 | break; | 7405 | break; |
7406 | case 4: | 7406 | case 4: |
7407 | if (vmcs12->cr4_guest_host_mask & | 7407 | if (vmcs12->cr4_guest_host_mask & |
7408 | (vmcs12->cr4_read_shadow ^ val)) | 7408 | (vmcs12->cr4_read_shadow ^ val)) |
7409 | return 1; | 7409 | return true; |
7410 | break; | 7410 | break; |
7411 | case 8: | 7411 | case 8: |
7412 | if (nested_cpu_has(vmcs12, CPU_BASED_CR8_LOAD_EXITING)) | 7412 | if (nested_cpu_has(vmcs12, CPU_BASED_CR8_LOAD_EXITING)) |
7413 | return 1; | 7413 | return true; |
7414 | break; | 7414 | break; |
7415 | } | 7415 | } |
7416 | break; | 7416 | break; |
7417 | case 2: /* clts */ | 7417 | case 2: /* clts */ |
7418 | if ((vmcs12->cr0_guest_host_mask & X86_CR0_TS) && | 7418 | if ((vmcs12->cr0_guest_host_mask & X86_CR0_TS) && |
7419 | (vmcs12->cr0_read_shadow & X86_CR0_TS)) | 7419 | (vmcs12->cr0_read_shadow & X86_CR0_TS)) |
7420 | return 1; | 7420 | return true; |
7421 | break; | 7421 | break; |
7422 | case 1: /* mov from cr */ | 7422 | case 1: /* mov from cr */ |
7423 | switch (cr) { | 7423 | switch (cr) { |
7424 | case 3: | 7424 | case 3: |
7425 | if (vmcs12->cpu_based_vm_exec_control & | 7425 | if (vmcs12->cpu_based_vm_exec_control & |
7426 | CPU_BASED_CR3_STORE_EXITING) | 7426 | CPU_BASED_CR3_STORE_EXITING) |
7427 | return 1; | 7427 | return true; |
7428 | break; | 7428 | break; |
7429 | case 8: | 7429 | case 8: |
7430 | if (vmcs12->cpu_based_vm_exec_control & | 7430 | if (vmcs12->cpu_based_vm_exec_control & |
7431 | CPU_BASED_CR8_STORE_EXITING) | 7431 | CPU_BASED_CR8_STORE_EXITING) |
7432 | return 1; | 7432 | return true; |
7433 | break; | 7433 | break; |
7434 | } | 7434 | } |
7435 | break; | 7435 | break; |
@@ -7440,14 +7440,14 @@ static bool nested_vmx_exit_handled_cr(struct kvm_vcpu *vcpu, | |||
7440 | */ | 7440 | */ |
7441 | if (vmcs12->cr0_guest_host_mask & 0xe & | 7441 | if (vmcs12->cr0_guest_host_mask & 0xe & |
7442 | (val ^ vmcs12->cr0_read_shadow)) | 7442 | (val ^ vmcs12->cr0_read_shadow)) |
7443 | return 1; | 7443 | return true; |
7444 | if ((vmcs12->cr0_guest_host_mask & 0x1) && | 7444 | if ((vmcs12->cr0_guest_host_mask & 0x1) && |
7445 | !(vmcs12->cr0_read_shadow & 0x1) && | 7445 | !(vmcs12->cr0_read_shadow & 0x1) && |
7446 | (val & 0x1)) | 7446 | (val & 0x1)) |
7447 | return 1; | 7447 | return true; |
7448 | break; | 7448 | break; |
7449 | } | 7449 | } |
7450 | return 0; | 7450 | return false; |
7451 | } | 7451 | } |
7452 | 7452 | ||
7453 | /* | 7453 | /* |
@@ -7470,43 +7470,43 @@ static bool nested_vmx_exit_handled(struct kvm_vcpu *vcpu) | |||
7470 | KVM_ISA_VMX); | 7470 | KVM_ISA_VMX); |
7471 | 7471 | ||
7472 | if (vmx->nested.nested_run_pending) | 7472 | if (vmx->nested.nested_run_pending) |
7473 | return 0; | 7473 | return false; |
7474 | 7474 | ||
7475 | if (unlikely(vmx->fail)) { | 7475 | if (unlikely(vmx->fail)) { |
7476 | pr_info_ratelimited("%s failed vm entry %x\n", __func__, | 7476 | pr_info_ratelimited("%s failed vm entry %x\n", __func__, |
7477 | vmcs_read32(VM_INSTRUCTION_ERROR)); | 7477 | vmcs_read32(VM_INSTRUCTION_ERROR)); |
7478 | return 1; | 7478 | return true; |
7479 | } | 7479 | } |
7480 | 7480 | ||
7481 | switch (exit_reason) { | 7481 | switch (exit_reason) { |
7482 | case EXIT_REASON_EXCEPTION_NMI: | 7482 | case EXIT_REASON_EXCEPTION_NMI: |
7483 | if (!is_exception(intr_info)) | 7483 | if (!is_exception(intr_info)) |
7484 | return 0; | 7484 | return false; |
7485 | else if (is_page_fault(intr_info)) | 7485 | else if (is_page_fault(intr_info)) |
7486 | return enable_ept; | 7486 | return enable_ept; |
7487 | else if (is_no_device(intr_info) && | 7487 | else if (is_no_device(intr_info) && |
7488 | !(vmcs12->guest_cr0 & X86_CR0_TS)) | 7488 | !(vmcs12->guest_cr0 & X86_CR0_TS)) |
7489 | return 0; | 7489 | return false; |
7490 | return vmcs12->exception_bitmap & | 7490 | return vmcs12->exception_bitmap & |
7491 | (1u << (intr_info & INTR_INFO_VECTOR_MASK)); | 7491 | (1u << (intr_info & INTR_INFO_VECTOR_MASK)); |
7492 | case EXIT_REASON_EXTERNAL_INTERRUPT: | 7492 | case EXIT_REASON_EXTERNAL_INTERRUPT: |
7493 | return 0; | 7493 | return false; |
7494 | case EXIT_REASON_TRIPLE_FAULT: | 7494 | case EXIT_REASON_TRIPLE_FAULT: |
7495 | return 1; | 7495 | return true; |
7496 | case EXIT_REASON_PENDING_INTERRUPT: | 7496 | case EXIT_REASON_PENDING_INTERRUPT: |
7497 | return nested_cpu_has(vmcs12, CPU_BASED_VIRTUAL_INTR_PENDING); | 7497 | return nested_cpu_has(vmcs12, CPU_BASED_VIRTUAL_INTR_PENDING); |
7498 | case EXIT_REASON_NMI_WINDOW: | 7498 | case EXIT_REASON_NMI_WINDOW: |
7499 | return nested_cpu_has(vmcs12, CPU_BASED_VIRTUAL_NMI_PENDING); | 7499 | return nested_cpu_has(vmcs12, CPU_BASED_VIRTUAL_NMI_PENDING); |
7500 | case EXIT_REASON_TASK_SWITCH: | 7500 | case EXIT_REASON_TASK_SWITCH: |
7501 | return 1; | 7501 | return true; |
7502 | case EXIT_REASON_CPUID: | 7502 | case EXIT_REASON_CPUID: |
7503 | if (kvm_register_read(vcpu, VCPU_REGS_RAX) == 0xa) | 7503 | if (kvm_register_read(vcpu, VCPU_REGS_RAX) == 0xa) |
7504 | return 0; | 7504 | return false; |
7505 | return 1; | 7505 | return true; |
7506 | case EXIT_REASON_HLT: | 7506 | case EXIT_REASON_HLT: |
7507 | return nested_cpu_has(vmcs12, CPU_BASED_HLT_EXITING); | 7507 | return nested_cpu_has(vmcs12, CPU_BASED_HLT_EXITING); |
7508 | case EXIT_REASON_INVD: | 7508 | case EXIT_REASON_INVD: |
7509 | return 1; | 7509 | return true; |
7510 | case EXIT_REASON_INVLPG: | 7510 | case EXIT_REASON_INVLPG: |
7511 | return nested_cpu_has(vmcs12, CPU_BASED_INVLPG_EXITING); | 7511 | return nested_cpu_has(vmcs12, CPU_BASED_INVLPG_EXITING); |
7512 | case EXIT_REASON_RDPMC: | 7512 | case EXIT_REASON_RDPMC: |
@@ -7523,7 +7523,7 @@ static bool nested_vmx_exit_handled(struct kvm_vcpu *vcpu) | |||
7523 | * VMX instructions trap unconditionally. This allows L1 to | 7523 | * VMX instructions trap unconditionally. This allows L1 to |
7524 | * emulate them for its L2 guest, i.e., allows 3-level nesting! | 7524 | * emulate them for its L2 guest, i.e., allows 3-level nesting! |
7525 | */ | 7525 | */ |
7526 | return 1; | 7526 | return true; |
7527 | case EXIT_REASON_CR_ACCESS: | 7527 | case EXIT_REASON_CR_ACCESS: |
7528 | return nested_vmx_exit_handled_cr(vcpu, vmcs12); | 7528 | return nested_vmx_exit_handled_cr(vcpu, vmcs12); |
7529 | case EXIT_REASON_DR_ACCESS: | 7529 | case EXIT_REASON_DR_ACCESS: |
@@ -7534,7 +7534,7 @@ static bool nested_vmx_exit_handled(struct kvm_vcpu *vcpu) | |||
7534 | case EXIT_REASON_MSR_WRITE: | 7534 | case EXIT_REASON_MSR_WRITE: |
7535 | return nested_vmx_exit_handled_msr(vcpu, vmcs12, exit_reason); | 7535 | return nested_vmx_exit_handled_msr(vcpu, vmcs12, exit_reason); |
7536 | case EXIT_REASON_INVALID_STATE: | 7536 | case EXIT_REASON_INVALID_STATE: |
7537 | return 1; | 7537 | return true; |
7538 | case EXIT_REASON_MWAIT_INSTRUCTION: | 7538 | case EXIT_REASON_MWAIT_INSTRUCTION: |
7539 | return nested_cpu_has(vmcs12, CPU_BASED_MWAIT_EXITING); | 7539 | return nested_cpu_has(vmcs12, CPU_BASED_MWAIT_EXITING); |
7540 | case EXIT_REASON_MONITOR_INSTRUCTION: | 7540 | case EXIT_REASON_MONITOR_INSTRUCTION: |
@@ -7544,7 +7544,7 @@ static bool nested_vmx_exit_handled(struct kvm_vcpu *vcpu) | |||
7544 | nested_cpu_has2(vmcs12, | 7544 | nested_cpu_has2(vmcs12, |
7545 | SECONDARY_EXEC_PAUSE_LOOP_EXITING); | 7545 | SECONDARY_EXEC_PAUSE_LOOP_EXITING); |
7546 | case EXIT_REASON_MCE_DURING_VMENTRY: | 7546 | case EXIT_REASON_MCE_DURING_VMENTRY: |
7547 | return 0; | 7547 | return false; |
7548 | case EXIT_REASON_TPR_BELOW_THRESHOLD: | 7548 | case EXIT_REASON_TPR_BELOW_THRESHOLD: |
7549 | return nested_cpu_has(vmcs12, CPU_BASED_TPR_SHADOW); | 7549 | return nested_cpu_has(vmcs12, CPU_BASED_TPR_SHADOW); |
7550 | case EXIT_REASON_APIC_ACCESS: | 7550 | case EXIT_REASON_APIC_ACCESS: |
@@ -7553,7 +7553,7 @@ static bool nested_vmx_exit_handled(struct kvm_vcpu *vcpu) | |||
7553 | case EXIT_REASON_APIC_WRITE: | 7553 | case EXIT_REASON_APIC_WRITE: |
7554 | case EXIT_REASON_EOI_INDUCED: | 7554 | case EXIT_REASON_EOI_INDUCED: |
7555 | /* apic_write and eoi_induced should exit unconditionally. */ | 7555 | /* apic_write and eoi_induced should exit unconditionally. */ |
7556 | return 1; | 7556 | return true; |
7557 | case EXIT_REASON_EPT_VIOLATION: | 7557 | case EXIT_REASON_EPT_VIOLATION: |
7558 | /* | 7558 | /* |
7559 | * L0 always deals with the EPT violation. If nested EPT is | 7559 | * L0 always deals with the EPT violation. If nested EPT is |
@@ -7561,7 +7561,7 @@ static bool nested_vmx_exit_handled(struct kvm_vcpu *vcpu) | |||
7561 | * missing in the guest EPT table (EPT12), the EPT violation | 7561 | * missing in the guest EPT table (EPT12), the EPT violation |
7562 | * will be injected with nested_ept_inject_page_fault() | 7562 | * will be injected with nested_ept_inject_page_fault() |
7563 | */ | 7563 | */ |
7564 | return 0; | 7564 | return false; |
7565 | case EXIT_REASON_EPT_MISCONFIG: | 7565 | case EXIT_REASON_EPT_MISCONFIG: |
7566 | /* | 7566 | /* |
7567 | * L2 never uses directly L1's EPT, but rather L0's own EPT | 7567 | * L2 never uses directly L1's EPT, but rather L0's own EPT |
@@ -7569,11 +7569,11 @@ static bool nested_vmx_exit_handled(struct kvm_vcpu *vcpu) | |||
7569 | * (EPT on EPT). So any problems with the structure of the | 7569 | * (EPT on EPT). So any problems with the structure of the |
7570 | * table is L0's fault. | 7570 | * table is L0's fault. |
7571 | */ | 7571 | */ |
7572 | return 0; | 7572 | return false; |
7573 | case EXIT_REASON_WBINVD: | 7573 | case EXIT_REASON_WBINVD: |
7574 | return nested_cpu_has2(vmcs12, SECONDARY_EXEC_WBINVD_EXITING); | 7574 | return nested_cpu_has2(vmcs12, SECONDARY_EXEC_WBINVD_EXITING); |
7575 | case EXIT_REASON_XSETBV: | 7575 | case EXIT_REASON_XSETBV: |
7576 | return 1; | 7576 | return true; |
7577 | case EXIT_REASON_XSAVES: case EXIT_REASON_XRSTORS: | 7577 | case EXIT_REASON_XSAVES: case EXIT_REASON_XRSTORS: |
7578 | /* | 7578 | /* |
7579 | * This should never happen, since it is not possible to | 7579 | * This should never happen, since it is not possible to |
@@ -7583,7 +7583,7 @@ static bool nested_vmx_exit_handled(struct kvm_vcpu *vcpu) | |||
7583 | */ | 7583 | */ |
7584 | return nested_cpu_has2(vmcs12, SECONDARY_EXEC_XSAVES); | 7584 | return nested_cpu_has2(vmcs12, SECONDARY_EXEC_XSAVES); |
7585 | default: | 7585 | default: |
7586 | return 1; | 7586 | return true; |
7587 | } | 7587 | } |
7588 | } | 7588 | } |
7589 | 7589 | ||