vm->persistent = 1;
if (virDomainDefSave(vm->newDef ? vm->newDef : vm->def,
- privconn->xmlopt, caps, BHYVE_CONFIG_DIR) < 0) {
+ privconn->xmlopt, BHYVE_CONFIG_DIR) < 0) {
virDomainObjListRemove(privconn->domains, vm);
goto cleanup;
}
{
bhyveConnPtr privconn = dom->conn->privateData;
virDomainObjPtr vm;
- virCapsPtr caps = NULL;
int ret = -1;
virCheckFlags(VIR_DOMAIN_AFFECT_LIVE |
if (virDomainSetMetadataEnsureACL(dom->conn, vm->def, flags) < 0)
goto cleanup;
- if (!(caps = bhyveDriverGetCapabilities(privconn)))
- goto cleanup;
-
- ret = virDomainObjSetMetadata(vm, type, metadata, key, uri, caps,
+ ret = virDomainObjSetMetadata(vm, type, metadata, key, uri,
privconn->xmlopt, BHYVE_STATE_DIR,
BHYVE_CONFIG_DIR, flags);
cleanup:
- virObjectUnref(caps);
virDomainObjEndAPI(&vm);
return ret;
}
bhyveConnPtr privconn = conn->privateData;
bhyveDomainObjPrivatePtr priv = vm->privateData;
int ret = -1, rc;
- virCapsPtr caps = NULL;
logfile = g_strdup_printf("%s/%s.log", BHYVE_LOG_DIR, vm->def->name);
- caps = bhyveDriverGetCapabilities(privconn);
- if (!caps)
- goto cleanup;
-
if ((logfd = open(logfile, O_WRONLY | O_APPEND | O_CREAT,
S_IRUSR | S_IWUSR)) < 0) {
virReportSystemError(errno,
virDomainObjSetState(vm, VIR_DOMAIN_RUNNING, reason);
priv->mon = bhyveMonitorOpen(vm, driver);
- if (virDomainObjSave(vm, driver->xmlopt, caps,
+ if (virDomainObjSave(vm, driver->xmlopt,
BHYVE_STATE_DIR) < 0)
goto cleanup;
ret = 0;
cleanup:
- virObjectUnref(caps);
if (devicemap != NULL) {
rc = unlink(devmap_file);
if (rc < 0 && errno != ENOENT)
char *expected_proctitle = NULL;
bhyveDomainObjPrivatePtr priv = vm->privateData;
int ret = -1;
- virCapsPtr caps = NULL;
if (!virDomainObjIsActive(vm))
return 0;
if (!vm->pid)
return 0;
- caps = bhyveDriverGetCapabilities(data->driver);
- if (!caps)
- return -1;
-
virObjectLock(vm);
kp = kvm_getprocs(data->kd, KERN_PROC_PID, vm->pid, &nprocs);
vm->def->id = -1;
virDomainObjSetState(vm, VIR_DOMAIN_SHUTOFF,
VIR_DOMAIN_SHUTOFF_UNKNOWN);
- ignore_value(virDomainObjSave(vm, data->driver->xmlopt, caps,
+ ignore_value(virDomainObjSave(vm, data->driver->xmlopt,
BHYVE_STATE_DIR));
}
- virObjectUnref(caps);
virObjectUnlock(vm);
VIR_FREE(expected_proctitle);
int
virDomainDefSave(virDomainDefPtr def,
virDomainXMLOptionPtr xmlopt,
- virCapsPtr caps G_GNUC_UNUSED,
const char *configDir)
{
g_autofree char *xml = NULL;
int
virDomainObjSave(virDomainObjPtr obj,
virDomainXMLOptionPtr xmlopt,
- virCapsPtr caps G_GNUC_UNUSED,
const char *statusDir)
{
unsigned int flags = (VIR_DOMAIN_DEF_FORMAT_SECURE |
const char *metadata,
const char *key,
const char *uri,
- virCapsPtr caps,
virDomainXMLOptionPtr xmlopt,
const char *stateDir,
const char *configDir,
if (virDomainDefSetMetadata(def, type, metadata, key, uri) < 0)
return -1;
- if (virDomainObjSave(vm, xmlopt, caps, stateDir) < 0)
+ if (virDomainObjSave(vm, xmlopt, stateDir) < 0)
return -1;
}
uri) < 0)
return -1;
- if (virDomainDefSave(persistentDef, xmlopt, caps, configDir) < 0)
+ if (virDomainDefSave(persistentDef, xmlopt, configDir) < 0)
return -1;
}
int virDomainDefSave(virDomainDefPtr def,
virDomainXMLOptionPtr xmlopt,
- virCapsPtr caps,
const char *configDir)
G_GNUC_WARN_UNUSED_RESULT
ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2)
int virDomainObjSave(virDomainObjPtr obj,
virDomainXMLOptionPtr xmlopt,
- virCapsPtr caps,
const char *statusDir)
G_GNUC_WARN_UNUSED_RESULT
ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2)
const char *metadata,
const char *key,
const char *uri,
- virCapsPtr caps,
virDomainXMLOptionPtr xmlopt,
const char *stateDir,
const char *configDir,
virDomainObjSetState(vm, VIR_DOMAIN_PAUSED, VIR_DOMAIN_PAUSED_USER);
}
- if (virDomainObjSave(vm, driver->xmlopt, cfg->caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
goto destroy_dom;
if (virAtomicIntInc(&driver->nactive) == 1 && driver->inhibitCallback)
libxlReconnectNotifyNets(vm->def);
- if (virDomainObjSave(vm, driver->xmlopt, cfg->caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
VIR_WARN("Cannot update XML for running Xen guest %s", vm->def->name);
/* now that we know it's reconnected call the hook if present */
VIR_DOMAIN_EVENT_SUSPENDED_PAUSED);
}
- if (virDomainObjSave(vm, driver->xmlopt, cfg->caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
goto endjob;
ret = 0;
VIR_DOMAIN_EVENT_RESUMED_UNPAUSED);
}
- if (virDomainObjSave(vm, driver->xmlopt, cfg->caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
goto endjob;
ret = 0;
virDomainDefSetMemoryTotal(persistentDef, newmem);
if (persistentDef->mem.cur_balloon > newmem)
persistentDef->mem.cur_balloon = newmem;
- ret = virDomainDefSave(persistentDef, driver->xmlopt, cfg->caps, cfg->configDir);
+ ret = virDomainDefSave(persistentDef, driver->xmlopt, cfg->configDir);
goto endjob;
}
if (flags & VIR_DOMAIN_MEM_CONFIG) {
sa_assert(persistentDef);
persistentDef->mem.cur_balloon = newmem;
- ret = virDomainDefSave(persistentDef, driver->xmlopt, cfg->caps, cfg->configDir);
+ ret = virDomainDefSave(persistentDef, driver->xmlopt, cfg->configDir);
goto endjob;
}
}
ret = 0;
if (flags & VIR_DOMAIN_VCPU_LIVE) {
- if (virDomainObjSave(vm, driver->xmlopt, cfg->caps, cfg->stateDir) < 0) {
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0) {
VIR_WARN("Unable to save status on vm %s after changing vcpus",
vm->def->name);
}
}
if (flags & VIR_DOMAIN_VCPU_CONFIG) {
- if (virDomainDefSave(def, driver->xmlopt, cfg->caps, cfg->configDir) < 0) {
+ if (virDomainDefSave(def, driver->xmlopt, cfg->configDir) < 0) {
VIR_WARN("Unable to save configuration of vm %s after changing vcpus",
vm->def->name);
}
ret = 0;
if (flags & VIR_DOMAIN_AFFECT_LIVE) {
- ret = virDomainObjSave(vm, driver->xmlopt, cfg->caps, cfg->stateDir);
+ ret = virDomainObjSave(vm, driver->xmlopt, cfg->stateDir);
} else if (flags & VIR_DOMAIN_AFFECT_CONFIG) {
- ret = virDomainDefSave(targetDef, driver->xmlopt, cfg->caps, cfg->configDir);
+ ret = virDomainDefSave(targetDef, driver->xmlopt, cfg->configDir);
}
endjob:
vm->persistent = 1;
if (virDomainDefSave(vm->newDef ? vm->newDef : vm->def,
- driver->xmlopt, cfg->caps, cfg->configDir) < 0) {
+ driver->xmlopt, cfg->configDir) < 0) {
virDomainObjListRemove(driver->domains, vm);
goto cleanup;
}
* update domain status forcibly because the domain status may be
* changed even if we attach the device failed.
*/
- if (virDomainObjSave(vm, driver->xmlopt, cfg->caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
goto endjob;
}
/* Finally, if no error until here, we can save config. */
if (flags & VIR_DOMAIN_DEVICE_MODIFY_CONFIG) {
- ret = virDomainDefSave(vmdef, driver->xmlopt, cfg->caps, cfg->configDir);
+ ret = virDomainDefSave(vmdef, driver->xmlopt, cfg->configDir);
if (!ret) {
virDomainObjAssignDef(vm, vmdef, false, NULL);
vmdef = NULL;
* update domain status forcibly because the domain status may be
* changed even if we attach the device failed.
*/
- if (virDomainObjSave(vm, driver->xmlopt, cfg->caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
goto endjob;
}
/* Finally, if no error until here, we can save config. */
if (flags & VIR_DOMAIN_DEVICE_MODIFY_CONFIG) {
- ret = virDomainDefSave(vmdef, driver->xmlopt, cfg->caps, cfg->configDir);
+ ret = virDomainDefSave(vmdef, driver->xmlopt, cfg->configDir);
if (!ret) {
virDomainObjAssignDef(vm, vmdef, false, NULL);
vmdef = NULL;
* update domain status forcibly because the domain status may be
* changed even if we attach the device failed.
*/
- if (virDomainObjSave(vm, driver->xmlopt, cfg->caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
ret = -1;
}
/* Finally, if no error until here, we can save config. */
if (!ret && (flags & VIR_DOMAIN_DEVICE_MODIFY_CONFIG)) {
- ret = virDomainDefSave(vmdef, driver->xmlopt, cfg->caps, cfg->configDir);
+ ret = virDomainDefSave(vmdef, driver->xmlopt, cfg->configDir);
if (!ret) {
virDomainObjAssignDef(vm, vmdef, false, NULL);
vmdef = NULL;
if (libxlDomainObjBeginJob(driver, vm, LIBXL_JOB_MODIFY) < 0)
goto cleanup;
- ret = virDomainObjSetMetadata(vm, type, metadata, key, uri, cfg->caps,
+ ret = virDomainObjSetMetadata(vm, type, metadata, key, uri,
driver->xmlopt, cfg->stateDir,
cfg->configDir, flags);
if (!(vmdef = virDomainObjGetPersistentDef(driver->xmlopt, vm, NULL)))
goto cleanup;
- if (virDomainDefSave(vmdef, driver->xmlopt, cfg->caps, cfg->configDir) < 0)
+ if (virDomainDefSave(vmdef, driver->xmlopt, cfg->configDir) < 0)
goto cleanup;
event = virDomainEventLifecycleNewFromObj(vm,
event = NULL;
}
- if (virDomainObjSave(vm, driver->xmlopt, cfg->caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
goto cleanup;
dom = virGetDomain(dconn, vm->def->name, vm->def->uuid, vm->def->id);
VIR_DOMAIN_PAUSED_MIGRATION);
event = virDomainEventLifecycleNewFromObj(vm, VIR_DOMAIN_EVENT_SUSPENDED,
VIR_DOMAIN_EVENT_SUSPENDED_MIGRATED);
- ignore_value(virDomainObjSave(vm, driver->xmlopt, cfg->caps, cfg->stateDir));
+ ignore_value(virDomainObjSave(vm, driver->xmlopt, cfg->stateDir));
}
goto cleanup;
}
vm->persistent = 1;
if (virDomainDefSave(vm->newDef ? vm->newDef : vm->def,
- driver->xmlopt, driver->caps, cfg->configDir) < 0) {
+ driver->xmlopt, cfg->configDir) < 0) {
virDomainObjListRemove(driver->domains, vm);
goto cleanup;
}
if (persistentDef->mem.cur_balloon > newmem)
persistentDef->mem.cur_balloon = newmem;
if (virDomainDefSave(persistentDef,
- driver->xmlopt, driver->caps, cfg->configDir) < 0)
+ driver->xmlopt, cfg->configDir) < 0)
goto endjob;
}
} else {
}
def->mem.cur_balloon = newmem;
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
goto endjob;
}
if (persistentDef) {
persistentDef->mem.cur_balloon = newmem;
if (virDomainDefSave(persistentDef,
- driver->xmlopt, driver->caps, cfg->configDir) < 0)
+ driver->xmlopt, cfg->configDir) < 0)
goto endjob;
}
}
#undef VIR_SET_MEM_PARAMETER
if (def &&
- virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0)
+ virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
goto endjob;
if (persistentDef &&
- virDomainDefSave(persistentDef, driver->xmlopt, driver->caps, cfg->configDir) < 0)
+ virDomainDefSave(persistentDef, driver->xmlopt, cfg->configDir) < 0)
goto endjob;
/* QEMU and LXC implementations are identical */
}
}
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
goto endjob;
if (persistentDef) {
- rc = virDomainDefSave(persistentDefCopy, driver->xmlopt, driver->caps,
+ rc = virDomainDefSave(persistentDefCopy, driver->xmlopt,
cfg->configDir);
if (rc < 0)
goto endjob;
}
}
- if (virDomainDefSave(persistentDef, driver->xmlopt, driver->caps, cfg->configDir) < 0)
+ if (virDomainDefSave(persistentDef, driver->xmlopt, cfg->configDir) < 0)
ret = -1;
}
VIR_DOMAIN_EVENT_SUSPENDED_PAUSED);
}
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
goto endjob;
ret = 0;
VIR_DOMAIN_EVENT_RESUMED_UNPAUSED);
}
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
goto endjob;
ret = 0;
* changed even if we failed to attach the device. For example,
* a new controller may be created.
*/
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0) {
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0) {
ret = -1;
goto endjob;
}
/* Finally, if no error until here, we can save config. */
if (flags & VIR_DOMAIN_AFFECT_CONFIG) {
- ret = virDomainDefSave(vmdef, driver->xmlopt, driver->caps, cfg->configDir);
+ ret = virDomainDefSave(vmdef, driver->xmlopt, cfg->configDir);
if (!ret) {
virDomainObjAssignDef(vm, vmdef, false, NULL);
vmdef = NULL;
if (lxcDomainUpdateDeviceConfig(vmdef, dev) < 0)
goto endjob;
- if (virDomainDefSave(vmdef, driver->xmlopt, driver->caps, cfg->configDir) < 0)
+ if (virDomainDefSave(vmdef, driver->xmlopt, cfg->configDir) < 0)
goto endjob;
virDomainObjAssignDef(vm, vmdef, false, NULL);
* changed even if we failed to attach the device. For example,
* a new controller may be created.
*/
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0) {
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0) {
ret = -1;
goto endjob;
}
/* Finally, if no error until here, we can save config. */
if (flags & VIR_DOMAIN_AFFECT_CONFIG) {
- ret = virDomainDefSave(vmdef, driver->xmlopt, driver->caps, cfg->configDir);
+ ret = virDomainDefSave(vmdef, driver->xmlopt, cfg->configDir);
if (!ret) {
virDomainObjAssignDef(vm, vmdef, false, NULL);
vmdef = NULL;
virLXCDriverPtr driver = dom->conn->privateData;
virDomainObjPtr vm;
virLXCDriverConfigPtr cfg = NULL;
- virCapsPtr caps = NULL;
int ret = -1;
virCheckFlags(VIR_DOMAIN_AFFECT_LIVE |
if (virDomainSetMetadataEnsureACL(dom->conn, vm->def, flags) < 0)
goto cleanup;
- if (!(caps = virLXCDriverGetCapabilities(driver, false)))
- goto cleanup;
-
if (virLXCDomainObjBeginJob(driver, vm, LXC_JOB_MODIFY) < 0)
goto cleanup;
- ret = virDomainObjSetMetadata(vm, type, metadata, key, uri, caps,
+ ret = virDomainObjSetMetadata(vm, type, metadata, key, uri,
driver->xmlopt, cfg->stateDir,
cfg->configDir, flags);
cleanup:
virDomainObjEndAPI(&vm);
- virObjectUnref(caps);
virObjectUnref(cfg);
return ret;
}
}
virDomainAuditInit(vm, initpid, inode);
- if (virDomainObjSave(vm, lxc_driver->xmlopt, lxc_driver->caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(vm, lxc_driver->xmlopt, cfg->stateDir) < 0)
VIR_WARN("Cannot update XML with PID for LXC %s", vm->def->name);
virObjectUnlock(vm);
/* Write domain status to disk for the controller to
* read when it starts */
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
goto cleanup;
/* Allow the child to exec the controller */
virLXCProcessReconnectNotifyNets(vm->def);
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
VIR_WARN("Cannot update XML for running LXC guest %s", vm->def->name);
/* now that we know it's reconnected call the hook if present */
virQEMUDriverConfigPtr cfg = virQEMUDriverGetConfig(driver);
if (virDomainObjIsActive(obj)) {
- if (virDomainObjSave(obj, driver->xmlopt, driver->caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(obj, driver->xmlopt, cfg->stateDir) < 0)
VIR_WARN("Failed to save status on vm %s", obj->def->name);
}
cfg = virQEMUDriverGetConfig(driver);
- if (virDomainDefSave(def, driver->xmlopt, driver->caps, cfg->configDir) < 0)
+ if (virDomainDefSave(def, driver->xmlopt, cfg->configDir) < 0)
VIR_WARN("Failed to save config of vm %s", obj->def->name);
}
priv->fakeReboot = value;
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
VIR_WARN("Failed to save status on vm %s", vm->def->name);
cleanup:
if (qemuProcessStopCPUs(driver, vm, reason, QEMU_ASYNC_JOB_NONE) < 0)
goto endjob;
}
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
goto endjob;
ret = 0;
goto endjob;
}
}
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
goto endjob;
ret = 0;
if (persistentDef->mem.cur_balloon > newmem)
persistentDef->mem.cur_balloon = newmem;
- ret = virDomainDefSave(persistentDef, driver->xmlopt, driver->caps,
+ ret = virDomainDefSave(persistentDef, driver->xmlopt,
cfg->configDir);
goto endjob;
}
if (persistentDef) {
persistentDef->mem.cur_balloon = newmem;
- ret = virDomainDefSave(persistentDef, driver->xmlopt, driver->caps,
+ ret = virDomainDefSave(persistentDef, driver->xmlopt,
cfg->configDir);
goto endjob;
}
}
def->memballoon->period = period;
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
goto endjob;
}
goto endjob;
}
persistentDef->memballoon->period = period;
- ret = virDomainDefSave(persistentDef, driver->xmlopt, driver->caps, cfg->configDir);
+ ret = virDomainDefSave(persistentDef, driver->xmlopt, cfg->configDir);
goto endjob;
}
virObjectEventStateQueue(driver->domainEventState, event);
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0) {
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0) {
VIR_WARN("Unable to save status on vm %s after state change",
vm->def->name);
}
goto endjob;
}
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
VIR_WARN("unable to save domain status after removing device %s",
devAlias);
dev.data.chr->state = newstate;
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
VIR_WARN("unable to save status of domain %s after updating state of "
"channel %s", vm->def->name, devAlias);
if (virDomainDefSetVcpusMax(persistentDef, nvcpus, driver->xmlopt) < 0)
return -1;
- if (virDomainDefSave(persistentDef, driver->xmlopt, driver->caps, cfg->configDir) < 0)
+ if (virDomainDefSave(persistentDef, driver->xmlopt, cfg->configDir) < 0)
return -1;
return 0;
vcpuinfo->cpumask = tmpmap;
tmpmap = NULL;
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
goto cleanup;
if (g_snprintf(paramField, VIR_TYPED_PARAM_FIELD_LENGTH,
vcpuinfo->cpumask = pcpumap;
pcpumap = NULL;
- ret = virDomainDefSave(persistentDef, driver->xmlopt, driver->caps, cfg->configDir);
+ ret = virDomainDefSave(persistentDef, driver->xmlopt, cfg->configDir);
goto endjob;
}
if (!(def->cputune.emulatorpin = virBitmapNewCopy(pcpumap)))
goto endjob;
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
goto endjob;
str = virBitmapFormat(pcpumap);
if (!(persistentDef->cputune.emulatorpin = virBitmapNewCopy(pcpumap)))
goto endjob;
- ret = virDomainDefSave(persistentDef, driver->xmlopt, driver->caps, cfg->configDir);
+ ret = virDomainDefSave(persistentDef, driver->xmlopt, cfg->configDir);
goto endjob;
}
if (virProcessSetAffinity(iothrid->thread_id, pcpumap) < 0)
goto endjob;
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
goto endjob;
if (g_snprintf(paramField, VIR_TYPED_PARAM_FIELD_LENGTH,
iothrid->cpumask = cpumask;
iothrid->autofill = false;
- ret = virDomainDefSave(persistentDef, driver->xmlopt, driver->caps, cfg->configDir);
+ ret = virDomainDefSave(persistentDef, driver->xmlopt, cfg->configDir);
goto endjob;
}
}
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
goto endjob;
}
break;
}
- if (virDomainDefSave(persistentDef, driver->xmlopt, driver->caps,
+ if (virDomainDefSave(persistentDef, driver->xmlopt,
cfg->configDir) < 0)
goto endjob;
}
"%s", _("failed to resume domain"));
goto cleanup;
}
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0) {
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0) {
VIR_WARN("Failed to save status on vm %s", vm->def->name);
goto cleanup;
}
vm->persistent = 1;
if (virDomainDefSave(vm->newDef ? vm->newDef : vm->def,
- driver->xmlopt, driver->caps, cfg->configDir) < 0) {
+ driver->xmlopt, cfg->configDir) < 0) {
if (oldDef) {
/* There is backup so this VM was defined before.
* Just restore the backup. */
* changed even if we failed to attach the device. For example,
* a new controller may be created.
*/
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
goto cleanup;
}
/* Finally, if no error until here, we can save config. */
if (flags & VIR_DOMAIN_AFFECT_CONFIG) {
- if (virDomainDefSave(vmdef, driver->xmlopt, driver->caps, cfg->configDir) < 0)
+ if (virDomainDefSave(vmdef, driver->xmlopt, cfg->configDir) < 0)
goto cleanup;
virDomainObjAssignDef(vm, vmdef, false, NULL);
* changed even if we failed to attach the device. For example,
* a new controller may be created.
*/
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0) {
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0) {
ret = -1;
goto endjob;
}
/* Finally, if no error until here, we can save config. */
if (flags & VIR_DOMAIN_AFFECT_CONFIG) {
- ret = virDomainDefSave(vmdef, driver->xmlopt, driver->caps, cfg->configDir);
+ ret = virDomainDefSave(vmdef, driver->xmlopt, cfg->configDir);
if (!ret) {
virDomainObjAssignDef(vm, vmdef, false, NULL);
vmdef = NULL;
* changed even if we failed to attach the device. For example,
* a new controller may be created.
*/
- if (virDomainObjSave(vm, driver->xmlopt, caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
goto cleanup;
}
/* Finally, if no error until here, we can save config. */
if (flags & VIR_DOMAIN_AFFECT_CONFIG) {
- if (virDomainDefSave(vmdef, driver->xmlopt, caps, cfg->configDir) < 0)
+ if (virDomainDefSave(vmdef, driver->xmlopt, cfg->configDir) < 0)
goto cleanup;
virDomainObjAssignDef(vm, vmdef, false, NULL);
}
if (vmdef) {
- if (virDomainDefSave(vmdef, driver->xmlopt, caps, cfg->configDir) < 0)
+ if (virDomainDefSave(vmdef, driver->xmlopt, cfg->configDir) < 0)
goto cleanup;
virDomainObjAssignDef(vm, vmdef, false, NULL);
vmdef = NULL;
}
}
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
goto endjob;
}
if (ret < 0)
}
}
- if (virDomainDefSave(persistentDef, driver->xmlopt, driver->caps, cfg->configDir) < 0)
+ if (virDomainDefSave(persistentDef, driver->xmlopt, cfg->configDir) < 0)
ret = -1;
}
#undef VIR_SET_MEM_PARAMETER
if (def &&
- virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0)
+ virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
goto endjob;
if (persistentDef &&
- virDomainDefSave(persistentDef, driver->xmlopt, driver->caps, cfg->configDir) < 0)
+ virDomainDefSave(persistentDef, driver->xmlopt, cfg->configDir) < 0)
goto endjob;
/* QEMU and LXC implementations are identical */
-1, mode, nodeset) < 0)
goto endjob;
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
goto endjob;
}
-1, mode, nodeset) < 0)
goto endjob;
- if (virDomainDefSave(persistentDef, driver->xmlopt, driver->caps, cfg->configDir) < 0)
+ if (virDomainDefSave(persistentDef, driver->xmlopt, cfg->configDir) < 0)
goto endjob;
}
VIR_TRISTATE_BOOL_YES : VIR_TRISTATE_BOOL_NO;
}
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
goto endjob;
}
VIR_TRISTATE_BOOL_YES : VIR_TRISTATE_BOOL_NO;
}
- if (virDomainDefSave(persistentDef, driver->xmlopt, driver->caps, cfg->configDir) < 0)
+ if (virDomainDefSave(persistentDef, driver->xmlopt, cfg->configDir) < 0)
goto endjob;
}
int ret = -1;
int rc;
g_autoptr(virQEMUDriverConfig) cfg = NULL;
- g_autoptr(virCaps) caps = NULL;
qemuDomainObjPrivatePtr priv;
virObjectEventPtr event = NULL;
virTypedParameterPtr eventParams = NULL;
goto cleanup;
}
- if (!(caps = virQEMUDriverGetCapabilities(driver, false)))
- goto cleanup;
-
if (qemuDomainObjBeginJob(driver, vm, QEMU_JOB_MODIFY) < 0)
goto cleanup;
}
}
- if (virDomainObjSave(vm, driver->xmlopt, caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
goto endjob;
if (eventNparams) {
}
if (persistentDef) {
- rc = virDomainDefSave(persistentDefCopy, driver->xmlopt, caps,
+ rc = virDomainDefSave(persistentDefCopy, driver->xmlopt,
cfg->configDir);
if (rc < 0)
goto endjob;
goto endjob;
}
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
goto endjob;
}
}
}
- if (virDomainDefSave(persistentDef, driver->xmlopt, driver->caps, cfg->configDir) < 0)
+ if (virDomainDefSave(persistentDef, driver->xmlopt, cfg->configDir) < 0)
goto endjob;
}
defdisk->src = g_steal_pointer(&newsrc);
}
- if (virDomainDefSave(vm->def, driver->xmlopt, driver->caps, cfg->configDir) < 0)
+ if (virDomainDefSave(vm->def, driver->xmlopt, cfg->configDir) < 0)
goto cleanup;
ret = 0;
if (rc < 0)
goto cleanup;
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0 ||
- (vm->newDef && virDomainDefSave(vm->newDef, driver->xmlopt, driver->caps,
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0 ||
+ (vm->newDef && virDomainDefSave(vm->newDef, driver->xmlopt,
cfg->configDir) < 0))
goto cleanup;
}
if (ret == 0 && defined && vm->persistent &&
!(ret = virDomainDefSave(vm->newDef ? vm->newDef : vm->def,
- driver->xmlopt, driver->caps, cfg->configDir))) {
+ driver->xmlopt, cfg->configDir))) {
detail = VIR_DOMAIN_EVENT_DEFINED_FROM_SNAPSHOT;
virObjectEventStateQueue(driver->domainEventState,
virDomainEventLifecycleNewFromObj(vm,
job->state = QEMU_BLOCKJOB_STATE_ABORTING;
}
- ignore_value(virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir));
+ ignore_value(virDomainObjSave(vm, driver->xmlopt, cfg->stateDir));
if (!async) {
qemuBlockJobUpdate(vm, job, QEMU_ASYNC_JOB_NONE);
if (virDomainDiskSetBlockIOTune(disk, &info) < 0)
goto endjob;
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
goto endjob;
if (eventNparams) {
if (virDomainDiskSetBlockIOTune(conf_disk, &info) < 0)
goto endjob;
- if (virDomainDefSave(persistentDef, driver->xmlopt, driver->caps,
+ if (virDomainDefSave(persistentDef, driver->xmlopt,
cfg->configDir) < 0)
goto endjob;
}
virQEMUDriverPtr driver = dom->conn->privateData;
virDomainObjPtr vm;
g_autoptr(virQEMUDriverConfig) cfg = NULL;
- g_autoptr(virCaps) caps = NULL;
int ret = -1;
virCheckFlags(VIR_DOMAIN_AFFECT_LIVE |
if (virDomainSetMetadataEnsureACL(dom->conn, vm->def, flags) < 0)
goto cleanup;
- if (!(caps = virQEMUDriverGetCapabilities(driver, false)))
- goto cleanup;
-
if (qemuDomainObjBeginJob(driver, vm, QEMU_JOB_MODIFY) < 0)
goto cleanup;
- ret = virDomainObjSetMetadata(vm, type, metadata, key, uri, caps,
+ ret = virDomainObjSetMetadata(vm, type, metadata, key, uri,
driver->xmlopt, cfg->stateDir,
cfg->configDir, flags);
vm->def->name = new_dom_name;
new_dom_name = NULL;
- if (virDomainDefSave(vm->def, driver->xmlopt, driver->caps, cfg->configDir) < 0)
+ if (virDomainDefSave(vm->def, driver->xmlopt, cfg->configDir) < 0)
goto rollback;
if (virFileExists(old_dom_cfg_file) &&
qemuDomainModifyLifecycleAction(def, type, action);
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
goto endjob;
}
if (persistentDef) {
qemuDomainModifyLifecycleAction(persistentDef, type, action);
- if (virDomainDefSave(persistentDef, driver->xmlopt, driver->caps,
+ if (virDomainDefSave(persistentDef, driver->xmlopt,
cfg->configDir) < 0)
goto endjob;
}
QEMU_DOMAIN_PRIVATE(vm)->agentTimeout = timeout;
if (virDomainObjIsActive(vm) &&
- virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0)
+ virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
goto cleanup;
ret = 0;
qemuDomainVcpuPersistOrder(vm->def);
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
goto cleanup;
ret = 0;
qemuDomainVcpuPersistOrder(vm->def);
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
goto cleanup;
ret = 0;
if (persistentDef) {
qemuDomainSetVcpusConfig(persistentDef, nvcpus, hotpluggable);
- if (virDomainDefSave(persistentDef, driver->xmlopt, driver->caps, cfg->configDir) < 0)
+ if (virDomainDefSave(persistentDef, driver->xmlopt, cfg->configDir) < 0)
goto cleanup;
}
if (persistentDef) {
qemuDomainSetVcpuConfig(persistentDef, map, state);
- if (virDomainDefSave(persistentDef, driver->xmlopt, driver->caps, cfg->configDir) < 0)
+ if (virDomainDefSave(persistentDef, driver->xmlopt, cfg->configDir) < 0)
goto cleanup;
}
tlsAlias, flags) < 0)
return -1;
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0) {
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0) {
VIR_WARN("Failed to save status on vm %s", vm->def->name);
return -1;
}
qemuMigrationParamsReset(driver, vm, QEMU_ASYNC_JOB_MIGRATION_OUT,
priv->job.migParams, priv->job.apiFlags);
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
VIR_WARN("Failed to save status on vm %s", vm->def->name);
}
priv->qemuCaps)))
goto error;
- if (virDomainDefSave(vmdef, driver->xmlopt, driver->caps, cfg->configDir) < 0 &&
+ if (virDomainDefSave(vmdef, driver->xmlopt, cfg->configDir) < 0 &&
!ignoreSaveError)
goto error;
}
if (virDomainObjIsActive(vm) &&
- virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0)
+ virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
VIR_WARN("Failed to save status on vm %s", vm->def->name);
/* Guest is successfully running, so cancel previous auto destroy */
if (priv->agent)
qemuAgentNotifyEvent(priv->agent, QEMU_AGENT_EVENT_RESET);
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
VIR_WARN("Failed to save status on vm %s", vm->def->name);
if (vm->def->onReboot == VIR_DOMAIN_LIFECYCLE_ACTION_DESTROY ||
goto endjob;
}
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0) {
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0) {
VIR_WARN("Unable to save status on vm %s after state change",
vm->def->name);
}
VIR_DOMAIN_EVENT_SHUTDOWN,
detail);
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0) {
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0) {
VIR_WARN("Unable to save status on vm %s after state change",
vm->def->name);
}
VIR_WARN("Unable to release lease on %s", vm->def->name);
VIR_DEBUG("Preserving lock state '%s'", NULLSTR(priv->lockState));
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0) {
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0) {
VIR_WARN("Unable to save status on vm %s after state change",
vm->def->name);
}
VIR_DOMAIN_EVENT_RESUMED,
eventDetail);
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0) {
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0) {
VIR_WARN("Unable to save status on vm %s after state change",
vm->def->name);
}
offset += vm->def->clock.data.variable.adjustment0;
vm->def->clock.data.variable.adjustment = offset;
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
VIR_WARN("unable to save domain status with RTC change");
}
VIR_WARN("Unable to release lease on %s", vm->def->name);
VIR_DEBUG("Preserving lock state '%s'", NULLSTR(priv->lockState));
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0) {
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0) {
VIR_WARN("Unable to save status on vm %s after watchdog event",
vm->def->name);
}
VIR_WARN("Unable to release lease on %s", vm->def->name);
VIR_DEBUG("Preserving lock state '%s'", NULLSTR(priv->lockState));
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
VIR_WARN("Unable to save status on vm %s after IO error", vm->def->name);
}
virObjectUnlock(vm);
else if (reason == VIR_DOMAIN_EVENT_TRAY_CHANGE_CLOSE)
disk->tray_status = VIR_DOMAIN_DISK_TRAY_CLOSED;
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0) {
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0) {
VIR_WARN("Unable to save status on vm %s after tray moved event",
vm->def->name);
}
VIR_DOMAIN_EVENT_STARTED,
VIR_DOMAIN_EVENT_STARTED_WAKEUP);
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0) {
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0) {
VIR_WARN("Unable to save status on vm %s after wakeup event",
vm->def->name);
}
VIR_DOMAIN_EVENT_PMSUSPENDED,
VIR_DOMAIN_EVENT_PMSUSPENDED_MEMORY);
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0) {
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0) {
VIR_WARN("Unable to save status on vm %s after suspend event",
vm->def->name);
}
vm->def->mem.cur_balloon, actual);
vm->def->mem.cur_balloon = actual;
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
VIR_WARN("unable to save domain status with balloon change");
virObjectUnlock(vm);
VIR_DOMAIN_EVENT_PMSUSPENDED,
VIR_DOMAIN_EVENT_PMSUSPENDED_DISK);
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0) {
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0) {
VIR_WARN("Unable to save status on vm %s after suspend event",
vm->def->name);
}
VIR_DOMAIN_EVENT_SUSPENDED,
VIR_DOMAIN_EVENT_SUSPENDED_POSTCOPY);
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0) {
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0) {
VIR_WARN("Unable to save status on vm %s after state change",
vm->def->name);
}
return -1;
cfg = virQEMUDriverGetConfig(driver);
- ret = virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir);
+ ret = virDomainObjSave(vm, driver->xmlopt, cfg->stateDir);
virObjectUnref(cfg);
return ret;
}
VIR_DEBUG("Writing early domain status to disk");
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
goto cleanup;
VIR_DEBUG("Waiting for handshake from child");
}
VIR_DEBUG("Writing domain status to disk");
- if (virDomainObjSave(vm, driver->xmlopt, driver->caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(vm, driver->xmlopt, cfg->stateDir) < 0)
goto cleanup;
if (qemuProcessStartHook(driver, vm,
}
/* update domain state XML with possibly updated state in virDomainObj */
- if (virDomainObjSave(obj, driver->xmlopt, driver->caps, cfg->stateDir) < 0)
+ if (virDomainObjSave(obj, driver->xmlopt, cfg->stateDir) < 0)
goto error;
/* Run an hook to allow admins to do some magic */
return -1;
ret = virDomainObjSetMetadata(privdom, type, metadata, key, uri,
- privconn->caps, privconn->xmlopt,
+ privconn->xmlopt,
NULL, NULL, flags);
if (ret == 0) {