From: Tom Lendacky Date: Wed, 12 Aug 2020 20:21:38 +0000 (-0500) Subject: OvmfPkg/VmgExitLib: Add support for INVD NAE events X-Git-Tag: edk2-stable202008~78 X-Git-Url: https://git.proxmox.com/?p=mirror_edk2.git;a=commitdiff_plain;h=3caf1e2e22e2d0272f8e8b599938b75ab60635de OvmfPkg/VmgExitLib: Add support for INVD NAE events BZ: https://bugzilla.tianocore.org/show_bug.cgi?id=2198 Under SEV-ES, a INVD intercept generates a #VC exception. VMGEXIT must be used to allow the hypervisor to handle this intercept. Cc: Jordan Justen Cc: Laszlo Ersek Cc: Ard Biesheuvel Acked-by: Laszlo Ersek Signed-off-by: Tom Lendacky Regression-tested-by: Laszlo Ersek --- diff --git a/OvmfPkg/Library/VmgExitLib/VmgExitVcHandler.c b/OvmfPkg/Library/VmgExitLib/VmgExitVcHandler.c index 0dd119fdec..ddaa19c7bc 100644 --- a/OvmfPkg/Library/VmgExitLib/VmgExitVcHandler.c +++ b/OvmfPkg/Library/VmgExitLib/VmgExitVcHandler.c @@ -1168,6 +1168,31 @@ IoioExit ( return 0; } +/** + Handle a INVD event. + + Use the VMGEXIT instruction to handle a INVD event. + + @param[in, out] Ghcb Pointer to the Guest-Hypervisor Communication + Block + @param[in, out] Regs x64 processor context + @param[in] InstructionData Instruction parsing context + + @retval 0 Event handled successfully + @return New exception value to propagate + +**/ +STATIC +UINT64 +InvdExit ( + IN OUT GHCB *Ghcb, + IN OUT EFI_SYSTEM_CONTEXT_X64 *Regs, + IN SEV_ES_INSTRUCTION_DATA *InstructionData + ) +{ + return VmgExit (Ghcb, SVM_EXIT_INVD, 0, 0); +} + /** Handle a CPUID event. @@ -1360,6 +1385,10 @@ VmgExitHandleVc ( NaeExit = CpuidExit; break; + case SVM_EXIT_INVD: + NaeExit = InvdExit; + break; + case SVM_EXIT_IOIO_PROT: NaeExit = IoioExit; break;