mirror of
https://github.com/cloud-hypervisor/cloud-hypervisor.git
synced 2025-01-10 14:47:42 +00:00
vmm: Enable provisioning for SGX guest
The guest can see that SGX supports provisioning as it is exposed through the CPUID. This patch enables the proper backing of this feature by having the host open the provisioning device and enable this capability through the hypervisor. Signed-off-by: Sebastien Boeuf <sebastien.boeuf@intel.com>
This commit is contained in:
parent
9ec0c981f8
commit
17c99ae00a
@ -213,6 +213,14 @@ pub enum Error {
|
|||||||
#[cfg(target_arch = "x86_64")]
|
#[cfg(target_arch = "x86_64")]
|
||||||
SgxVirtEpcFileSetLen(io::Error),
|
SgxVirtEpcFileSetLen(io::Error),
|
||||||
|
|
||||||
|
/// Failed opening SGX provisioning device
|
||||||
|
#[cfg(target_arch = "x86_64")]
|
||||||
|
SgxProvisionOpen(io::Error),
|
||||||
|
|
||||||
|
/// Failed enabling SGX provisioning
|
||||||
|
#[cfg(target_arch = "x86_64")]
|
||||||
|
SgxEnableProvisioning(hypervisor::HypervisorVmError),
|
||||||
|
|
||||||
/// Failed creating a new MmapRegion instance.
|
/// Failed creating a new MmapRegion instance.
|
||||||
#[cfg(target_arch = "x86_64")]
|
#[cfg(target_arch = "x86_64")]
|
||||||
NewMmapRegion(vm_memory::mmap::MmapRegionError),
|
NewMmapRegion(vm_memory::mmap::MmapRegionError),
|
||||||
@ -1370,7 +1378,18 @@ impl MemoryManager {
|
|||||||
}
|
}
|
||||||
|
|
||||||
#[cfg(target_arch = "x86_64")]
|
#[cfg(target_arch = "x86_64")]
|
||||||
pub fn setup_sgx(&mut self, sgx_epc_config: Vec<SgxEpcConfig>) -> Result<(), Error> {
|
pub fn setup_sgx(
|
||||||
|
&mut self,
|
||||||
|
sgx_epc_config: Vec<SgxEpcConfig>,
|
||||||
|
vm: &Arc<dyn hypervisor::Vm>,
|
||||||
|
) -> Result<(), Error> {
|
||||||
|
let file = OpenOptions::new()
|
||||||
|
.read(true)
|
||||||
|
.open("/dev/sgx_provision")
|
||||||
|
.map_err(Error::SgxProvisionOpen)?;
|
||||||
|
vm.enable_sgx_attribute(file)
|
||||||
|
.map_err(Error::SgxEnableProvisioning)?;
|
||||||
|
|
||||||
// Go over each EPC section and verify its size is a 4k multiple. At
|
// Go over each EPC section and verify its size is a 4k multiple. At
|
||||||
// the same time, calculate the total size needed for the contiguous
|
// the same time, calculate the total size needed for the contiguous
|
||||||
// EPC region.
|
// EPC region.
|
||||||
|
@ -724,7 +724,7 @@ impl Vm {
|
|||||||
memory_manager
|
memory_manager
|
||||||
.lock()
|
.lock()
|
||||||
.unwrap()
|
.unwrap()
|
||||||
.setup_sgx(sgx_epc_config)
|
.setup_sgx(sgx_epc_config, &vm)
|
||||||
.map_err(Error::MemoryManager)?;
|
.map_err(Error::MemoryManager)?;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user