mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-22 04:25:18 +00:00
docs, conf, schema: add support for shared memory mapping
Signed-off-by: Martin Kletzander <mkletzan@redhat.com>
This commit is contained in:
parent
f864aac90b
commit
def6b35989
@ -1141,7 +1141,7 @@
|
||||
...
|
||||
<numa>
|
||||
<cell id='0' cpus='0-3' memory='512000'/>
|
||||
<cell id='1' cpus='4-7' memory='512000'/>
|
||||
<cell id='1' cpus='4-7' memory='512000' memAccess='shared'/>
|
||||
</numa>
|
||||
...
|
||||
</cpu>
|
||||
@ -1158,6 +1158,11 @@
|
||||
assigned <code>id</code>s in the increasing order starting from
|
||||
0. Mixing cells with and without the <code>id</code> attribute
|
||||
is not recommended as it may result in unwanted behaviour.
|
||||
|
||||
<span class='since'>Since 1.2.9</span> the optional attribute
|
||||
<code>memAccess</code> can control whether the memory is to be
|
||||
mapped as "shared" or "private". This is valid only for
|
||||
hugepages-backed memory.
|
||||
</p>
|
||||
|
||||
<p>
|
||||
|
@ -4030,6 +4030,14 @@
|
||||
<attribute name="memory">
|
||||
<ref name="memoryKB"/>
|
||||
</attribute>
|
||||
<optional>
|
||||
<attribute name="memAccess">
|
||||
<choice>
|
||||
<value>shared</value>
|
||||
<value>private</value>
|
||||
</choice>
|
||||
</attribute>
|
||||
</optional>
|
||||
</element>
|
||||
</define>
|
||||
|
||||
|
@ -56,6 +56,11 @@ VIR_ENUM_IMPL(virCPUFeaturePolicy, VIR_CPU_FEATURE_LAST,
|
||||
"disable",
|
||||
"forbid")
|
||||
|
||||
VIR_ENUM_IMPL(virMemAccess, VIR_MEM_ACCESS_LAST,
|
||||
"default",
|
||||
"shared",
|
||||
"private")
|
||||
|
||||
|
||||
void ATTRIBUTE_NONNULL(1)
|
||||
virCPUDefFreeModel(virCPUDefPtr def)
|
||||
@ -435,7 +440,7 @@ virCPUDefParseXML(xmlNodePtr node,
|
||||
def->ncells = n;
|
||||
|
||||
for (i = 0; i < n; i++) {
|
||||
char *cpus, *memory;
|
||||
char *cpus, *memory, *memAccessStr;
|
||||
int ret, ncpus = 0;
|
||||
unsigned int cur_cell;
|
||||
char *tmp = NULL;
|
||||
@ -491,7 +496,7 @@ virCPUDefParseXML(xmlNodePtr node,
|
||||
goto error;
|
||||
}
|
||||
|
||||
ret = virStrToLong_ui(memory, NULL, 10, &def->cells[cur_cell].mem);
|
||||
ret = virStrToLong_ui(memory, NULL, 10, &def->cells[cur_cell].mem);
|
||||
if (ret == -1) {
|
||||
virReportError(VIR_ERR_XML_ERROR, "%s",
|
||||
_("Invalid 'memory' attribute in NUMA cell"));
|
||||
@ -499,6 +504,22 @@ virCPUDefParseXML(xmlNodePtr node,
|
||||
goto error;
|
||||
}
|
||||
VIR_FREE(memory);
|
||||
|
||||
memAccessStr = virXMLPropString(nodes[i], "memAccess");
|
||||
if (memAccessStr) {
|
||||
def->cells[cur_cell].memAccess =
|
||||
virMemAccessTypeFromString(memAccessStr);
|
||||
|
||||
if (def->cells[cur_cell].memAccess <= 0) {
|
||||
virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
|
||||
_("Invalid 'memAccess' attribute "
|
||||
"value '%s'"),
|
||||
memAccessStr);
|
||||
VIR_FREE(memAccessStr);
|
||||
goto cleanup;
|
||||
}
|
||||
VIR_FREE(memAccessStr);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@ -674,10 +695,15 @@ virCPUDefFormatBuf(virBufferPtr buf,
|
||||
virBufferAddLit(buf, "<numa>\n");
|
||||
virBufferAdjustIndent(buf, 2);
|
||||
for (i = 0; i < def->ncells; i++) {
|
||||
virMemAccess memAccess = def->cells[i].memAccess;
|
||||
|
||||
virBufferAddLit(buf, "<cell");
|
||||
virBufferAsprintf(buf, " id='%zu'", i);
|
||||
virBufferAsprintf(buf, " cpus='%s'", def->cells[i].cpustr);
|
||||
virBufferAsprintf(buf, " memory='%d'", def->cells[i].mem);
|
||||
if (memAccess)
|
||||
virBufferAsprintf(buf, " memAccess='%s'",
|
||||
virMemAccessTypeToString(memAccess));
|
||||
virBufferAddLit(buf, "/>\n");
|
||||
}
|
||||
virBufferAdjustIndent(buf, -2);
|
||||
|
@ -83,6 +83,16 @@ typedef enum {
|
||||
|
||||
VIR_ENUM_DECL(virCPUFeaturePolicy)
|
||||
|
||||
typedef enum {
|
||||
VIR_MEM_ACCESS_DEFAULT,
|
||||
VIR_MEM_ACCESS_SHARED,
|
||||
VIR_MEM_ACCESS_PRIVATE,
|
||||
|
||||
VIR_MEM_ACCESS_LAST,
|
||||
} virMemAccess;
|
||||
|
||||
VIR_ENUM_DECL(virMemAccess)
|
||||
|
||||
typedef struct _virCPUFeatureDef virCPUFeatureDef;
|
||||
typedef virCPUFeatureDef *virCPUFeatureDefPtr;
|
||||
struct _virCPUFeatureDef {
|
||||
@ -93,9 +103,10 @@ struct _virCPUFeatureDef {
|
||||
typedef struct _virCellDef virCellDef;
|
||||
typedef virCellDef *virCellDefPtr;
|
||||
struct _virCellDef {
|
||||
virBitmapPtr cpumask; /* CPUs that are part of this node */
|
||||
char *cpustr; /* CPUs stored in string form for dumpxml */
|
||||
unsigned int mem; /* Node memory in kB */
|
||||
virBitmapPtr cpumask; /* CPUs that are part of this node */
|
||||
char *cpustr; /* CPUs stored in string form for dumpxml */
|
||||
unsigned int mem; /* Node memory in kB */
|
||||
virMemAccess memAccess;
|
||||
};
|
||||
|
||||
typedef struct _virCPUDef virCPUDef;
|
||||
|
28
tests/qemuxml2argvdata/qemuxml2argv-cpu-numa-memshared.xml
Normal file
28
tests/qemuxml2argvdata/qemuxml2argv-cpu-numa-memshared.xml
Normal file
@ -0,0 +1,28 @@
|
||||
<domain type='qemu'>
|
||||
<name>QEMUGuest1</name>
|
||||
<uuid>c7a5fdbd-edaf-9455-926a-d65c16db1809</uuid>
|
||||
<memory unit='KiB'>219100</memory>
|
||||
<currentMemory unit='KiB'>219100</currentMemory>
|
||||
<vcpu placement='static'>16</vcpu>
|
||||
<os>
|
||||
<type arch='x86_64' machine='pc'>hvm</type>
|
||||
<boot dev='network'/>
|
||||
</os>
|
||||
<cpu>
|
||||
<topology sockets='2' cores='4' threads='2'/>
|
||||
<numa>
|
||||
<cell id='0' cpus='0-7' memory='109550' memAccess='shared'/>
|
||||
<cell id='1' cpus='8-15' memory='109550' memAccess='private'/>
|
||||
</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</emulator>
|
||||
<controller type='usb' index='0'/>
|
||||
<controller type='pci' index='0' model='pci-root'/>
|
||||
<memballoon model='virtio'/>
|
||||
</devices>
|
||||
</domain>
|
45
tests/qemuxml2argvdata/qemuxml2argv-hugepages-shared.xml
Normal file
45
tests/qemuxml2argvdata/qemuxml2argv-hugepages-shared.xml
Normal file
@ -0,0 +1,45 @@
|
||||
<domain type='qemu'>
|
||||
<name>QEMUGuest1</name>
|
||||
<uuid>c7a5fdbd-edaf-9455-926a-d65c16db1809</uuid>
|
||||
<memory unit='KiB'>4194304</memory>
|
||||
<currentMemory unit='KiB'>4194304</currentMemory>
|
||||
<memoryBacking>
|
||||
<hugepages>
|
||||
<page size='2048' unit='KiB' nodeset='1'/>
|
||||
<page size='1048576' unit='KiB' nodeset='0,2-3'/>
|
||||
</hugepages>
|
||||
</memoryBacking>
|
||||
<vcpu placement='static'>4</vcpu>
|
||||
<numatune>
|
||||
<memory mode='strict' nodeset='0-3'/>
|
||||
<memnode cellid='3' mode='strict' nodeset='3'/>
|
||||
</numatune>
|
||||
<os>
|
||||
<type arch='i686' machine='pc'>hvm</type>
|
||||
<boot dev='hd'/>
|
||||
</os>
|
||||
<cpu>
|
||||
<numa>
|
||||
<cell id='0' cpus='0' memory='1048576'/>
|
||||
<cell id='1' cpus='1' memory='1048576' memAccess='shared'/>
|
||||
<cell id='2' cpus='2' memory='1048576' memAccess='private'/>
|
||||
<cell id='3' cpus='3' memory='1048576'/>
|
||||
</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</emulator>
|
||||
<disk type='block' device='disk'>
|
||||
<source dev='/dev/HostVG/QEMUGuest1'/>
|
||||
<target dev='hda' bus='ide'/>
|
||||
<address type='drive' controller='0' bus='0' target='0' unit='0'/>
|
||||
</disk>
|
||||
<controller type='usb' index='0'/>
|
||||
<controller type='ide' index='0'/>
|
||||
<controller type='pci' index='0' model='pci-root'/>
|
||||
<memballoon model='virtio'/>
|
||||
</devices>
|
||||
</domain>
|
@ -205,6 +205,7 @@ mymain(void)
|
||||
DO_TEST("hugepages-pages");
|
||||
DO_TEST("hugepages-pages2");
|
||||
DO_TEST("hugepages-pages3");
|
||||
DO_TEST("hugepages-shared");
|
||||
DO_TEST("nosharepages");
|
||||
DO_TEST("disk-aio");
|
||||
DO_TEST("disk-cdrom");
|
||||
@ -392,6 +393,7 @@ mymain(void)
|
||||
DO_TEST_DIFFERENT("cpu-numa1");
|
||||
DO_TEST_DIFFERENT("cpu-numa2");
|
||||
DO_TEST("cpu-numa-disjoint");
|
||||
DO_TEST("cpu-numa-memshared");
|
||||
|
||||
DO_TEST_DIFFERENT("numatune-auto-prefer");
|
||||
DO_TEST_DIFFERENT("numatune-memnode");
|
||||
|
Loading…
x
Reference in New Issue
Block a user