提交 1cffb25c 编写于 作者: J Jiri Denemark

qemu: Fix old tcp:host URIs more cleanly

For compatibility with old libvirt we need to support both tcp:host and
tcp://host migration URIs. Let's make the code that parses them a bit
cleaner.
Signed-off-by: NJiri Denemark <jdenemar@redhat.com>
上级 30b24df1
...@@ -2817,6 +2817,29 @@ qemuMigrationPrepareTunnel(virQEMUDriverPtr driver, ...@@ -2817,6 +2817,29 @@ qemuMigrationPrepareTunnel(virQEMUDriverPtr driver,
} }
static virURIPtr
qemuMigrationParseURI(const char *uri, bool *wellFormed)
{
char *tmp = NULL;
virURIPtr parsed;
/* For compatibility reasons tcp://... URIs are sent as tcp:...
* We need to transform them to a well-formed URI before parsing. */
if (STRPREFIX(uri, "tcp:") && !STRPREFIX(uri + 4, "//")) {
if (virAsprintf(&tmp, "tcp://%s", uri + 4) < 0)
return NULL;
uri = tmp;
}
parsed = virURIParse(uri);
if (parsed && wellFormed)
*wellFormed = !tmp;
VIR_FREE(tmp);
return parsed;
}
int int
qemuMigrationPrepareDirect(virQEMUDriverPtr driver, qemuMigrationPrepareDirect(virQEMUDriverPtr driver,
virConnectPtr dconn, virConnectPtr dconn,
...@@ -2834,11 +2857,8 @@ qemuMigrationPrepareDirect(virQEMUDriverPtr driver, ...@@ -2834,11 +2857,8 @@ qemuMigrationPrepareDirect(virQEMUDriverPtr driver,
unsigned short port = 0; unsigned short port = 0;
bool autoPort = true; bool autoPort = true;
char *hostname = NULL; char *hostname = NULL;
const char *p;
char *uri_str = NULL;
int ret = -1; int ret = -1;
virURIPtr uri = NULL; virURIPtr uri = NULL;
bool well_formed_uri = true;
virQEMUDriverConfigPtr cfg = virQEMUDriverGetConfig(driver); virQEMUDriverConfigPtr cfg = virQEMUDriverGetConfig(driver);
const char *migrateHost = cfg->migrateHost; const char *migrateHost = cfg->migrateHost;
...@@ -2890,34 +2910,18 @@ qemuMigrationPrepareDirect(virQEMUDriverPtr driver, ...@@ -2890,34 +2910,18 @@ qemuMigrationPrepareDirect(virQEMUDriverPtr driver,
* compatibility with old targets. We at least make the * compatibility with old targets. We at least make the
* new targets accept both syntaxes though. * new targets accept both syntaxes though.
*/ */
/* Caller frees */
if (virAsprintf(uri_out, "tcp:%s:%d", hostname, port) < 0) if (virAsprintf(uri_out, "tcp:%s:%d", hostname, port) < 0)
goto cleanup; goto cleanup;
} else { } else {
/* Check the URI starts with "tcp:". We will escape the bool well_formed_uri;
* URI when passing it to the qemu monitor, so bad
* characters in hostname part don't matter.
*/
if (!(p = STRSKIP(uri_in, "tcp:"))) {
virReportError(VIR_ERR_INVALID_ARG, "%s",
_("only tcp URIs are supported for KVM/QEMU"
" migrations"));
goto cleanup;
}
/* Convert uri_in to well-formed URI with // after tcp: */ if (!(uri = qemuMigrationParseURI(uri_in, &well_formed_uri)))
if (!(STRPREFIX(uri_in, "tcp://"))) {
well_formed_uri = false;
if (virAsprintf(&uri_str, "tcp://%s", p) < 0)
goto cleanup; goto cleanup;
}
uri = virURIParse(uri_str ? uri_str : uri_in); if (STRNEQ(uri->scheme, "tcp")) {
VIR_FREE(uri_str); virReportError(VIR_ERR_ARGUMENT_UNSUPPORTED,
_("unsupported scheme %s in migration URI %s"),
if (uri == NULL) { uri->scheme, uri_in);
virReportError(VIR_ERR_INVALID_ARG, _("unable to parse URI: %s"),
uri_in);
goto cleanup; goto cleanup;
} }
...@@ -2931,18 +2935,15 @@ qemuMigrationPrepareDirect(virQEMUDriverPtr driver, ...@@ -2931,18 +2935,15 @@ qemuMigrationPrepareDirect(virQEMUDriverPtr driver,
if (virPortAllocatorAcquire(driver->migrationPorts, &port) < 0) if (virPortAllocatorAcquire(driver->migrationPorts, &port) < 0)
goto cleanup; goto cleanup;
/* Send well-formed URI only if uri_in was well-formed */
if (well_formed_uri) { if (well_formed_uri) {
uri->port = port; uri->port = port;
/* Caller frees */
if (!(*uri_out = virURIFormat(uri))) if (!(*uri_out = virURIFormat(uri)))
goto cleanup; goto cleanup;
} else { } else {
/* Caller frees */
if (virAsprintf(uri_out, "%s:%d", uri_in, port) < 0) if (virAsprintf(uri_out, "%s:%d", uri_in, port) < 0)
goto cleanup; goto cleanup;
} }
} else { } else {
port = uri->port; port = uri->port;
autoPort = false; autoPort = false;
...@@ -3704,17 +3705,7 @@ static int doNativeMigrate(virQEMUDriverPtr driver, ...@@ -3704,17 +3705,7 @@ static int doNativeMigrate(virQEMUDriverPtr driver,
cookieout, cookieoutlen, flags, resource, cookieout, cookieoutlen, flags, resource,
NULLSTR(graphicsuri)); NULLSTR(graphicsuri));
if (STRPREFIX(uri, "tcp:") && !STRPREFIX(uri, "tcp://")) { if (!(uribits = qemuMigrationParseURI(uri, NULL)))
char *tmp;
/* HACK: source host generates bogus URIs, so fix them up */
if (virAsprintf(&tmp, "tcp://%s", uri + strlen("tcp:")) < 0)
return -1;
uribits = virURIParse(tmp);
VIR_FREE(tmp);
} else {
uribits = virURIParse(uri);
}
if (!uribits)
return -1; return -1;
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_MIGRATE_QEMU_FD)) if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_MIGRATE_QEMU_FD))
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册