qemu: update callers of qemuProcessStartValidate to use virDomainObjPtr

This change is required by following patches.

Signed-off-by: Pavel Hrdina <phrdina@redhat.com>
This commit is contained in:
Pavel Hrdina 2016-03-17 13:19:35 +01:00
parent ddc0e6bcdc
commit a431d3440f
2 changed files with 42 additions and 40 deletions

View File

@ -6948,9 +6948,9 @@ static char *qemuConnectDomainXMLToNative(virConnectPtr conn,
unsigned int flags) unsigned int flags)
{ {
virQEMUDriverPtr driver = conn->privateData; virQEMUDriverPtr driver = conn->privateData;
virDomainDefPtr def = NULL;
virDomainChrSourceDef monConfig = {0}; virDomainChrSourceDef monConfig = {0};
virQEMUCapsPtr qemuCaps = NULL; virQEMUCapsPtr qemuCaps = NULL;
virDomainObjPtr vm = NULL;
bool monitor_json = false; bool monitor_json = false;
virCommandPtr cmd = NULL; virCommandPtr cmd = NULL;
char *ret = NULL; char *ret = NULL;
@ -6976,22 +6976,21 @@ static char *qemuConnectDomainXMLToNative(virConnectPtr conn,
if (!(caps = virQEMUDriverGetCapabilities(driver, false))) if (!(caps = virQEMUDriverGetCapabilities(driver, false)))
goto cleanup; goto cleanup;
def = virDomainDefParseString(xmlData, caps, driver->xmlopt, if (!(vm = virDomainObjNew(driver->xmlopt)))
goto cleanup;
if (!(vm->def = virDomainDefParseString(xmlData, caps, driver->xmlopt,
VIR_DOMAIN_DEF_PARSE_INACTIVE | VIR_DOMAIN_DEF_PARSE_INACTIVE |
VIR_DOMAIN_DEF_PARSE_ABI_UPDATE); VIR_DOMAIN_DEF_PARSE_ABI_UPDATE)))
if (!def)
goto cleanup; goto cleanup;
if (!(qemuCaps = virQEMUCapsCacheLookup(driver->qemuCapsCache, def->emulator))) if (qemuProcessStartValidate(vm->def, qemuCaps, false, false) < 0)
goto cleanup;
if (qemuProcessStartValidate(def, qemuCaps, false, false) < 0)
goto cleanup; goto cleanup;
/* Generate per-domain paths because we don't have the domain object */ /* Generate per-domain paths because we don't have the domain object */
if (qemuDomainSetPrivatePaths(&domainLibDir, &domainChannelTargetDir, if (qemuDomainSetPrivatePaths(&domainLibDir, &domainChannelTargetDir,
cfg->libDir, cfg->channelTargetDir, cfg->libDir, cfg->channelTargetDir,
def->name, -1) < 0) vm->def->name, -1) < 0)
goto cleanup; goto cleanup;
/* Since we're just exporting args, we can't do bridge/network/direct /* Since we're just exporting args, we can't do bridge/network/direct
@ -6999,8 +6998,8 @@ static char *qemuConnectDomainXMLToNative(virConnectPtr conn,
* directly. We convert those configs into generic 'ethernet' * directly. We convert those configs into generic 'ethernet'
* config and assume the user has suitable 'ifup-qemu' scripts * config and assume the user has suitable 'ifup-qemu' scripts
*/ */
for (i = 0; i < def->nnets; i++) { for (i = 0; i < vm->def->nnets; i++) {
virDomainNetDefPtr net = def->nets[i]; virDomainNetDefPtr net = vm->def->nets[i];
int bootIndex = net->info.bootIndex; int bootIndex = net->info.bootIndex;
char *model = net->model; char *model = net->model;
virMacAddr mac = net->mac; virMacAddr mac = net->mac;
@ -7084,18 +7083,18 @@ static char *qemuConnectDomainXMLToNative(virConnectPtr conn,
monitor_json = virQEMUCapsGet(qemuCaps, QEMU_CAPS_MONITOR_JSON); monitor_json = virQEMUCapsGet(qemuCaps, QEMU_CAPS_MONITOR_JSON);
if (qemuProcessPrepareMonitorChr(&monConfig, def->name) < 0) if (qemuProcessPrepareMonitorChr(&monConfig, vm->def->name) < 0)
goto cleanup; goto cleanup;
if (qemuAssignDeviceAliases(def, qemuCaps) < 0) if (qemuAssignDeviceAliases(vm->def, qemuCaps) < 0)
goto cleanup; goto cleanup;
if (qemuDomainAssignAddresses(def, qemuCaps, NULL) < 0) if (qemuDomainAssignAddresses(vm->def, qemuCaps, NULL) < 0)
goto cleanup; goto cleanup;
/* do fake auto-alloc of graphics ports, if such config is used */ /* do fake auto-alloc of graphics ports, if such config is used */
for (i = 0; i < def->ngraphics; ++i) { for (i = 0; i < vm->def->ngraphics; ++i) {
virDomainGraphicsDefPtr graphics = def->graphics[i]; virDomainGraphicsDefPtr graphics = vm->def->graphics[i];
if (graphics->type == VIR_DOMAIN_GRAPHICS_TYPE_VNC && if (graphics->type == VIR_DOMAIN_GRAPHICS_TYPE_VNC &&
!graphics->data.vnc.socket && graphics->data.vnc.autoport) { !graphics->data.vnc.socket && graphics->data.vnc.autoport) {
graphics->data.vnc.port = 5900; graphics->data.vnc.port = 5900;
@ -7105,7 +7104,7 @@ static char *qemuConnectDomainXMLToNative(virConnectPtr conn,
} }
} }
if (!(cmd = qemuBuildCommandLine(conn, driver, NULL, def, if (!(cmd = qemuBuildCommandLine(conn, driver, NULL, vm->def,
&monConfig, monitor_json, qemuCaps, &monConfig, monitor_json, qemuCaps,
NULL, NULL, NULL, NULL,
VIR_NETDEV_VPORT_PROFILE_OP_NO_OP, VIR_NETDEV_VPORT_PROFILE_OP_NO_OP,
@ -7122,7 +7121,7 @@ static char *qemuConnectDomainXMLToNative(virConnectPtr conn,
cleanup: cleanup:
virObjectUnref(qemuCaps); virObjectUnref(qemuCaps);
virCommandFree(cmd); virCommandFree(cmd);
virDomainDefFree(def); virObjectUnref(vm);
virObjectUnref(caps); virObjectUnref(caps);
virObjectUnref(cfg); virObjectUnref(cfg);
VIR_FREE(domainLibDir); VIR_FREE(domainLibDir);

View File

@ -258,7 +258,7 @@ static int testCompareXMLToArgvFiles(const char *xml,
{ {
char *actualargv = NULL; char *actualargv = NULL;
int ret = -1; int ret = -1;
virDomainDefPtr vmdef = NULL; virDomainObjPtr vm = NULL;
virDomainChrSourceDef monitor_chr; virDomainChrSourceDef monitor_chr;
virConnectPtr conn; virConnectPtr conn;
char *log = NULL; char *log = NULL;
@ -276,7 +276,10 @@ static int testCompareXMLToArgvFiles(const char *xml,
if (virBitmapParse("0-3", '\0', &nodeset, 4) < 0) if (virBitmapParse("0-3", '\0', &nodeset, 4) < 0)
goto out; goto out;
if (!(vmdef = virDomainDefParseFile(xml, driver.caps, driver.xmlopt, if (!(vm = virDomainObjNew(driver.xmlopt)))
goto out;
if (!(vm->def = virDomainDefParseFile(xml, driver.caps, driver.xmlopt,
(VIR_DOMAIN_DEF_PARSE_INACTIVE | (VIR_DOMAIN_DEF_PARSE_INACTIVE |
parseFlags)))) { parseFlags)))) {
if (flags & FLAG_EXPECT_PARSE_ERROR) if (flags & FLAG_EXPECT_PARSE_ERROR)
@ -284,16 +287,16 @@ static int testCompareXMLToArgvFiles(const char *xml,
goto out; goto out;
} }
if (!virDomainDefCheckABIStability(vmdef, vmdef)) { if (!virDomainDefCheckABIStability(vm->def, vm->def)) {
VIR_TEST_DEBUG("ABI stability check failed on %s", xml); VIR_TEST_DEBUG("ABI stability check failed on %s", xml);
goto out; goto out;
} }
vmdef->id = -1; vm->def->id = -1;
if (qemuDomainSetPrivatePaths(&domainLibDir, &domainChannelTargetDir, if (qemuDomainSetPrivatePaths(&domainLibDir, &domainChannelTargetDir,
"/tmp/lib", "/tmp/channel", "/tmp/lib", "/tmp/channel",
vmdef->name, vmdef->id) < 0) vm->def->name, vm->def->id) < 0)
goto out; goto out;
memset(&monitor_chr, 0, sizeof(monitor_chr)); memset(&monitor_chr, 0, sizeof(monitor_chr));
@ -305,16 +308,16 @@ static int testCompareXMLToArgvFiles(const char *xml,
QEMU_CAPS_DEVICE, QEMU_CAPS_DEVICE,
QEMU_CAPS_LAST); QEMU_CAPS_LAST);
if (STREQ(vmdef->os.machine, "pc") && if (STREQ(vm->def->os.machine, "pc") &&
STREQ(vmdef->emulator, "/usr/bin/qemu-system-x86_64")) { STREQ(vm->def->emulator, "/usr/bin/qemu-system-x86_64")) {
VIR_FREE(vmdef->os.machine); VIR_FREE(vm->def->os.machine);
if (VIR_STRDUP(vmdef->os.machine, "pc-0.11") < 0) if (VIR_STRDUP(vm->def->os.machine, "pc-0.11") < 0)
goto out; goto out;
} }
virQEMUCapsFilterByMachineType(extraFlags, vmdef->os.machine); virQEMUCapsFilterByMachineType(extraFlags, vm->def->os.machine);
if (qemuDomainAssignAddresses(vmdef, extraFlags, NULL)) { if (qemuDomainAssignAddresses(vm->def, extraFlags, NULL)) {
if (flags & FLAG_EXPECT_ERROR) if (flags & FLAG_EXPECT_ERROR)
goto ok; goto ok;
goto out; goto out;
@ -324,16 +327,16 @@ static int testCompareXMLToArgvFiles(const char *xml,
VIR_FREE(log); VIR_FREE(log);
virResetLastError(); virResetLastError();
if (vmdef->os.arch == VIR_ARCH_X86_64 || if (vm->def->os.arch == VIR_ARCH_X86_64 ||
vmdef->os.arch == VIR_ARCH_I686) { vm->def->os.arch == VIR_ARCH_I686) {
virQEMUCapsSet(extraFlags, QEMU_CAPS_PCI_MULTIBUS); virQEMUCapsSet(extraFlags, QEMU_CAPS_PCI_MULTIBUS);
} }
if (qemuAssignDeviceAliases(vmdef, extraFlags) < 0) if (qemuAssignDeviceAliases(vm->def, extraFlags) < 0)
goto out; goto out;
for (i = 0; i < vmdef->nhostdevs; i++) { for (i = 0; i < vm->def->nhostdevs; i++) {
virDomainHostdevDefPtr hostdev = vmdef->hostdevs[i]; virDomainHostdevDefPtr hostdev = vm->def->hostdevs[i];
if (hostdev->mode == VIR_DOMAIN_HOSTDEV_MODE_SUBSYS && if (hostdev->mode == VIR_DOMAIN_HOSTDEV_MODE_SUBSYS &&
hostdev->source.subsys.type == VIR_DOMAIN_HOSTDEV_SUBSYS_TYPE_PCI && hostdev->source.subsys.type == VIR_DOMAIN_HOSTDEV_SUBSYS_TYPE_PCI &&
@ -342,18 +345,18 @@ static int testCompareXMLToArgvFiles(const char *xml,
} }
} }
for (i = 0; i < vmdef->ndisks; i++) { for (i = 0; i < vm->def->ndisks; i++) {
if (virStorageTranslateDiskSourcePool(conn, vmdef->disks[i]) < 0) if (virStorageTranslateDiskSourcePool(conn, vm->def->disks[i]) < 0)
goto out; goto out;
} }
if (qemuProcessStartValidate(vmdef, extraFlags, !!migrateURI, false) < 0) { if (qemuProcessStartValidate(vm->def, extraFlags, !!migrateURI, false) < 0) {
if (flags & FLAG_EXPECT_FAILURE) if (flags & FLAG_EXPECT_FAILURE)
goto ok; goto ok;
goto out; goto out;
} }
if (!(cmd = qemuBuildCommandLine(conn, &driver, NULL, vmdef, &monitor_chr, if (!(cmd = qemuBuildCommandLine(conn, &driver, NULL, vm->def, &monitor_chr,
(flags & FLAG_JSON), extraFlags, (flags & FLAG_JSON), extraFlags,
migrateURI, NULL, migrateURI, NULL,
VIR_NETDEV_VPORT_PROFILE_OP_NO_OP, VIR_NETDEV_VPORT_PROFILE_OP_NO_OP,
@ -398,7 +401,7 @@ static int testCompareXMLToArgvFiles(const char *xml,
VIR_FREE(log); VIR_FREE(log);
VIR_FREE(actualargv); VIR_FREE(actualargv);
virCommandFree(cmd); virCommandFree(cmd);
virDomainDefFree(vmdef); virObjectUnref(vm);
virObjectUnref(conn); virObjectUnref(conn);
virBitmapFree(nodeset); virBitmapFree(nodeset);
VIR_FREE(domainLibDir); VIR_FREE(domainLibDir);