From ea1a05f846c6b06139b80fae4d25a1ad907c89ae Mon Sep 17 00:00:00 2001 From: Bo Chen Date: Mon, 22 May 2023 15:44:29 -0700 Subject: [PATCH] vmm: Allocate guest memory address space before TDX initialization The refactoring on deferring address space allocation (#5169) broke TDX, as TDX initialization needs to access guest memory for encryption and measurement of guest pages. Signed-off-by: Bo Chen --- vmm/src/vm.rs | 24 ++++++++++++------------ 1 file changed, 12 insertions(+), 12 deletions(-) diff --git a/vmm/src/vm.rs b/vmm/src/vm.rs index 5723e4915..683946f5f 100644 --- a/vmm/src/vm.rs +++ b/vmm/src/vm.rs @@ -2004,6 +2004,18 @@ impl Vm { }) .transpose()?; + #[cfg(target_arch = "x86_64")] + // Note: For x86, always call this function before invoking start boot vcpus. + // Otherwise guest would fail to boot because we haven't created the + // userspace mappings to update the hypervisor about the memory mappings. + // These mappings must be created before we start the vCPU threads for + // the very first time. + self.memory_manager + .lock() + .unwrap() + .allocate_address_space() + .map_err(Error::MemoryManager)?; + #[cfg(feature = "tdx")] if let Some(hob_address) = hob_address { // With the HOB address extracted the vCPUs can have @@ -2021,18 +2033,6 @@ impl Vm { self.vm.tdx_finalize().map_err(Error::FinalizeTdx)?; } - #[cfg(target_arch = "x86_64")] - // Note: For x86, always call this function before invoking start boot vcpus. - // Otherwise guest would fail to boot because we haven't created the - // userspace mappings to update the hypervisor about the memory mappings. - // These mappings must be created before we start the vCPU threads for - // the very first time. - self.memory_manager - .lock() - .unwrap() - .allocate_address_space() - .map_err(Error::MemoryManager)?; - self.cpu_manager .lock() .unwrap()