OSDN Git Service

x86/sev: Make the #VC exception stacks part of the default stacks storage
authorBorislav Petkov <bp@suse.de>
Fri, 1 Oct 2021 19:41:20 +0000 (21:41 +0200)
committerBorislav Petkov <bp@suse.de>
Wed, 6 Oct 2021 19:48:27 +0000 (21:48 +0200)
commit541ac97186d9ea88491961a46284de3603c914fd
tree1a1821f1b37e721c8bde5528af8368a9e8bae447
parentc7419a6e1aa3219ff62045ab6e56e37d5ad2d292
x86/sev: Make the #VC exception stacks part of the default stacks storage

The size of the exception stacks was increased by the commit in Fixes,
resulting in stack sizes greater than a page in size. The #VC exception
handling was only mapping the first (bottom) page, resulting in an
SEV-ES guest failing to boot.

Make the #VC exception stacks part of the default exception stacks
storage and allocate them with a CONFIG_AMD_MEM_ENCRYPT=y .config. Map
them only when a SEV-ES guest has been detected.

Rip out the custom VC stacks mapping and storage code.

 [ bp: Steal and adapt Tom's commit message. ]

Fixes: 7fae4c24a2b8 ("x86: Increase exception stack sizes")
Signed-off-by: Borislav Petkov <bp@suse.de>
Tested-by: Tom Lendacky <thomas.lendacky@amd.com>
Tested-by: Brijesh Singh <brijesh.singh@amd.com>
Link: https://lkml.kernel.org/r/YVt1IMjIs7pIZTRR@zn.tnic
arch/x86/include/asm/cpu_entry_area.h
arch/x86/kernel/sev.c
arch/x86/mm/cpu_entry_area.c