mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-11 09:17:52 +03:00
conf: Introduce SGX EPC element into device memory xml
<devices> ... <memory model='sgx-epc'> <source> <nodemask>0-1</nodemask> </source> <target> <size unit='KiB'>512</size> <node>0</node> </target> </memory> ... </devices> Signed-off-by: Lin Yang <lin.a.yang@intel.com> Signed-off-by: Michal Privoznik <mprivozn@redhat.com> Signed-off-by: Haibin Huang <haibin.huang@intel.com> Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
This commit is contained in:
parent
8db09767a9
commit
facadf2491
@ -8002,6 +8002,20 @@ Example: usage of the memory devices
|
|||||||
<current unit='KiB'>524288</current>
|
<current unit='KiB'>524288</current>
|
||||||
</target>
|
</target>
|
||||||
</memory>
|
</memory>
|
||||||
|
<memory model='sgx-epc'>
|
||||||
|
<source>
|
||||||
|
<nodemask>0-1</nodemask>
|
||||||
|
</source>
|
||||||
|
<target>
|
||||||
|
<size unit='KiB'>16384</size>
|
||||||
|
<node>0</node>
|
||||||
|
</target>
|
||||||
|
</memory>
|
||||||
|
<memory model='sgx-epc'>
|
||||||
|
<target>
|
||||||
|
<size unit='KiB'>16384</size>
|
||||||
|
</target>
|
||||||
|
</memory>
|
||||||
</devices>
|
</devices>
|
||||||
...
|
...
|
||||||
|
|
||||||
@ -8010,7 +8024,9 @@ Example: usage of the memory devices
|
|||||||
1.2.14` Provide ``nvdimm`` model that adds a Non-Volatile DIMM module.
|
1.2.14` Provide ``nvdimm`` model that adds a Non-Volatile DIMM module.
|
||||||
:since:`Since 3.2.0` Provide ``virtio-pmem`` model to add a paravirtualized
|
:since:`Since 3.2.0` Provide ``virtio-pmem`` model to add a paravirtualized
|
||||||
persistent memory device. :since:`Since 7.1.0` Provide ``virtio-mem`` model
|
persistent memory device. :since:`Since 7.1.0` Provide ``virtio-mem`` model
|
||||||
to add paravirtualized memory device. :since:`Since 7.9.0`
|
to add paravirtualized memory device. :since:`Since 7.9.0` Provide
|
||||||
|
``sgx-epc`` model to add a SGX enclave page cache (EPC) memory to the guest.
|
||||||
|
:since:`Since 8.10.0 and QEMU 7.0.0`
|
||||||
|
|
||||||
``access``
|
``access``
|
||||||
An optional attribute ``access`` ( :since:`since 3.2.0` ) that provides
|
An optional attribute ``access`` ( :since:`since 3.2.0` ) that provides
|
||||||
@ -8070,6 +8086,13 @@ Example: usage of the memory devices
|
|||||||
Represents a path in the host that backs the virtio memory module in the
|
Represents a path in the host that backs the virtio memory module in the
|
||||||
guest. It is mandatory.
|
guest. It is mandatory.
|
||||||
|
|
||||||
|
For model ``sgx-epc`` this element is optional. The following optional
|
||||||
|
elements may be used:
|
||||||
|
|
||||||
|
``nodemask``
|
||||||
|
This element can be used to override the default set of NUMA nodes where
|
||||||
|
the memory would be allocated. :since:`Since 8.10.0 and QEMU 7.0.0`
|
||||||
|
|
||||||
``target``
|
``target``
|
||||||
The mandatory ``target`` element configures the placement and sizing of the
|
The mandatory ``target`` element configures the placement and sizing of the
|
||||||
added memory from the perspective of the guest.
|
added memory from the perspective of the guest.
|
||||||
|
@ -1444,6 +1444,7 @@ VIR_ENUM_IMPL(virDomainMemoryModel,
|
|||||||
"nvdimm",
|
"nvdimm",
|
||||||
"virtio-pmem",
|
"virtio-pmem",
|
||||||
"virtio-mem",
|
"virtio-mem",
|
||||||
|
"sgx-epc",
|
||||||
);
|
);
|
||||||
|
|
||||||
VIR_ENUM_IMPL(virDomainShmemModel,
|
VIR_ENUM_IMPL(virDomainShmemModel,
|
||||||
@ -13054,6 +13055,20 @@ virDomainMemorySourceDefParseXML(xmlNodePtr node,
|
|||||||
def->nvdimmPath = virXPathString("string(./path)", ctxt);
|
def->nvdimmPath = virXPathString("string(./path)", ctxt);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case VIR_DOMAIN_MEMORY_MODEL_SGX_EPC:
|
||||||
|
if ((nodemask = virXPathString("string(./nodemask)", ctxt))) {
|
||||||
|
if (virBitmapParse(nodemask, &def->sourceNodes,
|
||||||
|
VIR_DOMAIN_CPUMASK_LEN) < 0)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
if (virBitmapIsAllClear(def->sourceNodes)) {
|
||||||
|
virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
|
||||||
|
_("Invalid value of 'nodemask': %s"), nodemask);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
||||||
break;
|
break;
|
||||||
@ -13122,6 +13137,7 @@ virDomainMemoryTargetDefParseXML(xmlNodePtr node,
|
|||||||
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_DIMM:
|
case VIR_DOMAIN_MEMORY_MODEL_DIMM:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_VIRTIO_PMEM:
|
case VIR_DOMAIN_MEMORY_MODEL_VIRTIO_PMEM:
|
||||||
|
case VIR_DOMAIN_MEMORY_MODEL_SGX_EPC:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -14918,6 +14934,11 @@ virDomainMemoryFindByDefInternal(virDomainDef *def,
|
|||||||
continue;
|
continue;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case VIR_DOMAIN_MEMORY_MODEL_SGX_EPC:
|
||||||
|
if (!virBitmapEqual(tmp->sourceNodes, mem->sourceNodes))
|
||||||
|
continue;
|
||||||
|
break;
|
||||||
|
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
||||||
break;
|
break;
|
||||||
@ -24535,6 +24556,15 @@ virDomainMemorySourceDefFormat(virBuffer *buf,
|
|||||||
virBufferEscapeString(&childBuf, "<path>%s</path>\n", def->nvdimmPath);
|
virBufferEscapeString(&childBuf, "<path>%s</path>\n", def->nvdimmPath);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case VIR_DOMAIN_MEMORY_MODEL_SGX_EPC:
|
||||||
|
if (def->sourceNodes) {
|
||||||
|
if (!(bitmap = virBitmapFormat(def->sourceNodes)))
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
virBufferAsprintf(&childBuf, "<nodemask>%s</nodemask>\n", bitmap);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
||||||
break;
|
break;
|
||||||
|
@ -2585,6 +2585,7 @@ typedef enum {
|
|||||||
VIR_DOMAIN_MEMORY_MODEL_NVDIMM, /* nvdimm memory device */
|
VIR_DOMAIN_MEMORY_MODEL_NVDIMM, /* nvdimm memory device */
|
||||||
VIR_DOMAIN_MEMORY_MODEL_VIRTIO_PMEM, /* virtio-pmem memory device */
|
VIR_DOMAIN_MEMORY_MODEL_VIRTIO_PMEM, /* virtio-pmem memory device */
|
||||||
VIR_DOMAIN_MEMORY_MODEL_VIRTIO_MEM, /* virtio-mem memory device */
|
VIR_DOMAIN_MEMORY_MODEL_VIRTIO_MEM, /* virtio-mem memory device */
|
||||||
|
VIR_DOMAIN_MEMORY_MODEL_SGX_EPC, /* SGX enclave page cache */
|
||||||
|
|
||||||
VIR_DOMAIN_MEMORY_MODEL_LAST
|
VIR_DOMAIN_MEMORY_MODEL_LAST
|
||||||
} virDomainMemoryModel;
|
} virDomainMemoryModel;
|
||||||
|
@ -645,6 +645,7 @@ virDomainMemoryDefPostParse(virDomainMemoryDef *mem,
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_VIRTIO_MEM:
|
case VIR_DOMAIN_MEMORY_MODEL_VIRTIO_MEM:
|
||||||
|
case VIR_DOMAIN_MEMORY_MODEL_SGX_EPC:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_DIMM:
|
case VIR_DOMAIN_MEMORY_MODEL_DIMM:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
||||||
|
@ -2360,6 +2360,15 @@ virDomainMemoryDefValidate(const virDomainMemoryDef *mem,
|
|||||||
case VIR_DOMAIN_MEMORY_MODEL_DIMM:
|
case VIR_DOMAIN_MEMORY_MODEL_DIMM:
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case VIR_DOMAIN_MEMORY_MODEL_SGX_EPC:
|
||||||
|
if (mem->info.type != VIR_DOMAIN_DEVICE_ADDRESS_TYPE_NONE) {
|
||||||
|
virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
|
||||||
|
_("memory device address is not supported for model '%s'"),
|
||||||
|
virDomainMemoryModelTypeToString(mem->model));
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
||||||
default:
|
default:
|
||||||
|
@ -6909,6 +6909,7 @@
|
|||||||
<value>nvdimm</value>
|
<value>nvdimm</value>
|
||||||
<value>virtio-pmem</value>
|
<value>virtio-pmem</value>
|
||||||
<value>virtio-mem</value>
|
<value>virtio-mem</value>
|
||||||
|
<value>sgx-epc</value>
|
||||||
</choice>
|
</choice>
|
||||||
</attribute>
|
</attribute>
|
||||||
<optional>
|
<optional>
|
||||||
|
@ -513,6 +513,9 @@ qemuAssignDeviceMemoryAlias(virDomainDef *def,
|
|||||||
case VIR_DOMAIN_MEMORY_MODEL_VIRTIO_MEM:
|
case VIR_DOMAIN_MEMORY_MODEL_VIRTIO_MEM:
|
||||||
prefix = "virtiomem";
|
prefix = "virtiomem";
|
||||||
break;
|
break;
|
||||||
|
case VIR_DOMAIN_MEMORY_MODEL_SGX_EPC:
|
||||||
|
prefix = "epc";
|
||||||
|
break;
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
||||||
default:
|
default:
|
||||||
|
@ -3562,6 +3562,7 @@ qemuBuildMemoryDeviceProps(virQEMUDriverConfig *cfg,
|
|||||||
return NULL;
|
return NULL;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case VIR_DOMAIN_MEMORY_MODEL_SGX_EPC:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
||||||
default:
|
default:
|
||||||
|
@ -8383,6 +8383,7 @@ qemuDomainUpdateMemoryDeviceInfo(virDomainObj *vm,
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_VIRTIO_PMEM:
|
case VIR_DOMAIN_MEMORY_MODEL_VIRTIO_PMEM:
|
||||||
|
case VIR_DOMAIN_MEMORY_MODEL_SGX_EPC:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
||||||
break;
|
break;
|
||||||
@ -9064,6 +9065,12 @@ qemuDomainDefValidateMemoryHotplugDevice(const virDomainMemoryDef *mem,
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case VIR_DOMAIN_MEMORY_MODEL_SGX_EPC:
|
||||||
|
virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
|
||||||
|
_("hotplug is not supported for the %s device"),
|
||||||
|
virDomainMemoryModelTypeToString(mem->model));
|
||||||
|
return -1;
|
||||||
|
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
||||||
return -1;
|
return -1;
|
||||||
@ -9148,10 +9155,23 @@ qemuDomainDefValidateMemoryHotplug(const virDomainDef *def,
|
|||||||
for (i = 0; i < def->nmems; i++) {
|
for (i = 0; i < def->nmems; i++) {
|
||||||
hotplugMemory += def->mems[i]->size;
|
hotplugMemory += def->mems[i]->size;
|
||||||
|
|
||||||
|
switch (def->mems[i]->model) {
|
||||||
|
case VIR_DOMAIN_MEMORY_MODEL_DIMM:
|
||||||
|
case VIR_DOMAIN_MEMORY_MODEL_NVDIMM:
|
||||||
|
case VIR_DOMAIN_MEMORY_MODEL_VIRTIO_PMEM:
|
||||||
|
case VIR_DOMAIN_MEMORY_MODEL_VIRTIO_MEM:
|
||||||
/* already existing devices don't need to be checked on hotplug */
|
/* already existing devices don't need to be checked on hotplug */
|
||||||
if (!mem &&
|
if (!mem &&
|
||||||
qemuDomainDefValidateMemoryHotplugDevice(def->mems[i], def) < 0)
|
qemuDomainDefValidateMemoryHotplugDevice(def->mems[i], def) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case VIR_DOMAIN_MEMORY_MODEL_SGX_EPC:
|
||||||
|
/* sgx epc memory does not support hotplug, skip this check */
|
||||||
|
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
||||||
|
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hotplugMemory > hotplugSpace) {
|
if (hotplugMemory > hotplugSpace) {
|
||||||
|
@ -389,6 +389,7 @@ qemuDomainPrimeVirtioDeviceAddresses(virDomainDef *def,
|
|||||||
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_DIMM:
|
case VIR_DOMAIN_MEMORY_MODEL_DIMM:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_NVDIMM:
|
case VIR_DOMAIN_MEMORY_MODEL_NVDIMM:
|
||||||
|
case VIR_DOMAIN_MEMORY_MODEL_SGX_EPC:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -1038,6 +1039,7 @@ qemuDomainDeviceCalculatePCIConnectFlags(virDomainDeviceDef *dev,
|
|||||||
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_DIMM:
|
case VIR_DOMAIN_MEMORY_MODEL_DIMM:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_NVDIMM:
|
case VIR_DOMAIN_MEMORY_MODEL_NVDIMM:
|
||||||
|
case VIR_DOMAIN_MEMORY_MODEL_SGX_EPC:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -2420,6 +2422,7 @@ qemuDomainAssignDevicePCISlots(virDomainDef *def,
|
|||||||
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_DIMM:
|
case VIR_DOMAIN_MEMORY_MODEL_DIMM:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_NVDIMM:
|
case VIR_DOMAIN_MEMORY_MODEL_NVDIMM:
|
||||||
|
case VIR_DOMAIN_MEMORY_MODEL_SGX_EPC:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -3080,6 +3083,7 @@ qemuDomainAssignMemoryDeviceSlot(virDomainObj *vm,
|
|||||||
return qemuDomainEnsurePCIAddress(vm, &dev);
|
return qemuDomainEnsurePCIAddress(vm, &dev);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case VIR_DOMAIN_MEMORY_MODEL_SGX_EPC:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
||||||
break;
|
break;
|
||||||
@ -3106,6 +3110,7 @@ qemuDomainReleaseMemoryDeviceSlot(virDomainObj *vm,
|
|||||||
qemuDomainReleaseDeviceAddress(vm, &mem->info);
|
qemuDomainReleaseDeviceAddress(vm, &mem->info);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case VIR_DOMAIN_MEMORY_MODEL_SGX_EPC:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
||||||
break;
|
break;
|
||||||
@ -3139,6 +3144,7 @@ qemuDomainAssignMemorySlots(virDomainDef *def)
|
|||||||
case VIR_DOMAIN_MEMORY_MODEL_VIRTIO_MEM:
|
case VIR_DOMAIN_MEMORY_MODEL_VIRTIO_MEM:
|
||||||
/* handled in qemuDomainAssignPCIAddresses() */
|
/* handled in qemuDomainAssignPCIAddresses() */
|
||||||
break;
|
break;
|
||||||
|
case VIR_DOMAIN_MEMORY_MODEL_SGX_EPC:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
||||||
break;
|
break;
|
||||||
|
@ -6831,6 +6831,7 @@ qemuDomainChangeMemoryLiveValidateChange(const virDomainMemoryDef *oldDef,
|
|||||||
case VIR_DOMAIN_MEMORY_MODEL_DIMM:
|
case VIR_DOMAIN_MEMORY_MODEL_DIMM:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_NVDIMM:
|
case VIR_DOMAIN_MEMORY_MODEL_NVDIMM:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_VIRTIO_PMEM:
|
case VIR_DOMAIN_MEMORY_MODEL_VIRTIO_PMEM:
|
||||||
|
case VIR_DOMAIN_MEMORY_MODEL_SGX_EPC:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
||||||
virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
|
virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
|
||||||
_("cannot modify memory of model '%s'"),
|
_("cannot modify memory of model '%s'"),
|
||||||
|
@ -3871,6 +3871,7 @@ qemuProcessDomainMemoryDefNeedHugepagesPath(const virDomainMemoryDef *mem,
|
|||||||
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_NVDIMM:
|
case VIR_DOMAIN_MEMORY_MODEL_NVDIMM:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_VIRTIO_PMEM:
|
case VIR_DOMAIN_MEMORY_MODEL_VIRTIO_PMEM:
|
||||||
|
case VIR_DOMAIN_MEMORY_MODEL_SGX_EPC:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
||||||
/* None of these can be backed by hugepages. */
|
/* None of these can be backed by hugepages. */
|
||||||
return false;
|
return false;
|
||||||
@ -3955,6 +3956,7 @@ qemuProcessNeedMemoryBackingPath(virDomainDef *def,
|
|||||||
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_NVDIMM:
|
case VIR_DOMAIN_MEMORY_MODEL_NVDIMM:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_VIRTIO_PMEM:
|
case VIR_DOMAIN_MEMORY_MODEL_VIRTIO_PMEM:
|
||||||
|
case VIR_DOMAIN_MEMORY_MODEL_SGX_EPC:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
||||||
/* Backed by user provided path. Not stored in memory
|
/* Backed by user provided path. Not stored in memory
|
||||||
* backing dir anyway. */
|
* backing dir anyway. */
|
||||||
|
@ -5025,6 +5025,14 @@ qemuValidateDomainDeviceDefMemory(virDomainMemoryDef *mem,
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case VIR_DOMAIN_MEMORY_MODEL_SGX_EPC:
|
||||||
|
if (!virQEMUCapsGet(qemuCaps, QEMU_CAPS_SGX_EPC)) {
|
||||||
|
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
|
||||||
|
_("sgx epc isn't supported by this QEMU binary"));
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
||||||
break;
|
break;
|
||||||
|
@ -687,6 +687,7 @@ AppArmorSetMemoryLabel(virSecurityManager *mgr,
|
|||||||
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_DIMM:
|
case VIR_DOMAIN_MEMORY_MODEL_DIMM:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_VIRTIO_MEM:
|
case VIR_DOMAIN_MEMORY_MODEL_VIRTIO_MEM:
|
||||||
|
case VIR_DOMAIN_MEMORY_MODEL_SGX_EPC:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -1853,6 +1853,7 @@ virSecurityDACRestoreMemoryLabel(virSecurityManager *mgr,
|
|||||||
|
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_DIMM:
|
case VIR_DOMAIN_MEMORY_MODEL_DIMM:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_VIRTIO_MEM:
|
case VIR_DOMAIN_MEMORY_MODEL_VIRTIO_MEM:
|
||||||
|
case VIR_DOMAIN_MEMORY_MODEL_SGX_EPC:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
||||||
ret = 0;
|
ret = 0;
|
||||||
@ -2040,6 +2041,7 @@ virSecurityDACSetMemoryLabel(virSecurityManager *mgr,
|
|||||||
|
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_DIMM:
|
case VIR_DOMAIN_MEMORY_MODEL_DIMM:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_VIRTIO_MEM:
|
case VIR_DOMAIN_MEMORY_MODEL_VIRTIO_MEM:
|
||||||
|
case VIR_DOMAIN_MEMORY_MODEL_SGX_EPC:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
||||||
ret = 0;
|
ret = 0;
|
||||||
|
@ -1580,6 +1580,7 @@ virSecuritySELinuxSetMemoryLabel(virSecurityManager *mgr,
|
|||||||
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_DIMM:
|
case VIR_DOMAIN_MEMORY_MODEL_DIMM:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_VIRTIO_MEM:
|
case VIR_DOMAIN_MEMORY_MODEL_VIRTIO_MEM:
|
||||||
|
case VIR_DOMAIN_MEMORY_MODEL_SGX_EPC:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -1608,6 +1609,7 @@ virSecuritySELinuxRestoreMemoryLabel(virSecurityManager *mgr,
|
|||||||
|
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_DIMM:
|
case VIR_DOMAIN_MEMORY_MODEL_DIMM:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_VIRTIO_MEM:
|
case VIR_DOMAIN_MEMORY_MODEL_VIRTIO_MEM:
|
||||||
|
case VIR_DOMAIN_MEMORY_MODEL_SGX_EPC:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
case VIR_DOMAIN_MEMORY_MODEL_NONE:
|
||||||
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
case VIR_DOMAIN_MEMORY_MODEL_LAST:
|
||||||
ret = 0;
|
ret = 0;
|
||||||
|
65
tests/qemuxml2argvdata/sgx-epc.xml
Normal file
65
tests/qemuxml2argvdata/sgx-epc.xml
Normal file
@ -0,0 +1,65 @@
|
|||||||
|
<domain type='qemu'>
|
||||||
|
<name>QEMUGuest1</name>
|
||||||
|
<uuid>c7a5fdbd-edaf-9455-926a-d65c16db1809</uuid>
|
||||||
|
<maxMemory slots='16' unit='KiB'>1130496</maxMemory>
|
||||||
|
<memory unit='KiB'>1048576</memory>
|
||||||
|
<currentMemory unit='KiB'>1048576</currentMemory>
|
||||||
|
<vcpu placement='static'>2</vcpu>
|
||||||
|
<os>
|
||||||
|
<type arch='x86_64' machine='pc-q35-7.0'>hvm</type>
|
||||||
|
<boot dev='hd'/>
|
||||||
|
</os>
|
||||||
|
<cpu mode='custom' match='exact' check='none'>
|
||||||
|
<model fallback='forbid'>qemu64</model>
|
||||||
|
<numa>
|
||||||
|
<cell id='0' cpus='0' memory='524288' unit='KiB'/>
|
||||||
|
<cell id='1' cpus='1' memory='524288' unit='KiB'/>
|
||||||
|
</numa>
|
||||||
|
</cpu>
|
||||||
|
<clock offset='utc'/>
|
||||||
|
<on_poweroff>destroy</on_poweroff>
|
||||||
|
<on_reboot>restart</on_reboot>
|
||||||
|
<on_crash>destroy</on_crash>
|
||||||
|
<devices>
|
||||||
|
<emulator>/usr/bin/qemu-system-x86_64</emulator>
|
||||||
|
<controller type='pci' index='0' model='pcie-root'/>
|
||||||
|
<controller type='pci' index='1' model='pcie-root-port'>
|
||||||
|
<model name='pcie-root-port'/>
|
||||||
|
<target chassis='1' port='0x8'/>
|
||||||
|
<address type='pci' domain='0x0000' bus='0x00' slot='0x01' function='0x0' multifunction='on'/>
|
||||||
|
</controller>
|
||||||
|
<controller type='pci' index='2' model='pcie-root-port'>
|
||||||
|
<model name='pcie-root-port'/>
|
||||||
|
<target chassis='2' port='0x9'/>
|
||||||
|
<address type='pci' domain='0x0000' bus='0x00' slot='0x01' function='0x1'/>
|
||||||
|
</controller>
|
||||||
|
<controller type='usb' index='0' model='none'/>
|
||||||
|
<controller type='sata' index='0'>
|
||||||
|
<address type='pci' domain='0x0000' bus='0x00' slot='0x1f' function='0x2'/>
|
||||||
|
</controller>
|
||||||
|
<input type='mouse' bus='ps2'/>
|
||||||
|
<input type='keyboard' bus='ps2'/>
|
||||||
|
<audio id='1' type='none'/>
|
||||||
|
<memballoon model='virtio'>
|
||||||
|
<address type='pci' domain='0x0000' bus='0x01' slot='0x00' function='0x0'/>
|
||||||
|
</memballoon>
|
||||||
|
<memory model='sgx-epc'>
|
||||||
|
<source>
|
||||||
|
<nodemask>0-1</nodemask>
|
||||||
|
</source>
|
||||||
|
<target>
|
||||||
|
<size unit='KiB'>65536</size>
|
||||||
|
<node>0</node>
|
||||||
|
</target>
|
||||||
|
</memory>
|
||||||
|
<memory model='sgx-epc'>
|
||||||
|
<source>
|
||||||
|
<nodemask>0-1</nodemask>
|
||||||
|
</source>
|
||||||
|
<target>
|
||||||
|
<size unit='KiB'>16384</size>
|
||||||
|
<node>1</node>
|
||||||
|
</target>
|
||||||
|
</memory>
|
||||||
|
</devices>
|
||||||
|
</domain>
|
1
tests/qemuxml2xmloutdata/sgx-epc.x86_64-7.0.0.xml
Symbolic link
1
tests/qemuxml2xmloutdata/sgx-epc.x86_64-7.0.0.xml
Symbolic link
@ -0,0 +1 @@
|
|||||||
|
../qemuxml2argvdata/sgx-epc.xml
|
@ -1295,6 +1295,8 @@ mymain(void)
|
|||||||
DO_TEST_CAPS_LATEST("channel-qemu-vdagent");
|
DO_TEST_CAPS_LATEST("channel-qemu-vdagent");
|
||||||
DO_TEST_CAPS_LATEST("channel-qemu-vdagent-features");
|
DO_TEST_CAPS_LATEST("channel-qemu-vdagent-features");
|
||||||
|
|
||||||
|
DO_TEST_CAPS_VER("sgx-epc", "7.0.0");
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
if (getenv("LIBVIRT_SKIP_CLEANUP") == NULL)
|
if (getenv("LIBVIRT_SKIP_CLEANUP") == NULL)
|
||||||
virFileDeleteTree(fakerootdir);
|
virFileDeleteTree(fakerootdir);
|
||||||
|
Loading…
Reference in New Issue
Block a user