mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-25 22:15:20 +00:00
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:
parent
6ab7fd16d1
commit
e50daa6331
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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,
|
||||||
|
@ -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;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user