{
qemuDomainObjPrivatePtr priv = vm->privateData;
virQEMUDriverConfigPtr cfg = virQEMUDriverGetConfig(driver);
+ unsigned long long oldmem = virDomainDefGetMemoryActual(vm->def);
char *devstr = NULL;
char *objalias = NULL;
const char *backendType;
if (fix_balloon)
vm->def->mem.cur_balloon += mem->size;
+ virDomainAuditMemory(vm, oldmem, virDomainDefGetMemoryActual(vm->def),
+ "update", ret == 0);
+
/* mem is consumed by vm->def */
mem = NULL;
virDomainMemoryDefPtr mem)
{
qemuDomainObjPrivatePtr priv = vm->privateData;
+ unsigned long long oldmem = virDomainDefGetMemoryActual(vm->def);
virObjectEventPtr event;
char *backendAlias = NULL;
int rc;
int idx;
+ int ret = -1;
VIR_DEBUG("Removing memory device %s from domain %p %s",
mem->info.alias, vm, vm->def->name);
qemuDomainEventQueue(driver, event);
if (virAsprintf(&backendAlias, "mem%s", mem->info.alias) < 0)
- goto error;
+ goto cleanup;
qemuDomainObjEnterMonitor(driver, vm);
rc = qemuMonitorDelObject(priv->mon, backendAlias);
if (qemuDomainObjExitMonitor(driver, vm) < 0 || rc < 0)
- goto error;
+ goto cleanup;
vm->def->mem.cur_balloon -= mem->size;
virDomainMemoryRemove(vm->def, idx);
virDomainMemoryDefFree(mem);
- VIR_FREE(backendAlias);
- return 0;
+ ret = 0;
+
+ cleanup:
+ virDomainAuditMemory(vm, oldmem, virDomainDefGetMemoryActual(vm->def),
+ "update", ret == 0);
- error:
VIR_FREE(backendAlias);
- return -1;
+ return ret;
}