x86/sev-es: Replace open-coded hlt-loops with sev_es_terminate()
authorJoerg Roedel <jroedel@suse.de>
Fri, 12 Mar 2021 12:38:24 +0000 (13:38 +0100)
committerBorislav Petkov <bp@suse.de>
Thu, 18 Mar 2021 22:04:12 +0000 (23:04 +0100)
There are a few places left in the SEV-ES C code where hlt loops and/or
terminate requests are implemented. Replace them all with calls to
sev_es_terminate().

Signed-off-by: Joerg Roedel <jroedel@suse.de>
Signed-off-by: Borislav Petkov <bp@suse.de>
Link: https://lkml.kernel.org/r/20210312123824.306-9-joro@8bytes.org
arch/x86/boot/compressed/sev-es.c
arch/x86/kernel/sev-es-shared.c

index 27826c2..d904bd5 100644 (file)
@@ -200,14 +200,8 @@ void do_boot_stage2_vc(struct pt_regs *regs, unsigned long exit_code)
        }
 
 finish:
-       if (result == ES_OK) {
+       if (result == ES_OK)
                vc_finish_insn(&ctxt);
-       } else if (result != ES_RETRY) {
-               /*
-                * For now, just halt the machine. That makes debugging easier,
-                * later we just call sev_es_terminate() here.
-                */
-               while (true)
-                       asm volatile("hlt\n");
-       }
+       else if (result != ES_RETRY)
+               sev_es_terminate(GHCB_SEV_ES_REASON_GENERAL_REQUEST);
 }
index 387b716..0aa9f13 100644 (file)
@@ -24,7 +24,7 @@ static bool __init sev_es_check_cpu_features(void)
        return true;
 }
 
-static void sev_es_terminate(unsigned int reason)
+static void __noreturn sev_es_terminate(unsigned int reason)
 {
        u64 val = GHCB_SEV_TERMINATE;
 
@@ -206,12 +206,8 @@ void __init do_vc_no_ghcb(struct pt_regs *regs, unsigned long exit_code)
        return;
 
 fail:
-       sev_es_wr_ghcb_msr(GHCB_SEV_TERMINATE);
-       VMGEXIT();
-
-       /* Shouldn't get here - if we do halt the machine */
-       while (true)
-               asm volatile("hlt\n");
+       /* Terminate the guest */
+       sev_es_terminate(GHCB_SEV_ES_REASON_GENERAL_REQUEST);
 }
 
 static enum es_result vc_insn_string_read(struct es_em_ctxt *ctxt,