mirror of https://gitee.com/openkylin/libvirt.git
libxl: detect support for save and restore
libxl does not support save, restore, or migrate on all architectures, notably ARM. Detect whether libxl supports these operations using LIBXL_HAVE_NO_SUSPEND_RESUME. If not supported, drop advertisement of <migration_features>. Found by Ian Campbell while improving Xen's OSSTEST infrastructure http://lists.xen.org/archives/html/xen-devel/2014-06/msg02171.html
This commit is contained in:
parent
39931f5ee8
commit
1d37a4c46b
|
@ -1340,7 +1340,11 @@ libxlMakeCapabilities(libxl_ctx *ctx)
|
||||||
{
|
{
|
||||||
virCapsPtr caps;
|
virCapsPtr caps;
|
||||||
|
|
||||||
|
#ifdef LIBXL_HAVE_NO_SUSPEND_RESUME
|
||||||
|
if ((caps = virCapabilitiesNew(virArchFromHost(), 0, 0)) == NULL)
|
||||||
|
#else
|
||||||
if ((caps = virCapabilitiesNew(virArchFromHost(), 1, 1)) == NULL)
|
if ((caps = virCapabilitiesNew(virArchFromHost(), 1, 1)) == NULL)
|
||||||
|
#endif
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
if (libxlCapsInitHost(ctx, caps) < 0)
|
if (libxlCapsInitHost(ctx, caps) < 0)
|
||||||
|
|
|
@ -1379,6 +1379,11 @@ libxlDomainSaveFlags(virDomainPtr dom, const char *to, const char *dxml,
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
bool remove_dom = false;
|
bool remove_dom = false;
|
||||||
|
|
||||||
|
#ifdef LIBXL_HAVE_NO_SUSPEND_RESUME
|
||||||
|
virReportUnsupportedError();
|
||||||
|
return -1;
|
||||||
|
#endif
|
||||||
|
|
||||||
virCheckFlags(0, -1);
|
virCheckFlags(0, -1);
|
||||||
if (dxml) {
|
if (dxml) {
|
||||||
virReportError(VIR_ERR_ARGUMENT_UNSUPPORTED, "%s",
|
virReportError(VIR_ERR_ARGUMENT_UNSUPPORTED, "%s",
|
||||||
|
@ -1440,6 +1445,11 @@ libxlDomainRestoreFlags(virConnectPtr conn, const char *from,
|
||||||
int fd = -1;
|
int fd = -1;
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
|
|
||||||
|
#ifdef LIBXL_HAVE_NO_SUSPEND_RESUME
|
||||||
|
virReportUnsupportedError();
|
||||||
|
return -1;
|
||||||
|
#endif
|
||||||
|
|
||||||
virCheckFlags(VIR_DOMAIN_SAVE_PAUSED, -1);
|
virCheckFlags(VIR_DOMAIN_SAVE_PAUSED, -1);
|
||||||
if (dxml) {
|
if (dxml) {
|
||||||
virReportError(VIR_ERR_ARGUMENT_UNSUPPORTED, "%s",
|
virReportError(VIR_ERR_ARGUMENT_UNSUPPORTED, "%s",
|
||||||
|
@ -4351,6 +4361,11 @@ libxlDomainMigrateBegin3Params(virDomainPtr domain,
|
||||||
const char *xmlin = NULL;
|
const char *xmlin = NULL;
|
||||||
virDomainObjPtr vm = NULL;
|
virDomainObjPtr vm = NULL;
|
||||||
|
|
||||||
|
#ifdef LIBXL_HAVE_NO_SUSPEND_RESUME
|
||||||
|
virReportUnsupportedError();
|
||||||
|
return NULL;
|
||||||
|
#endif
|
||||||
|
|
||||||
virCheckFlags(LIBXL_MIGRATION_FLAGS, NULL);
|
virCheckFlags(LIBXL_MIGRATION_FLAGS, NULL);
|
||||||
if (virTypedParamsValidate(params, nparams, LIBXL_MIGRATION_PARAMETERS) < 0)
|
if (virTypedParamsValidate(params, nparams, LIBXL_MIGRATION_PARAMETERS) < 0)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
@ -4395,6 +4410,11 @@ libxlDomainMigratePrepare3Params(virConnectPtr dconn,
|
||||||
const char *dname = NULL;
|
const char *dname = NULL;
|
||||||
const char *uri_in = NULL;
|
const char *uri_in = NULL;
|
||||||
|
|
||||||
|
#ifdef LIBXL_HAVE_NO_SUSPEND_RESUME
|
||||||
|
virReportUnsupportedError();
|
||||||
|
return -1;
|
||||||
|
#endif
|
||||||
|
|
||||||
virCheckFlags(LIBXL_MIGRATION_FLAGS, -1);
|
virCheckFlags(LIBXL_MIGRATION_FLAGS, -1);
|
||||||
if (virTypedParamsValidate(params, nparams, LIBXL_MIGRATION_PARAMETERS) < 0)
|
if (virTypedParamsValidate(params, nparams, LIBXL_MIGRATION_PARAMETERS) < 0)
|
||||||
goto error;
|
goto error;
|
||||||
|
@ -4445,6 +4465,11 @@ libxlDomainMigratePerform3Params(virDomainPtr dom,
|
||||||
const char *uri = NULL;
|
const char *uri = NULL;
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
|
|
||||||
|
#ifdef LIBXL_HAVE_NO_SUSPEND_RESUME
|
||||||
|
virReportUnsupportedError();
|
||||||
|
return -1;
|
||||||
|
#endif
|
||||||
|
|
||||||
virCheckFlags(LIBXL_MIGRATION_FLAGS, -1);
|
virCheckFlags(LIBXL_MIGRATION_FLAGS, -1);
|
||||||
if (virTypedParamsValidate(params, nparams, LIBXL_MIGRATION_PARAMETERS) < 0)
|
if (virTypedParamsValidate(params, nparams, LIBXL_MIGRATION_PARAMETERS) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
@ -4497,6 +4522,11 @@ libxlDomainMigrateFinish3Params(virConnectPtr dconn,
|
||||||
virDomainObjPtr vm = NULL;
|
virDomainObjPtr vm = NULL;
|
||||||
const char *dname = NULL;
|
const char *dname = NULL;
|
||||||
|
|
||||||
|
#ifdef LIBXL_HAVE_NO_SUSPEND_RESUME
|
||||||
|
virReportUnsupportedError();
|
||||||
|
return NULL;
|
||||||
|
#endif
|
||||||
|
|
||||||
virCheckFlags(LIBXL_MIGRATION_FLAGS, NULL);
|
virCheckFlags(LIBXL_MIGRATION_FLAGS, NULL);
|
||||||
if (virTypedParamsValidate(params, nparams, LIBXL_MIGRATION_PARAMETERS) < 0)
|
if (virTypedParamsValidate(params, nparams, LIBXL_MIGRATION_PARAMETERS) < 0)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
@ -4545,6 +4575,11 @@ libxlDomainMigrateConfirm3Params(virDomainPtr domain,
|
||||||
libxlDriverPrivatePtr driver = domain->conn->privateData;
|
libxlDriverPrivatePtr driver = domain->conn->privateData;
|
||||||
virDomainObjPtr vm = NULL;
|
virDomainObjPtr vm = NULL;
|
||||||
|
|
||||||
|
#ifdef LIBXL_HAVE_NO_SUSPEND_RESUME
|
||||||
|
virReportUnsupportedError();
|
||||||
|
return -1;
|
||||||
|
#endif
|
||||||
|
|
||||||
virCheckFlags(LIBXL_MIGRATION_FLAGS, -1);
|
virCheckFlags(LIBXL_MIGRATION_FLAGS, -1);
|
||||||
if (virTypedParamsValidate(params, nparams, LIBXL_MIGRATION_PARAMETERS) < 0)
|
if (virTypedParamsValidate(params, nparams, LIBXL_MIGRATION_PARAMETERS) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
Loading…
Reference in New Issue