diff options
author | Tom Lendacky <thomas.lendacky@amd.com> | 2021-10-01 06:42:01 +0200 |
---|---|---|
committer | Borislav Petkov <bp@suse.de> | 2021-10-01 11:14:41 +0200 |
commit | 06f2ac3d4219bbbfd93d79e01966a42053084f11 (patch) | |
tree | c52d41e8352130a21dafb365ff34b6ccd6f72acb /arch/x86/kernel/sev-shared.c | |
parent | Linux 5.15-rc3 (diff) | |
download | linux-06f2ac3d4219bbbfd93d79e01966a42053084f11.tar.xz linux-06f2ac3d4219bbbfd93d79e01966a42053084f11.zip |
x86/sev: Return an error on a returned non-zero SW_EXITINFO1[31:0]
After returning from a VMGEXIT NAE event, SW_EXITINFO1[31:0] is checked
for a value of 1, which indicates an error and that SW_EXITINFO2
contains exception information. However, future versions of the GHCB
specification may define new values for SW_EXITINFO1[31:0], so really
any non-zero value should be treated as an error.
Fixes: 597cfe48212a ("x86/boot/compressed/64: Setup a GHCB-based VC Exception handler")
Signed-off-by: Tom Lendacky <thomas.lendacky@amd.com>
Signed-off-by: Borislav Petkov <bp@suse.de>
Cc: <stable@vger.kernel.org> # 5.10+
Link: https://lkml.kernel.org/r/efc772af831e9e7f517f0439b13b41f56bad8784.1633063321.git.thomas.lendacky@amd.com
Diffstat (limited to '')
-rw-r--r-- | arch/x86/kernel/sev-shared.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/arch/x86/kernel/sev-shared.c b/arch/x86/kernel/sev-shared.c index 9f90f460a28c..bf1033a62e48 100644 --- a/arch/x86/kernel/sev-shared.c +++ b/arch/x86/kernel/sev-shared.c @@ -130,6 +130,8 @@ static enum es_result sev_es_ghcb_hv_call(struct ghcb *ghcb, } else { ret = ES_VMM_ERROR; } + } else if (ghcb->save.sw_exit_info_1 & 0xffffffff) { + ret = ES_VMM_ERROR; } else { ret = ES_OK; } |