mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-18 10:35:20 +00:00
qemuMigrationCookieXMLParse: Remove 'error' label
Now it only returns -1 so we can do that directly. Signed-off-by: Peter Krempa <pkrempa@redhat.com> Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
This commit is contained in:
parent
8c3f86e290
commit
600c1b5202
@ -1221,33 +1221,33 @@ qemuMigrationCookieXMLParse(qemuMigrationCookiePtr mig,
|
|||||||
if (!(name = virXPathString("string(./name[1])", ctxt))) {
|
if (!(name = virXPathString("string(./name[1])", ctxt))) {
|
||||||
virReportError(VIR_ERR_INTERNAL_ERROR,
|
virReportError(VIR_ERR_INTERNAL_ERROR,
|
||||||
"%s", _("missing name element in migration data"));
|
"%s", _("missing name element in migration data"));
|
||||||
goto error;
|
return -1;
|
||||||
}
|
}
|
||||||
if (STRNEQ(name, mig->name)) {
|
if (STRNEQ(name, mig->name)) {
|
||||||
virReportError(VIR_ERR_INTERNAL_ERROR,
|
virReportError(VIR_ERR_INTERNAL_ERROR,
|
||||||
_("Incoming cookie data had unexpected name %s vs %s"),
|
_("Incoming cookie data had unexpected name %s vs %s"),
|
||||||
name, mig->name);
|
name, mig->name);
|
||||||
goto error;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Extract domain uuid */
|
/* Extract domain uuid */
|
||||||
if (!(uuid = virXPathString("string(./uuid[1])", ctxt))) {
|
if (!(uuid = virXPathString("string(./uuid[1])", ctxt))) {
|
||||||
virReportError(VIR_ERR_INTERNAL_ERROR,
|
virReportError(VIR_ERR_INTERNAL_ERROR,
|
||||||
"%s", _("missing uuid element in migration data"));
|
"%s", _("missing uuid element in migration data"));
|
||||||
goto error;
|
return -1;
|
||||||
}
|
}
|
||||||
virUUIDFormat(mig->uuid, localdomuuid);
|
virUUIDFormat(mig->uuid, localdomuuid);
|
||||||
if (STRNEQ(uuid, localdomuuid)) {
|
if (STRNEQ(uuid, localdomuuid)) {
|
||||||
virReportError(VIR_ERR_INTERNAL_ERROR,
|
virReportError(VIR_ERR_INTERNAL_ERROR,
|
||||||
_("Incoming cookie data had unexpected UUID %s vs %s"),
|
_("Incoming cookie data had unexpected UUID %s vs %s"),
|
||||||
uuid, localdomuuid);
|
uuid, localdomuuid);
|
||||||
goto error;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!(mig->remoteHostname = virXPathString("string(./hostname[1])", ctxt))) {
|
if (!(mig->remoteHostname = virXPathString("string(./hostname[1])", ctxt))) {
|
||||||
virReportError(VIR_ERR_INTERNAL_ERROR,
|
virReportError(VIR_ERR_INTERNAL_ERROR,
|
||||||
"%s", _("missing hostname element in migration data"));
|
"%s", _("missing hostname element in migration data"));
|
||||||
goto error;
|
return -1;
|
||||||
}
|
}
|
||||||
/* Historically, this is the place where we checked whether remoteHostname
|
/* Historically, this is the place where we checked whether remoteHostname
|
||||||
* and localHostname are the same. But even if they were, it doesn't mean
|
* and localHostname are the same. But even if they were, it doesn't mean
|
||||||
@ -1258,18 +1258,18 @@ qemuMigrationCookieXMLParse(qemuMigrationCookiePtr mig,
|
|||||||
if (!(hostuuid = virXPathString("string(./hostuuid[1])", ctxt))) {
|
if (!(hostuuid = virXPathString("string(./hostuuid[1])", ctxt))) {
|
||||||
virReportError(VIR_ERR_INTERNAL_ERROR,
|
virReportError(VIR_ERR_INTERNAL_ERROR,
|
||||||
"%s", _("missing hostuuid element in migration data"));
|
"%s", _("missing hostuuid element in migration data"));
|
||||||
goto error;
|
return -1;
|
||||||
}
|
}
|
||||||
if (virUUIDParse(hostuuid, mig->remoteHostuuid) < 0) {
|
if (virUUIDParse(hostuuid, mig->remoteHostuuid) < 0) {
|
||||||
virReportError(VIR_ERR_INTERNAL_ERROR,
|
virReportError(VIR_ERR_INTERNAL_ERROR,
|
||||||
"%s", _("malformed hostuuid element in migration data"));
|
"%s", _("malformed hostuuid element in migration data"));
|
||||||
goto error;
|
return -1;
|
||||||
}
|
}
|
||||||
if (memcmp(mig->remoteHostuuid, mig->localHostuuid, VIR_UUID_BUFLEN) == 0) {
|
if (memcmp(mig->remoteHostuuid, mig->localHostuuid, VIR_UUID_BUFLEN) == 0) {
|
||||||
virReportError(VIR_ERR_INTERNAL_ERROR,
|
virReportError(VIR_ERR_INTERNAL_ERROR,
|
||||||
_("Attempt to migrate guest to the same host %s"),
|
_("Attempt to migrate guest to the same host %s"),
|
||||||
hostuuid);
|
hostuuid);
|
||||||
goto error;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (qemuMigrationCookieXMLParseMandatoryFeatures(ctxt, flags) < 0)
|
if (qemuMigrationCookieXMLParseMandatoryFeatures(ctxt, flags) < 0)
|
||||||
@ -1278,7 +1278,7 @@ qemuMigrationCookieXMLParse(qemuMigrationCookiePtr mig,
|
|||||||
if ((flags & QEMU_MIGRATION_COOKIE_GRAPHICS) &&
|
if ((flags & QEMU_MIGRATION_COOKIE_GRAPHICS) &&
|
||||||
virXPathBoolean("count(./graphics) > 0", ctxt) &&
|
virXPathBoolean("count(./graphics) > 0", ctxt) &&
|
||||||
(!(mig->graphics = qemuMigrationCookieGraphicsXMLParse(ctxt))))
|
(!(mig->graphics = qemuMigrationCookieGraphicsXMLParse(ctxt))))
|
||||||
goto error;
|
return -1;
|
||||||
|
|
||||||
if ((flags & QEMU_MIGRATION_COOKIE_LOCKSTATE) &&
|
if ((flags & QEMU_MIGRATION_COOKIE_LOCKSTATE) &&
|
||||||
virXPathBoolean("count(./lockstate) > 0", ctxt)) {
|
virXPathBoolean("count(./lockstate) > 0", ctxt)) {
|
||||||
@ -1286,7 +1286,7 @@ qemuMigrationCookieXMLParse(qemuMigrationCookiePtr mig,
|
|||||||
if (!mig->lockDriver) {
|
if (!mig->lockDriver) {
|
||||||
virReportError(VIR_ERR_INTERNAL_ERROR, "%s",
|
virReportError(VIR_ERR_INTERNAL_ERROR, "%s",
|
||||||
_("Missing lock driver name in migration cookie"));
|
_("Missing lock driver name in migration cookie"));
|
||||||
goto error;
|
return -1;
|
||||||
}
|
}
|
||||||
mig->lockState = virXPathString("string(./lockstate[1]/leases[1])", ctxt);
|
mig->lockState = virXPathString("string(./lockstate[1]/leases[1])", ctxt);
|
||||||
if (mig->lockState && STREQ(mig->lockState, ""))
|
if (mig->lockState && STREQ(mig->lockState, ""))
|
||||||
@ -1300,7 +1300,7 @@ qemuMigrationCookieXMLParse(qemuMigrationCookiePtr mig,
|
|||||||
if ((virXPathNodeSet("./domain", ctxt, &nodes)) != 1) {
|
if ((virXPathNodeSet("./domain", ctxt, &nodes)) != 1) {
|
||||||
virReportError(VIR_ERR_INTERNAL_ERROR, "%s",
|
virReportError(VIR_ERR_INTERNAL_ERROR, "%s",
|
||||||
_("Too many domain elements in migration cookie"));
|
_("Too many domain elements in migration cookie"));
|
||||||
goto error;
|
return -1;
|
||||||
}
|
}
|
||||||
mig->persistent = virDomainDefParseNode(doc, nodes[0],
|
mig->persistent = virDomainDefParseNode(doc, nodes[0],
|
||||||
driver->xmlopt, qemuCaps,
|
driver->xmlopt, qemuCaps,
|
||||||
@ -1308,40 +1308,37 @@ qemuMigrationCookieXMLParse(qemuMigrationCookiePtr mig,
|
|||||||
VIR_DOMAIN_DEF_PARSE_ABI_UPDATE_MIGRATION |
|
VIR_DOMAIN_DEF_PARSE_ABI_UPDATE_MIGRATION |
|
||||||
VIR_DOMAIN_DEF_PARSE_SKIP_VALIDATE);
|
VIR_DOMAIN_DEF_PARSE_SKIP_VALIDATE);
|
||||||
if (!mig->persistent)
|
if (!mig->persistent)
|
||||||
goto error;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((flags & QEMU_MIGRATION_COOKIE_NETWORK) &&
|
if ((flags & QEMU_MIGRATION_COOKIE_NETWORK) &&
|
||||||
virXPathBoolean("count(./network) > 0", ctxt) &&
|
virXPathBoolean("count(./network) > 0", ctxt) &&
|
||||||
(!(mig->network = qemuMigrationCookieNetworkXMLParse(ctxt))))
|
(!(mig->network = qemuMigrationCookieNetworkXMLParse(ctxt))))
|
||||||
goto error;
|
return -1;
|
||||||
|
|
||||||
if (flags & QEMU_MIGRATION_COOKIE_NBD &&
|
if (flags & QEMU_MIGRATION_COOKIE_NBD &&
|
||||||
virXPathBoolean("boolean(./nbd)", ctxt) &&
|
virXPathBoolean("boolean(./nbd)", ctxt) &&
|
||||||
(!(mig->nbd = qemuMigrationCookieNBDXMLParse(ctxt))))
|
(!(mig->nbd = qemuMigrationCookieNBDXMLParse(ctxt))))
|
||||||
goto error;
|
return -1;
|
||||||
|
|
||||||
if (flags & QEMU_MIGRATION_COOKIE_STATS &&
|
if (flags & QEMU_MIGRATION_COOKIE_STATS &&
|
||||||
virXPathBoolean("boolean(./statistics)", ctxt) &&
|
virXPathBoolean("boolean(./statistics)", ctxt) &&
|
||||||
(!(mig->jobInfo = qemuMigrationCookieStatisticsXMLParse(ctxt))))
|
(!(mig->jobInfo = qemuMigrationCookieStatisticsXMLParse(ctxt))))
|
||||||
goto error;
|
return -1;
|
||||||
|
|
||||||
if (flags & QEMU_MIGRATION_COOKIE_CPU &&
|
if (flags & QEMU_MIGRATION_COOKIE_CPU &&
|
||||||
virCPUDefParseXML(ctxt, "./cpu[1]", VIR_CPU_TYPE_GUEST, &mig->cpu) < 0)
|
virCPUDefParseXML(ctxt, "./cpu[1]", VIR_CPU_TYPE_GUEST, &mig->cpu) < 0)
|
||||||
goto error;
|
return -1;
|
||||||
|
|
||||||
if (flags & QEMU_MIGRATION_COOKIE_ALLOW_REBOOT &&
|
if (flags & QEMU_MIGRATION_COOKIE_ALLOW_REBOOT &&
|
||||||
qemuDomainObjPrivateXMLParseAllowReboot(ctxt, &mig->allowReboot) < 0)
|
qemuDomainObjPrivateXMLParseAllowReboot(ctxt, &mig->allowReboot) < 0)
|
||||||
goto error;
|
return -1;
|
||||||
|
|
||||||
if (flags & QEMU_MIGRATION_COOKIE_CAPS &&
|
if (flags & QEMU_MIGRATION_COOKIE_CAPS &&
|
||||||
!(mig->caps = qemuMigrationCookieCapsXMLParse(ctxt)))
|
!(mig->caps = qemuMigrationCookieCapsXMLParse(ctxt)))
|
||||||
goto error;
|
return -1;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
error:
|
|
||||||
return -1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user