From 68f63673daaaa5ff953336461a096df7205ffe97 Mon Sep 17 00:00:00 2001 From: Jiri Denemark Date: Fri, 12 Mar 2010 14:55:27 +0100 Subject: [PATCH] Public virDomainMigrateSetMaxDowntime API --- include/libvirt/libvirt.h.in | 4 +++ src/libvirt.c | 49 ++++++++++++++++++++++++++++++++++++ src/libvirt_public.syms | 1 + 3 files changed, 54 insertions(+) diff --git a/include/libvirt/libvirt.h.in b/include/libvirt/libvirt.h.in index 1430a959ed..12b8ea12b0 100644 --- a/include/libvirt/libvirt.h.in +++ b/include/libvirt/libvirt.h.in @@ -408,6 +408,10 @@ int virDomainMigrateToURI (virDomainPtr domain, const char *duri, unsigned long flags, const char *dname, unsigned long bandwidth); +int virDomainMigrateSetMaxDowntime (virDomainPtr domain, + unsigned long long downtime, + unsigned int flags); + /** * VIR_NODEINFO_MAXCPUS: * @nodeinfo: virNodeInfo instance diff --git a/src/libvirt.c b/src/libvirt.c index 74b075b6f5..7b74fd9336 100644 --- a/src/libvirt.c +++ b/src/libvirt.c @@ -11312,3 +11312,52 @@ error: virDispatchError(conn); return -1; } + + +/** + * virDomainMigrateSetMaxDowntime: + * @domain: a domain object + * @downtime: maximum tolerable downtime for live migration, in milliseconds + * @flags: fine-tuning flags, currently unused, use 0 + * + * Sets maximum tolerable time for which the domain is allowed to be paused + * at the end of live migration. It's supposed to be called while the domain is + * being live-migrated as a reaction to migration progress. + * + * Returns 0 in case of success, -1 otherwise. + */ +int +virDomainMigrateSetMaxDowntime(virDomainPtr domain, + unsigned long long downtime, + unsigned int flags) +{ + virConnectPtr conn; + + DEBUG("domain=%p, downtime=%llu, flags=%u", domain, downtime, flags); + + virResetLastError(); + + if (!VIR_IS_CONNECTED_DOMAIN(domain)) { + virLibDomainError(NULL, VIR_ERR_INVALID_DOMAIN, __FUNCTION__); + virDispatchError(NULL); + return -1; + } + + conn = domain->conn; + if (conn->flags & VIR_CONNECT_RO) { + virLibDomainError(domain, VIR_ERR_OPERATION_DENIED, __FUNCTION__); + goto error; + } + + if (conn->driver->domainMigrateSetMaxDowntime) { + if (conn->driver->domainMigrateSetMaxDowntime(domain, downtime, flags) < 0) + goto error; + return 0; + } + + virLibConnError(conn, VIR_ERR_NO_SUPPORT, __FUNCTION__); + +error: + virDispatchError(conn); + return -1; +} diff --git a/src/libvirt_public.syms b/src/libvirt_public.syms index 8c72ec6142..623e53cb11 100644 --- a/src/libvirt_public.syms +++ b/src/libvirt_public.syms @@ -361,6 +361,7 @@ LIBVIRT_0.7.7 { LIBVIRT_0.7.8 { global: virStorageVolWipe; + virDomainMigrateSetMaxDowntime; } LIBVIRT_0.7.7; # .... define new API here using predicted next version number ....