qemu: hotplug: Refactor memory props formatting to qemuMonitorCreateObjectProps

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
This commit is contained in:
Peter Krempa 2018-05-18 14:48:22 +02:00
parent 6ab7fd16d1
commit e50daa6331
3 changed files with 43 additions and 43 deletions

View File

@ -2938,7 +2938,7 @@ qemuBuildControllerDevCommandLine(virCommandPtr cmd,
/** /**
* qemuBuildMemoryBackendProps: * qemuBuildMemoryBackendProps:
* @backendProps: [out] constructed object * @backendProps: [out] constructed object
* @backendType: [out] type of the backennd used * @alias: alias of the device
* @cfg: qemu driver config object * @cfg: qemu driver config object
* @qemuCaps: qemu capabilities object * @qemuCaps: qemu capabilities object
* @def: domain definition object * @def: domain definition object
@ -2963,7 +2963,7 @@ qemuBuildControllerDevCommandLine(virCommandPtr cmd,
*/ */
int int
qemuBuildMemoryBackendProps(virJSONValuePtr *backendProps, qemuBuildMemoryBackendProps(virJSONValuePtr *backendProps,
const char **backendType, const char *alias,
virQEMUDriverConfigPtr cfg, virQEMUDriverConfigPtr cfg,
virQEMUCapsPtr qemuCaps, virQEMUCapsPtr qemuCaps,
virDomainDefPtr def, virDomainDefPtr def,
@ -2971,6 +2971,7 @@ qemuBuildMemoryBackendProps(virJSONValuePtr *backendProps,
virBitmapPtr autoNodeset, virBitmapPtr autoNodeset,
bool force) bool force)
{ {
const char *backendType = "memory-backend-file";
virDomainNumatuneMemMode mode; virDomainNumatuneMemMode mode;
const long system_page_size = virGetSystemPageSizeKB(); const long system_page_size = virGetSystemPageSizeKB();
virDomainMemoryAccess memAccess = mem->access; virDomainMemoryAccess memAccess = mem->access;
@ -2993,7 +2994,6 @@ qemuBuildMemoryBackendProps(virJSONValuePtr *backendProps,
* @useHugepage. */ * @useHugepage. */
*backendProps = NULL; *backendProps = NULL;
*backendType = NULL;
if (mem->targetNode >= 0) { if (mem->targetNode >= 0) {
/* memory devices could provide a invalid guest node */ /* memory devices could provide a invalid guest node */
@ -3082,7 +3082,6 @@ qemuBuildMemoryBackendProps(virJSONValuePtr *backendProps,
if (useHugepage || mem->nvdimmPath || memAccess || if (useHugepage || mem->nvdimmPath || memAccess ||
def->mem.source == VIR_DOMAIN_MEMORY_SOURCE_FILE) { def->mem.source == VIR_DOMAIN_MEMORY_SOURCE_FILE) {
*backendType = "memory-backend-file";
if (useHugepage) { if (useHugepage) {
if (qemuGetDomainHupageMemPath(def, cfg, pagesize, &memPath) < 0) if (qemuGetDomainHupageMemPath(def, cfg, pagesize, &memPath) < 0)
@ -3135,7 +3134,7 @@ qemuBuildMemoryBackendProps(virJSONValuePtr *backendProps,
break; break;
} }
} else { } else {
*backendType = "memory-backend-ram"; backendType = "memory-backend-ram";
} }
if (virJSONValueObjectAdd(props, "U:size", mem->size * 1024, NULL) < 0) if (virJSONValueObjectAdd(props, "U:size", mem->size * 1024, NULL) < 0)
@ -3169,13 +3168,13 @@ qemuBuildMemoryBackendProps(virJSONValuePtr *backendProps,
ret = 1; ret = 1;
} else { } else {
/* otherwise check the required capability */ /* otherwise check the required capability */
if (STREQ(*backendType, "memory-backend-file") && if (STREQ(backendType, "memory-backend-file") &&
!virQEMUCapsGet(qemuCaps, QEMU_CAPS_OBJECT_MEMORY_FILE)) { !virQEMUCapsGet(qemuCaps, QEMU_CAPS_OBJECT_MEMORY_FILE)) {
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s", virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
_("this qemu doesn't support the " _("this qemu doesn't support the "
"memory-backend-file object")); "memory-backend-file object"));
goto cleanup; goto cleanup;
} else if (STREQ(*backendType, "memory-backend-ram") && } else if (STREQ(backendType, "memory-backend-ram") &&
!virQEMUCapsGet(qemuCaps, QEMU_CAPS_OBJECT_MEMORY_RAM)) { !virQEMUCapsGet(qemuCaps, QEMU_CAPS_OBJECT_MEMORY_RAM)) {
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s", virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
_("this qemu doesn't support the " _("this qemu doesn't support the "
@ -3186,8 +3185,9 @@ qemuBuildMemoryBackendProps(virJSONValuePtr *backendProps,
ret = 0; ret = 0;
} }
*backendProps = props; if (!(*backendProps = qemuMonitorCreateObjectPropsWrap(backendType, alias,
props = NULL; &props)))
ret = -1;
cleanup: cleanup:
virJSONValueFree(props); virJSONValueFree(props);
@ -3201,11 +3201,10 @@ qemuBuildMemoryCellBackendStr(virDomainDefPtr def,
virQEMUDriverConfigPtr cfg, virQEMUDriverConfigPtr cfg,
size_t cell, size_t cell,
qemuDomainObjPrivatePtr priv, qemuDomainObjPrivatePtr priv,
char **backendStr) virBufferPtr buf)
{ {
virJSONValuePtr props = NULL; virJSONValuePtr props = NULL;
char *alias = NULL; char *alias = NULL;
const char *backendType;
int ret = -1; int ret = -1;
int rc; int rc;
virDomainMemoryDef mem = { 0 }; virDomainMemoryDef mem = { 0 };
@ -3215,18 +3214,15 @@ qemuBuildMemoryCellBackendStr(virDomainDefPtr def,
if (virAsprintf(&alias, "ram-node%zu", cell) < 0) if (virAsprintf(&alias, "ram-node%zu", cell) < 0)
goto cleanup; goto cleanup;
*backendStr = NULL;
mem.size = memsize; mem.size = memsize;
mem.targetNode = cell; mem.targetNode = cell;
mem.info.alias = alias; mem.info.alias = alias;
if ((rc = qemuBuildMemoryBackendProps(&props, &backendType, cfg, priv->qemuCaps, if ((rc = qemuBuildMemoryBackendProps(&props, alias, cfg, priv->qemuCaps,
def, &mem, priv->autoNodeset, false)) < 0) def, &mem, priv->autoNodeset, false)) < 0)
goto cleanup; goto cleanup;
if (!(*backendStr = virQEMUBuildObjectCommandlineFromJSONType(backendType, if (virQEMUBuildObjectCommandlineFromJSON(buf, props) < 0)
alias,
props)))
goto cleanup; goto cleanup;
ret = rc; ret = rc;
@ -3239,31 +3235,34 @@ qemuBuildMemoryCellBackendStr(virDomainDefPtr def,
} }
static char * static int
qemuBuildMemoryDimmBackendStr(virDomainMemoryDefPtr mem, qemuBuildMemoryDimmBackendStr(virBufferPtr buf,
virDomainMemoryDefPtr mem,
virDomainDefPtr def, virDomainDefPtr def,
virQEMUDriverConfigPtr cfg, virQEMUDriverConfigPtr cfg,
qemuDomainObjPrivatePtr priv) qemuDomainObjPrivatePtr priv)
{ {
virJSONValuePtr props = NULL; virJSONValuePtr props = NULL;
char *alias = NULL; char *alias = NULL;
const char *backendType; int ret = -1;
char *ret = NULL;
if (!mem->info.alias) { if (!mem->info.alias) {
virReportError(VIR_ERR_INTERNAL_ERROR, "%s", virReportError(VIR_ERR_INTERNAL_ERROR, "%s",
_("memory device alias is not assigned")); _("memory device alias is not assigned"));
return NULL; return -1;
} }
if (virAsprintf(&alias, "mem%s", mem->info.alias) < 0) if (virAsprintf(&alias, "mem%s", mem->info.alias) < 0)
goto cleanup; goto cleanup;
if (qemuBuildMemoryBackendProps(&props, &backendType, cfg, priv->qemuCaps, if (qemuBuildMemoryBackendProps(&props, alias, cfg, priv->qemuCaps,
def, mem, priv->autoNodeset, true) < 0) def, mem, priv->autoNodeset, true) < 0)
goto cleanup; goto cleanup;
ret = virQEMUBuildObjectCommandlineFromJSONType(backendType, alias, props); if (virQEMUBuildObjectCommandlineFromJSON(buf, props) < 0)
goto cleanup;
ret = 0;
cleanup: cleanup:
VIR_FREE(alias); VIR_FREE(alias);
@ -7392,7 +7391,7 @@ qemuBuildNumaArgStr(virQEMUDriverConfigPtr cfg,
virQEMUCapsPtr qemuCaps = priv->qemuCaps; virQEMUCapsPtr qemuCaps = priv->qemuCaps;
virBuffer buf = VIR_BUFFER_INITIALIZER; virBuffer buf = VIR_BUFFER_INITIALIZER;
char *cpumask = NULL, *tmpmask = NULL, *next = NULL; char *cpumask = NULL, *tmpmask = NULL, *next = NULL;
char **nodeBackends = NULL; virBufferPtr *nodeBackends = NULL;
bool needBackend = false; bool needBackend = false;
int rc; int rc;
int ret = -1; int ret = -1;
@ -7453,8 +7452,12 @@ qemuBuildNumaArgStr(virQEMUDriverConfigPtr cfg,
for (i = 0; i < ncells; i++) { for (i = 0; i < ncells; i++) {
if (virQEMUCapsGet(qemuCaps, QEMU_CAPS_OBJECT_MEMORY_RAM) || if (virQEMUCapsGet(qemuCaps, QEMU_CAPS_OBJECT_MEMORY_RAM) ||
virQEMUCapsGet(qemuCaps, QEMU_CAPS_OBJECT_MEMORY_FILE)) { virQEMUCapsGet(qemuCaps, QEMU_CAPS_OBJECT_MEMORY_FILE)) {
if (VIR_ALLOC(nodeBackends[i]) < 0)
goto cleanup;
if ((rc = qemuBuildMemoryCellBackendStr(def, cfg, i, priv, if ((rc = qemuBuildMemoryCellBackendStr(def, cfg, i, priv,
&nodeBackends[i])) < 0) nodeBackends[i])) < 0)
goto cleanup; goto cleanup;
if (rc == 0) if (rc == 0)
@ -7486,8 +7489,10 @@ qemuBuildNumaArgStr(virQEMUDriverConfigPtr cfg,
goto cleanup; goto cleanup;
} }
if (needBackend) if (needBackend) {
virCommandAddArgList(cmd, "-object", nodeBackends[i], NULL); virCommandAddArg(cmd, "-object");
virCommandAddArgBuffer(cmd, nodeBackends[i]);
}
virCommandAddArg(cmd, "-numa"); virCommandAddArg(cmd, "-numa");
virBufferAsprintf(&buf, "node,nodeid=%zu", i); virBufferAsprintf(&buf, "node,nodeid=%zu", i);
@ -7550,7 +7555,7 @@ qemuBuildNumaArgStr(virQEMUDriverConfigPtr cfg,
if (nodeBackends) { if (nodeBackends) {
for (i = 0; i < ncells; i++) for (i = 0; i < ncells; i++)
VIR_FREE(nodeBackends[i]); virBufferFreeAndReset(nodeBackends[i]);
VIR_FREE(nodeBackends); VIR_FREE(nodeBackends);
} }
@ -7571,21 +7576,20 @@ qemuBuildMemoryDeviceCommandLine(virCommandPtr cmd,
/* memory hotplug requires NUMA to be enabled - we already checked /* memory hotplug requires NUMA to be enabled - we already checked
* that memory devices are present only when NUMA is */ * that memory devices are present only when NUMA is */
for (i = 0; i < def->nmems; i++) { for (i = 0; i < def->nmems; i++) {
char *backStr; virBuffer buf = VIR_BUFFER_INITIALIZER;
char *dimmStr; char *dimmStr;
if (!(backStr = qemuBuildMemoryDimmBackendStr(def->mems[i], def, if (qemuBuildMemoryDimmBackendStr(&buf, def->mems[i], def, cfg, priv) < 0)
cfg, priv)))
return -1; return -1;
if (!(dimmStr = qemuBuildMemoryDeviceStr(def->mems[i]))) { virCommandAddArg(cmd, "-object");
VIR_FREE(backStr); virCommandAddArgBuffer(cmd, &buf);
if (!(dimmStr = qemuBuildMemoryDeviceStr(def->mems[i])))
return -1; return -1;
}
virCommandAddArgList(cmd, "-object", backStr, "-device", dimmStr, NULL); virCommandAddArgList(cmd, "-device", dimmStr, NULL);
VIR_FREE(backStr);
VIR_FREE(dimmStr); VIR_FREE(dimmStr);
} }

View File

@ -120,7 +120,7 @@ int qemuBuildControllerDevStr(const virDomainDef *domainDef,
int *nusbcontroller); int *nusbcontroller);
int qemuBuildMemoryBackendProps(virJSONValuePtr *backendProps, int qemuBuildMemoryBackendProps(virJSONValuePtr *backendProps,
const char **backendType, const char *alias,
virQEMUDriverConfigPtr cfg, virQEMUDriverConfigPtr cfg,
virQEMUCapsPtr qemuCaps, virQEMUCapsPtr qemuCaps,
virDomainDefPtr def, virDomainDefPtr def,

View File

@ -2098,7 +2098,6 @@ qemuDomainAttachMemory(virQEMUDriverPtr driver,
unsigned long long newmem = oldmem + mem->size; unsigned long long newmem = oldmem + mem->size;
char *devstr = NULL; char *devstr = NULL;
char *objalias = NULL; char *objalias = NULL;
const char *backendType;
bool objAdded = false; bool objAdded = false;
bool teardownlabel = false; bool teardownlabel = false;
bool teardowncgroup = false; bool teardowncgroup = false;
@ -2107,7 +2106,6 @@ qemuDomainAttachMemory(virQEMUDriverPtr driver,
virObjectEventPtr event; virObjectEventPtr event;
int id; int id;
int ret = -1; int ret = -1;
int rv;
qemuDomainMemoryDeviceAlignSize(vm->def, mem); qemuDomainMemoryDeviceAlignSize(vm->def, mem);
@ -2128,7 +2126,7 @@ qemuDomainAttachMemory(virQEMUDriverPtr driver,
if (!(devstr = qemuBuildMemoryDeviceStr(mem))) if (!(devstr = qemuBuildMemoryDeviceStr(mem)))
goto cleanup; goto cleanup;
if (qemuBuildMemoryBackendProps(&props, &backendType, cfg, if (qemuBuildMemoryBackendProps(&props, objalias, cfg,
priv->qemuCaps, vm->def, mem, NULL, true) < 0) priv->qemuCaps, vm->def, mem, NULL, true) < 0)
goto cleanup; goto cleanup;
@ -2154,9 +2152,7 @@ qemuDomainAttachMemory(virQEMUDriverPtr driver,
goto removedef; goto removedef;
qemuDomainObjEnterMonitor(driver, vm); qemuDomainObjEnterMonitor(driver, vm);
rv = qemuMonitorAddObjectType(priv->mon, backendType, objalias, props); if (qemuMonitorAddObject(priv->mon, &props, NULL) < 0)
props = NULL; /* qemuMonitorAddObjectType consumes */
if (rv < 0)
goto exit_monitor; goto exit_monitor;
objAdded = true; objAdded = true;