mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-18 10:35:20 +00:00
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:
parent
ddc0e6bcdc
commit
a431d3440f
@ -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)))
|
||||||
VIR_DOMAIN_DEF_PARSE_INACTIVE |
|
|
||||||
VIR_DOMAIN_DEF_PARSE_ABI_UPDATE);
|
|
||||||
if (!def)
|
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if (!(qemuCaps = virQEMUCapsCacheLookup(driver->qemuCapsCache, def->emulator)))
|
if (!(vm->def = virDomainDefParseString(xmlData, caps, driver->xmlopt,
|
||||||
|
VIR_DOMAIN_DEF_PARSE_INACTIVE |
|
||||||
|
VIR_DOMAIN_DEF_PARSE_ABI_UPDATE)))
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if (qemuProcessStartValidate(def, qemuCaps, false, false) < 0)
|
if (qemuProcessStartValidate(vm->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);
|
||||||
|
@ -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,24 +276,27 @@ 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)))
|
||||||
(VIR_DOMAIN_DEF_PARSE_INACTIVE |
|
goto out;
|
||||||
parseFlags)))) {
|
|
||||||
|
if (!(vm->def = virDomainDefParseFile(xml, driver.caps, driver.xmlopt,
|
||||||
|
(VIR_DOMAIN_DEF_PARSE_INACTIVE |
|
||||||
|
parseFlags)))) {
|
||||||
if (flags & FLAG_EXPECT_PARSE_ERROR)
|
if (flags & FLAG_EXPECT_PARSE_ERROR)
|
||||||
goto ok;
|
goto ok;
|
||||||
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);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user