mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-05 04:25:19 +00:00
qemu: Only use memory-backend-file with NUMA if needed
If this reminds you of a commit message from around a year ago, it's41c2aa729f
and yes, we're dealing with "the same thing" again. Orf309db1f4d
and it's similar. There is a logic in place that if there is no real need for memory-backend-file, qemuBuildMemoryBackendStr() returns 0. However that wasn't the case with hugepage backing. The reason for that was that we abused the 'pagesize' variable for storing that information, but we should rather have a separate one that specifies whether we really need the new object for hugepage backing. And that variable should be set only if this particular NUMA cell needs special treatment WRT hugepages. Resolves: https://bugzilla.redhat.com/show_bug.cgi?id=1372153 Signed-off-by: Martin Kletzander <mkletzan@redhat.com> (cherry picked from commit 4372a7845acbc6974f6027ef68e7dd3eeb47f425)
This commit is contained in:
parent
cbdeac8898
commit
135ae6d50c
@ -3013,6 +3013,7 @@ qemuBuildMemoryBackendStr(unsigned long long size,
|
|||||||
int ret = -1;
|
int ret = -1;
|
||||||
virJSONValuePtr props = NULL;
|
virJSONValuePtr props = NULL;
|
||||||
bool nodeSpecified = virDomainNumatuneNodeSpecified(def->numa, guestNode);
|
bool nodeSpecified = virDomainNumatuneNodeSpecified(def->numa, guestNode);
|
||||||
|
bool needHugepage = !!pagesize;
|
||||||
|
|
||||||
*backendProps = NULL;
|
*backendProps = NULL;
|
||||||
*backendType = NULL;
|
*backendType = NULL;
|
||||||
@ -3035,10 +3036,10 @@ qemuBuildMemoryBackendStr(unsigned long long size,
|
|||||||
mode = VIR_DOMAIN_NUMATUNE_MEM_STRICT;
|
mode = VIR_DOMAIN_NUMATUNE_MEM_STRICT;
|
||||||
|
|
||||||
if (pagesize == 0) {
|
if (pagesize == 0) {
|
||||||
|
bool thisHugepage = false;
|
||||||
|
|
||||||
/* Find the huge page size we want to use */
|
/* Find the huge page size we want to use */
|
||||||
for (i = 0; i < def->mem.nhugepages; i++) {
|
for (i = 0; i < def->mem.nhugepages; i++) {
|
||||||
bool thisHugepage = false;
|
|
||||||
|
|
||||||
hugepage = &def->mem.hugepages[i];
|
hugepage = &def->mem.hugepages[i];
|
||||||
|
|
||||||
if (!hugepage->nodemask) {
|
if (!hugepage->nodemask) {
|
||||||
@ -3060,6 +3061,7 @@ qemuBuildMemoryBackendStr(unsigned long long size,
|
|||||||
|
|
||||||
if (thisHugepage) {
|
if (thisHugepage) {
|
||||||
/* Hooray, we've found the page size */
|
/* Hooray, we've found the page size */
|
||||||
|
needHugepage = true;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -3166,7 +3168,7 @@ qemuBuildMemoryBackendStr(unsigned long long size,
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* If none of the following is requested... */
|
/* If none of the following is requested... */
|
||||||
if (!pagesize && !userNodeset && !memAccess && !nodeSpecified && !force) {
|
if (!needHugepage && !userNodeset && !memAccess && !nodeSpecified && !force) {
|
||||||
/* report back that using the new backend is not necessary
|
/* report back that using the new backend is not necessary
|
||||||
* to achieve the desired configuration */
|
* to achieve the desired configuration */
|
||||||
ret = 1;
|
ret = 1;
|
||||||
|
@ -10,12 +10,10 @@ QEMU_AUDIO_DRV=none \
|
|||||||
-M pc \
|
-M pc \
|
||||||
-m 1024 \
|
-m 1024 \
|
||||||
-smp 2 \
|
-smp 2 \
|
||||||
-object memory-backend-file,id=ram-node0,prealloc=yes,\
|
-mem-prealloc \
|
||||||
mem-path=/dev/hugepages2M/libvirt/qemu,size=268435456 \
|
-mem-path /dev/hugepages2M/libvirt/qemu \
|
||||||
-numa node,nodeid=0,cpus=0,memdev=ram-node0 \
|
-numa node,nodeid=0,cpus=0,mem=256 \
|
||||||
-object memory-backend-file,id=ram-node1,prealloc=yes,\
|
-numa node,nodeid=1,cpus=1,mem=768 \
|
||||||
mem-path=/dev/hugepages2M/libvirt/qemu,size=805306368 \
|
|
||||||
-numa node,nodeid=1,cpus=1,memdev=ram-node1 \
|
|
||||||
-uuid ef1bdff4-27f3-4e85-a807-5fb4d58463cc \
|
-uuid ef1bdff4-27f3-4e85-a807-5fb4d58463cc \
|
||||||
-nographic \
|
-nographic \
|
||||||
-nodefaults \
|
-nodefaults \
|
||||||
|
Loading…
Reference in New Issue
Block a user