vmm: simplify VM creation API
Create HypervisorVmConfig early and pass the struct to VM creation API in the vmm crate. Getting rid of multiple conditional parameter. Signed-off-by: Muminul Islam <muislam@microsoft.com>
This commit is contained in:
parent
6897c2a462
commit
deaf660a52
2 changed files with 17 additions and 30 deletions
|
|
@ -210,6 +210,20 @@ pub enum Error {
|
|||
#[error("Error applying landlock")]
|
||||
ApplyLandlock(#[source] LandlockError),
|
||||
}
|
||||
|
||||
impl From<&VmConfig> for hypervisor::HypervisorVmConfig {
|
||||
fn from(_value: &VmConfig) -> Self {
|
||||
hypervisor::HypervisorVmConfig {
|
||||
#[cfg(feature = "tdx")]
|
||||
tdx_enabled: _value.platform.as_ref().map(|p| p.tdx).unwrap_or(false),
|
||||
#[cfg(feature = "sev_snp")]
|
||||
sev_snp_enabled: _value.is_sev_snp_enabled(),
|
||||
#[cfg(feature = "sev_snp")]
|
||||
mem_size: _value.memory.total_size(),
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
pub type Result<T> = result::Result<T, Error>;
|
||||
|
||||
#[derive(Debug, Clone, Copy, PartialEq, Eq)]
|
||||
|
|
@ -1006,12 +1020,7 @@ impl Vmm {
|
|||
|
||||
let vm = Vm::create_hypervisor_vm(
|
||||
self.hypervisor.as_ref(),
|
||||
#[cfg(feature = "tdx")]
|
||||
false,
|
||||
#[cfg(feature = "sev_snp")]
|
||||
false,
|
||||
#[cfg(feature = "sev_snp")]
|
||||
config.lock().unwrap().memory.total_size(),
|
||||
(&*self.vm_config.as_ref().unwrap().lock().unwrap()).into(),
|
||||
)
|
||||
.map_err(|e| {
|
||||
MigratableError::MigrateReceive(anyhow!(
|
||||
|
|
|
|||
|
|
@ -1009,21 +1009,9 @@ impl Vm {
|
|||
vm_config.lock().unwrap().is_tdx_enabled()
|
||||
};
|
||||
|
||||
#[cfg(feature = "sev_snp")]
|
||||
let sev_snp_enabled = if snapshot.is_some() {
|
||||
false
|
||||
} else {
|
||||
vm_config.lock().unwrap().is_sev_snp_enabled()
|
||||
};
|
||||
|
||||
let vm = Self::create_hypervisor_vm(
|
||||
hypervisor.as_ref(),
|
||||
#[cfg(feature = "tdx")]
|
||||
tdx_enabled,
|
||||
#[cfg(feature = "sev_snp")]
|
||||
sev_snp_enabled,
|
||||
#[cfg(feature = "sev_snp")]
|
||||
vm_config.lock().unwrap().memory.total_size(),
|
||||
vm_config.as_ref().lock().unwrap().deref().into(),
|
||||
)?;
|
||||
|
||||
#[cfg(all(feature = "kvm", target_arch = "x86_64"))]
|
||||
|
|
@ -1083,19 +1071,9 @@ impl Vm {
|
|||
|
||||
pub fn create_hypervisor_vm(
|
||||
hypervisor: &dyn hypervisor::Hypervisor,
|
||||
#[cfg(feature = "tdx")] tdx_enabled: bool,
|
||||
#[cfg(feature = "sev_snp")] sev_snp_enabled: bool,
|
||||
#[cfg(feature = "sev_snp")] mem_size: u64,
|
||||
config: HypervisorVmConfig,
|
||||
) -> Result<Arc<dyn hypervisor::Vm>> {
|
||||
hypervisor.check_required_extensions().unwrap();
|
||||
let config = HypervisorVmConfig {
|
||||
#[cfg(feature = "tdx")]
|
||||
tdx_enabled,
|
||||
#[cfg(feature = "sev_snp")]
|
||||
sev_snp_enabled,
|
||||
#[cfg(feature = "sev_snp")]
|
||||
mem_size,
|
||||
};
|
||||
|
||||
let vm = hypervisor.create_vm(config).unwrap();
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue