/kernel/linux/linux-5.10/arch/x86/kernel/ |
H A D | sev-es-shared.c | 99 u64 exit_code, u64 exit_info_1, in sev_es_ghcb_hv_call() 109 ghcb_set_sw_exit_info_1(ghcb, exit_info_1); in sev_es_ghcb_hv_call() 406 u64 exit_info_1, exit_info_2; in vc_handle_ioio() local 409 ret = vc_ioio_exitinfo(ctxt, &exit_info_1); in vc_handle_ioio() 413 if (exit_info_1 & IOIO_TYPE_STR) { in vc_handle_ioio() 429 io_bytes = (exit_info_1 >> 4) & 0x7; in vc_handle_ioio() 432 op_count = (exit_info_1 & IOIO_REP) ? regs->cx : 1; in vc_handle_ioio() 439 if (!(exit_info_1 & IOIO_TYPE_IN)) { in vc_handle_ioio() 456 exit_info_1, exit_info_2); in vc_handle_ioio() 461 if (exit_info_1 in vc_handle_ioio() 97 sev_es_ghcb_hv_call(struct ghcb *ghcb, struct es_em_ctxt *ctxt, u64 exit_code, u64 exit_info_1, u64 exit_info_2) sev_es_ghcb_hv_call() argument [all...] |
H A D | sev-es.c | 623 u64 exit_info_1; in vc_handle_msr() local 626 exit_info_1 = (ctxt->insn.opcode.bytes[1] == 0x30) ? 1 : 0; in vc_handle_msr() 629 if (exit_info_1) { in vc_handle_msr() 634 ret = sev_es_ghcb_hv_call(ghcb, ctxt, SVM_EXIT_MSR, exit_info_1, 0); in vc_handle_msr() 636 if ((ret == ES_OK) && (!exit_info_1)) { in vc_handle_msr() 826 u64 exit_code, exit_info_1, exit_info_2; in vc_do_mmio() local 846 exit_info_1 = paddr; in vc_do_mmio() 852 return sev_es_ghcb_hv_call(ghcb, ctxt, exit_code, exit_info_1, exit_info_2); in vc_do_mmio()
|
/kernel/linux/linux-6.6/arch/x86/kernel/ |
H A D | sev-shared.c | 227 u64 exit_code, u64 exit_info_1, in sev_es_ghcb_hv_call() 235 ghcb_set_sw_exit_info_1(ghcb, exit_info_1); in sev_es_ghcb_hv_call() 821 u64 exit_info_1, exit_info_2; in vc_handle_ioio() local 824 ret = vc_ioio_exitinfo(ctxt, &exit_info_1); in vc_handle_ioio() 828 if (exit_info_1 & IOIO_TYPE_STR) { in vc_handle_ioio() 844 io_bytes = (exit_info_1 >> 4) & 0x7; in vc_handle_ioio() 847 op_count = (exit_info_1 & IOIO_REP) ? regs->cx : 1; in vc_handle_ioio() 854 if (!(exit_info_1 & IOIO_TYPE_IN)) { in vc_handle_ioio() 871 exit_info_1, exit_info_2); in vc_handle_ioio() 876 if (exit_info_1 in vc_handle_ioio() 225 sev_es_ghcb_hv_call(struct ghcb *ghcb, struct es_em_ctxt *ctxt, u64 exit_code, u64 exit_info_1, u64 exit_info_2) sev_es_ghcb_hv_call() argument [all...] |
H A D | sev.c | 1200 u64 exit_info_1; in vc_handle_msr() local 1203 exit_info_1 = (ctxt->insn.opcode.bytes[1] == 0x30) ? 1 : 0; in vc_handle_msr() 1206 if (exit_info_1) { in vc_handle_msr() 1211 ret = sev_es_ghcb_hv_call(ghcb, ctxt, SVM_EXIT_MSR, exit_info_1, 0); in vc_handle_msr() 1213 if ((ret == ES_OK) && (!exit_info_1)) { in vc_handle_msr() 1426 u64 exit_code, exit_info_1, exit_info_2; in vc_do_mmio() local 1446 exit_info_1 = paddr; in vc_do_mmio() 1452 return sev_es_ghcb_hv_call(ghcb, ctxt, exit_code, exit_info_1, exit_info_2); in vc_do_mmio()
|
/kernel/linux/linux-5.10/arch/x86/kvm/svm/ |
H A D | nested.c | 40 * correctly fill in the high bits of exit_info_1. in nested_svm_inject_npf_exit() 44 svm->vmcb->control.exit_info_1 = (1ULL << 32); in nested_svm_inject_npf_exit() 48 svm->vmcb->control.exit_info_1 &= ~0xffffffffULL; in nested_svm_inject_npf_exit() 49 svm->vmcb->control.exit_info_1 |= fault->error_code; in nested_svm_inject_npf_exit() 63 svm->vmcb->control.exit_info_1 = fault->error_code; in svm_inject_page_fault_nested() 173 dst->exit_info_1 = from->exit_info_1; in copy_vmcb_control_area() 528 vmcb12->control.exit_info_1 = 0; in nested_svm_vmrun() 587 svm->vmcb->control.exit_info_1 = 0; in nested_svm_vmrun() 665 vmcb12->control.exit_info_1 in nested_svm_vmexit() [all...] |
H A D | avic.c | 300 u32 icrh = svm->vmcb->control.exit_info_1 >> 32; in avic_incomplete_ipi_interception() 301 u32 icrl = svm->vmcb->control.exit_info_1; in avic_incomplete_ipi_interception() 481 u32 offset = svm->vmcb->control.exit_info_1 & in avic_unaccel_trap_write() 537 u32 offset = svm->vmcb->control.exit_info_1 & in avic_unaccelerated_access_interception() 541 bool write = (svm->vmcb->control.exit_info_1 >> 32) & in avic_unaccelerated_access_interception()
|
H A D | svm.c | 1809 u64 error_code = svm->vmcb->control.exit_info_1; in pf_interception() 1820 u64 error_code = svm->vmcb->control.exit_info_1; in npf_interception() 1886 u32 error_code = svm->vmcb->control.exit_info_1; in gp_interception() 2003 u32 io_info = svm->vmcb->control.exit_info_1; /* address size bug? */ in io_interception() 2220 tss_selector = (u16)svm->vmcb->control.exit_info_1; in task_switch_interception() 2296 kvm_mmu_invlpg(&svm->vcpu, svm->vmcb->control.exit_info_1); in invlpg_interception() 2353 if (unlikely((svm->vmcb->control.exit_info_1 & CR_VALID) == 0)) in cr_interception() 2356 reg = svm->vmcb->control.exit_info_1 & SVM_EXITINFO_REG_MASK; in cr_interception() 2436 reg = svm->vmcb->control.exit_info_1 & SVM_EXITINFO_REG_MASK; in dr_interception() 2799 if (svm->vmcb->control.exit_info_1) in msr_interception() [all...] |
/kernel/linux/linux-6.6/arch/x86/kvm/svm/ |
H A D | nested.c | 45 * correctly fill in the high bits of exit_info_1. in nested_svm_inject_npf_exit() 49 vmcb->control.exit_info_1 = (1ULL << 32); in nested_svm_inject_npf_exit() 53 vmcb->control.exit_info_1 &= ~0xffffffffULL; in nested_svm_inject_npf_exit() 54 vmcb->control.exit_info_1 |= fault->error_code; in nested_svm_inject_npf_exit() 348 to->exit_info_1 = from->exit_info_1; in __nested_copy_vmcb_control_to_cache() 644 * Filled at exit: exit_code, exit_code_hi, exit_info_1, exit_info_2, in nested_vmcb02_prepare_control() 884 vmcb12->control.exit_info_1 = 0; in nested_svm_vmrun() 917 svm->vmcb->control.exit_info_1 = 0; in nested_svm_vmrun() 1017 vmcb12->control.exit_info_1 in nested_svm_vmexit() [all...] |
H A D | hyperv.c | 15 svm->vmcb->control.exit_info_1 = HV_SVM_ENL_EXITCODE_TRAP_AFTER_FLUSH; in svm_hv_inject_synthetic_vmexit_post_tlb_flush()
|
H A D | avic.c | 493 u32 icrh = svm->vmcb->control.exit_info_1 >> 32; in avic_incomplete_ipi_interception() 494 u32 icrl = svm->vmcb->control.exit_info_1; in avic_incomplete_ipi_interception() 643 u32 offset = to_svm(vcpu)->vmcb->control.exit_info_1 & in avic_unaccel_trap_write() 697 u32 offset = svm->vmcb->control.exit_info_1 & in avic_unaccelerated_access_interception() 701 bool write = (svm->vmcb->control.exit_info_1 >> 32) & in avic_unaccelerated_access_interception()
|
H A D | svm.c | 2060 u64 error_code = svm->vmcb->control.exit_info_1; in pf_interception() 2073 u64 error_code = svm->vmcb->control.exit_info_1; in npf_interception() 2232 u32 io_info = svm->vmcb->control.exit_info_1; /* address size bug? */ in io_interception() 2387 u32 error_code = svm->vmcb->control.exit_info_1; in gp_interception() 2521 tss_selector = (u16)svm->vmcb->control.exit_info_1; in task_switch_interception() 2605 kvm_mmu_invlpg(vcpu, to_svm(vcpu)->vmcb->control.exit_info_1); in invlpg_interception() 2653 if (unlikely((svm->vmcb->control.exit_info_1 & CR_VALID) == 0)) in cr_interception() 2656 reg = svm->vmcb->control.exit_info_1 & SVM_EXITINFO_REG_MASK; in cr_interception() 2724 new_value = (unsigned long)svm->vmcb->control.exit_info_1; in cr_trap() 2780 reg = svm->vmcb->control.exit_info_1 in dr_interception() [all...] |
H A D | sev.c | 2457 control->exit_info_1 = ghcb_get_sw_exit_info_1(ghcb); in sev_es_sync_from_ghcb() 2520 if (control->exit_info_1 & SVM_IOIO_STR_MASK) { in sev_es_validate_vmgexit() 2524 if (!(control->exit_info_1 & SVM_IOIO_TYPE_MASK)) in sev_es_validate_vmgexit() 2532 if (control->exit_info_1) { in sev_es_validate_vmgexit() 2886 control->exit_info_1, in sev_handle_vmgexit() 2896 control->exit_info_1, in sev_handle_vmgexit() 2912 switch (control->exit_info_1) { in sev_handle_vmgexit() 2922 pr_err("svm: vmgexit: unsupported AP jump table request - exit_info_1=%#llx\n", in sev_handle_vmgexit() 2923 control->exit_info_1); in sev_handle_vmgexit() 2933 "vmgexit: unsupported event - exit_info_1 in sev_handle_vmgexit() [all...] |
H A D | svm.h | 139 u64 exit_info_1; member 603 svm->vmcb->control.exit_info_1 = 0; in nested_svm_simple_vmexit()
|
/kernel/linux/linux-6.6/tools/testing/selftests/kvm/x86_64/ |
H A D | svm_nested_soft_inject_test.c | 108 vmcb->control.exit_info_1, vmcb->control.exit_info_2); in l1_guest_code() 138 vmcb->control.exit_info_1, vmcb->control.exit_info_2); in l1_guest_code()
|
H A D | hyperv_svm_test.c | 142 GUEST_ASSERT(vmcb->control.exit_info_1 == HV_SVM_ENL_EXITCODE_TRAP_AFTER_FLUSH); in guest_code()
|
H A D | nested_exceptions_test.c | 89 GUEST_ASSERT_EQ(ctrl->exit_info_1, error_code); in svm_run_l2()
|
/kernel/linux/linux-6.6/arch/x86/boot/compressed/ |
H A D | sev.c | 274 u64 exit_info_1 = SVM_VMGEXIT_TERM_REASON(set, reason); in sev_es_ghcb_terminate() local 278 ghcb_set_sw_exit_info_1(ghcb, exit_info_1); in sev_es_ghcb_terminate()
|
/kernel/linux/linux-6.6/arch/x86/hyperv/ |
H A D | ivm.c | 122 u64 exit_info_1, u64 exit_info_2) in hv_ghcb_hv_call() 129 ghcb_set_sw_exit_info_1(ghcb, exit_info_1); in hv_ghcb_hv_call() 121 hv_ghcb_hv_call(struct ghcb *ghcb, u64 exit_code, u64 exit_info_1, u64 exit_info_2) hv_ghcb_hv_call() argument
|
/kernel/linux/linux-5.10/tools/testing/selftests/kvm/include/x86_64/ |
H A D | svm.h | 82 u64 exit_info_1; member
|
/kernel/linux/linux-6.6/tools/testing/selftests/kvm/include/x86_64/ |
H A D | svm.h | 103 u64 exit_info_1; member
|
/kernel/linux/linux-5.10/arch/x86/include/asm/ |
H A D | svm.h | 127 u64 exit_info_1; member
|
/kernel/linux/linux-6.6/arch/x86/include/asm/ |
H A D | svm.h | 139 u64 exit_info_1; member
|