x86/sev-es: Allow copy_from_kernel_nofault() in earlier boot
authorAdam Dunlap <acdunlap@google.com>
Tue, 12 Sep 2023 00:27:02 +0000 (17:27 -0700)
committerIngo Molnar <mingo@kernel.org>
Thu, 28 Sep 2023 20:49:35 +0000 (22:49 +0200)
commitf79936545fb122856bd78b189d3c7ee59928c751
tree0ecbebf171b37820ec7c62c999f03294c301bf70
parentf4c5ca9850124fb5715eff06cffb1beed837500c
x86/sev-es: Allow copy_from_kernel_nofault() in earlier boot

Previously, if copy_from_kernel_nofault() was called before
boot_cpu_data.x86_virt_bits was set up, then it would trigger undefined
behavior due to a shift by 64.

This ended up causing boot failures in the latest version of ubuntu2204
in the gcp project when using SEV-SNP.

Specifically, this function is called during an early #VC handler which
is triggered by a CPUID to check if NX is implemented.

Fixes: 1aa9aa8ee517 ("x86/sev-es: Setup GHCB-based boot #VC handler")
Suggested-by: Dave Hansen <dave.hansen@linux.intel.com>
Signed-off-by: Adam Dunlap <acdunlap@google.com>
Signed-off-by: Ingo Molnar <mingo@kernel.org>
Tested-by: Jacob Xu <jacobhxu@google.com>
Link: https://lore.kernel.org/r/20230912002703.3924521-2-acdunlap@google.com
arch/x86/mm/maccess.c