#include "xm_internal.h"
/* The five Xen drivers below us. */
-static virDriverPtr drivers[] = {
+static virDriverPtr drivers[XEN_UNIFIED_NR_DRIVERS] = {
&xenHypervisorDriver,
&xenProxyDriver,
&xenDaemonDriver,
&xenStoreDriver,
&xenXMDriver
};
-static const int nb_drivers = sizeof drivers / sizeof drivers[0];
static const int hypervisor_offset = 0;
static const int proxy_offset = 1;
priv->xshandle = NULL;
priv->proxy = -1;
- for (i = 0; i < nb_drivers; ++i) {
- int failed_to_open = 1;
+ for (i = 0; i < XEN_UNIFIED_NR_DRIVERS; ++i) {
+ priv->opened[i] = 0;
/* Ignore proxy for root */
if (i == proxy_offset && getuid() == 0)
if (drivers[i]->open &&
drivers[i]->open (conn, name, flags) == VIR_DRV_OPEN_SUCCESS)
- failed_to_open = 0;
+ priv->opened[i] = 1;
/* If as root, then all drivers must succeed.
If non-root, then only proxy must succeed */
- if (failed_to_open && (getuid() == 0 || i == proxy_offset)) {
+ if (!priv->opened[i] && (getuid() == 0 || i == proxy_offset)) {
for (j = 0; j < i; ++j)
- drivers[j]->close (conn);
+ if (priv->opened[j]) drivers[j]->close (conn);
return VIR_DRV_OPEN_ERROR;
}
}
return VIR_DRV_OPEN_SUCCESS;
}
+#define GET_PRIVATE(conn) \
+ xenUnifiedPrivatePtr priv = (xenUnifiedPrivatePtr) (conn)->privateData
+
static int
xenUnifiedClose (virConnectPtr conn)
{
+ GET_PRIVATE(conn);
int i;
- for (i = 0; i < nb_drivers; ++i)
- if (drivers[i]->close)
+ for (i = 0; i < XEN_UNIFIED_NR_DRIVERS; ++i)
+ if (priv->opened[i] && drivers[i]->close)
(void) drivers[i]->close (conn);
free (conn->privateData);
static const char *
xenUnifiedType (virConnectPtr conn)
{
+ GET_PRIVATE(conn);
int i;
const char *ret;
- for (i = 0; i < nb_drivers; ++i)
- if (drivers[i]->type) {
+ for (i = 0; i < XEN_UNIFIED_NR_DRIVERS; ++i)
+ if (priv->opened[i] && drivers[i]->type) {
ret = drivers[i]->type (conn);
if (ret) return ret;
}
static int
xenUnifiedVersion (virConnectPtr conn, unsigned long *hvVer)
{
+ GET_PRIVATE(conn);
int i;
- for (i = 0; i < nb_drivers; ++i)
- if (drivers[i]->version &&
+ for (i = 0; i < XEN_UNIFIED_NR_DRIVERS; ++i)
+ if (priv->opened[i] &&
+ drivers[i]->version &&
drivers[i]->version (conn, hvVer) == 0)
return 0;
static int
xenUnifiedGetMaxVcpus (virConnectPtr conn, const char *type)
{
+ GET_PRIVATE(conn);
int i;
if (!type)
type = "Xen";
- for (i = 0; i < nb_drivers; ++i)
- if (strcmp (drivers[i]->name, type) == 0)
+ for (i = 0; i < XEN_UNIFIED_NR_DRIVERS; ++i)
+ if (priv->opened[i] && strcmp (drivers[i]->name, type) == 0)
return drivers[i]->getMaxVcpus (conn, type);
return -1;
static int
xenUnifiedNodeGetInfo (virConnectPtr conn, virNodeInfoPtr info)
{
+ GET_PRIVATE(conn);
int i;
- for (i = 0; i < nb_drivers; ++i)
- if (drivers[i]->nodeGetInfo &&
+ for (i = 0; i < XEN_UNIFIED_NR_DRIVERS; ++i)
+ if (priv->opened[i] &&
+ drivers[i]->nodeGetInfo &&
drivers[i]->nodeGetInfo (conn, info) == 0)
return 0;
static char *
xenUnifiedGetCapabilities (virConnectPtr conn)
{
+ GET_PRIVATE(conn);
int i;
char *ret;
- for (i = 0; i < nb_drivers; ++i)
- if (drivers[i]->getCapabilities) {
+ for (i = 0; i < XEN_UNIFIED_NR_DRIVERS; ++i)
+ if (priv->opened[i] && drivers[i]->getCapabilities) {
ret = drivers[i]->getCapabilities (conn);
if (ret) return ret;
}
static int
xenUnifiedListDomains (virConnectPtr conn, int *ids, int maxids)
{
+ GET_PRIVATE(conn);
int i, ret;
- for (i = 0; i < nb_drivers; ++i)
- if (drivers[i]->listDomains) {
+ for (i = 0; i < XEN_UNIFIED_NR_DRIVERS; ++i)
+ if (priv->opened[i] && drivers[i]->listDomains) {
ret = drivers[i]->listDomains (conn, ids, maxids);
if (ret >= 0) return ret;
}
static int
xenUnifiedNumOfDomains (virConnectPtr conn)
{
+ GET_PRIVATE(conn);
int i, ret;
- for (i = 0; i < nb_drivers; ++i)
- if (drivers[i]->numOfDomains) {
+ for (i = 0; i < XEN_UNIFIED_NR_DRIVERS; ++i)
+ if (priv->opened[i] && drivers[i]->numOfDomains) {
ret = drivers[i]->numOfDomains (conn);
if (ret >= 0) return ret;
}
xenUnifiedDomainCreateLinux (virConnectPtr conn,
const char *xmlDesc, unsigned int flags)
{
+ GET_PRIVATE(conn);
int i;
virDomainPtr ret;
- for (i = 0; i < nb_drivers; ++i)
- if (drivers[i]->domainCreateLinux) {
+ for (i = 0; i < XEN_UNIFIED_NR_DRIVERS; ++i)
+ if (priv->opened[i] && drivers[i]->domainCreateLinux) {
ret = drivers[i]->domainCreateLinux (conn, xmlDesc, flags);
if (ret) return ret;
}
static virDomainPtr
xenUnifiedDomainLookupByID (virConnectPtr conn, int id)
{
+ GET_PRIVATE(conn);
int i;
virDomainPtr ret;
- for (i = 0; i < nb_drivers; ++i)
- if (drivers[i]->domainLookupByID) {
+ for (i = 0; i < XEN_UNIFIED_NR_DRIVERS; ++i)
+ if (priv->opened[i] && drivers[i]->domainLookupByID) {
ret = drivers[i]->domainLookupByID (conn, id);
if (ret) return ret;
}
xenUnifiedDomainLookupByUUID (virConnectPtr conn,
const unsigned char *uuid)
{
+ GET_PRIVATE(conn);
int i;
virDomainPtr ret;
- for (i = 0; i < nb_drivers; ++i)
- if (drivers[i]->domainLookupByUUID) {
+ for (i = 0; i < XEN_UNIFIED_NR_DRIVERS; ++i)
+ if (priv->opened[i] && drivers[i]->domainLookupByUUID) {
ret = drivers[i]->domainLookupByUUID (conn, uuid);
if (ret) return ret;
}
xenUnifiedDomainLookupByName (virConnectPtr conn,
const char *name)
{
+ GET_PRIVATE(conn);
int i;
virDomainPtr ret;
- for (i = 0; i < nb_drivers; ++i)
- if (drivers[i]->domainLookupByName) {
+ for (i = 0; i < XEN_UNIFIED_NR_DRIVERS; ++i)
+ if (priv->opened[i] && drivers[i]->domainLookupByName) {
ret = drivers[i]->domainLookupByName (conn, name);
if (ret) return ret;
}
static int
xenUnifiedDomainSuspend (virDomainPtr dom)
{
+ GET_PRIVATE(dom->conn);
int i;
/* Try non-hypervisor methods first, then hypervisor direct method
* as a last resort.
*/
- for (i = 0; i < nb_drivers; ++i)
+ for (i = 0; i < XEN_UNIFIED_NR_DRIVERS; ++i)
if (i != hypervisor_offset &&
+ priv->opened[i] &&
drivers[i]->domainSuspend &&
drivers[i]->domainSuspend (dom) == 0)
return 0;
- if (drivers[hypervisor_offset]->domainSuspend &&
+ if (priv->opened[hypervisor_offset] &&
+ drivers[hypervisor_offset]->domainSuspend &&
drivers[hypervisor_offset]->domainSuspend (dom) == 0)
return 0;
static int
xenUnifiedDomainResume (virDomainPtr dom)
{
+ GET_PRIVATE(dom->conn);
int i;
/* Try non-hypervisor methods first, then hypervisor direct method
* as a last resort.
*/
- for (i = 0; i < nb_drivers; ++i)
+ for (i = 0; i < XEN_UNIFIED_NR_DRIVERS; ++i)
if (i != hypervisor_offset &&
+ priv->opened[i] &&
drivers[i]->domainResume &&
drivers[i]->domainResume (dom) == 0)
return 0;
- if (drivers[hypervisor_offset]->domainResume &&
+ if (priv->opened[hypervisor_offset] &&
+ drivers[hypervisor_offset]->domainResume &&
drivers[hypervisor_offset]->domainResume (dom) == 0)
return 0;
static int
xenUnifiedDomainShutdown (virDomainPtr dom)
{
+ GET_PRIVATE(dom->conn);
int i;
- for (i = 0; i < nb_drivers; ++i)
- if (drivers[i]->domainShutdown &&
+ for (i = 0; i < XEN_UNIFIED_NR_DRIVERS; ++i)
+ if (priv->opened[i] &&
+ drivers[i]->domainShutdown &&
drivers[i]->domainShutdown (dom) == 0)
return 0;
static int
xenUnifiedDomainReboot (virDomainPtr dom, unsigned int flags)
{
+ GET_PRIVATE(dom->conn);
int i;
- for (i = 0; i < nb_drivers; ++i)
- if (drivers[i]->domainReboot &&
+ for (i = 0; i < XEN_UNIFIED_NR_DRIVERS; ++i)
+ if (priv->opened[i] &&
+ drivers[i]->domainReboot &&
drivers[i]->domainReboot (dom, flags) == 0)
return 0;
static int
xenUnifiedDomainDestroy (virDomainPtr dom)
{
+ GET_PRIVATE(dom->conn);
int i;
/* Try non-hypervisor methods first, then hypervisor direct method
* as a last resort.
*/
- for (i = 0; i < nb_drivers; ++i)
+ for (i = 0; i < XEN_UNIFIED_NR_DRIVERS; ++i)
if (i != hypervisor_offset &&
+ priv->opened[i] &&
drivers[i]->domainDestroy &&
drivers[i]->domainDestroy (dom) == 0)
return 0;
- if (drivers[hypervisor_offset]->domainDestroy &&
+ if (priv->opened[i] &&
+ drivers[hypervisor_offset]->domainDestroy &&
drivers[hypervisor_offset]->domainDestroy (dom) == 0)
return 0;
static char *
xenUnifiedDomainGetOSType (virDomainPtr dom)
{
+ GET_PRIVATE(dom->conn);
int i;
char *ret;
- for (i = 0; i < nb_drivers; ++i)
- if (drivers[i]->domainGetOSType) {
+ for (i = 0; i < XEN_UNIFIED_NR_DRIVERS; ++i)
+ if (priv->opened[i] && drivers[i]->domainGetOSType) {
ret = drivers[i]->domainGetOSType (dom);
if (ret) return ret;
}
static unsigned long
xenUnifiedDomainGetMaxMemory (virDomainPtr dom)
{
+ GET_PRIVATE(dom->conn);
int i;
unsigned long ret;
- for (i = 0; i < nb_drivers; ++i)
- if (drivers[i]->domainGetMaxMemory) {
+ for (i = 0; i < XEN_UNIFIED_NR_DRIVERS; ++i)
+ if (priv->opened[i] && drivers[i]->domainGetMaxMemory) {
ret = drivers[i]->domainGetMaxMemory (dom);
if (ret != 0) return ret;
}
static int
xenUnifiedDomainSetMaxMemory (virDomainPtr dom, unsigned long memory)
{
+ GET_PRIVATE(dom->conn);
int i;
- for (i = 0; i < nb_drivers; ++i)
- if (drivers[i]->domainSetMaxMemory &&
+ for (i = 0; i < XEN_UNIFIED_NR_DRIVERS; ++i)
+ if (priv->opened[i] &&
+ drivers[i]->domainSetMaxMemory &&
drivers[i]->domainSetMaxMemory (dom, memory) == 0)
return 0;
static int
xenUnifiedDomainSetMemory (virDomainPtr dom, unsigned long memory)
{
+ GET_PRIVATE(dom->conn);
int i;
- for (i = 0; i < nb_drivers; ++i)
- if (drivers[i]->domainSetMemory &&
+ for (i = 0; i < XEN_UNIFIED_NR_DRIVERS; ++i)
+ if (priv->opened[i] &&
+ drivers[i]->domainSetMemory &&
drivers[i]->domainSetMemory (dom, memory) == 0)
return 0;
static int
xenUnifiedDomainGetInfo (virDomainPtr dom, virDomainInfoPtr info)
{
+ GET_PRIVATE(dom->conn);
int i;
- for (i = 0; i < nb_drivers; ++i)
- if (drivers[i]->domainGetInfo &&
+ for (i = 0; i < XEN_UNIFIED_NR_DRIVERS; ++i)
+ if (priv->opened[i] &&
+ drivers[i]->domainGetInfo &&
drivers[i]->domainGetInfo (dom, info) == 0)
return 0;
static int
xenUnifiedDomainSave (virDomainPtr dom, const char *to)
{
+ GET_PRIVATE(dom->conn);
int i;
- for (i = 0; i < nb_drivers; ++i)
- if (drivers[i]->domainSave &&
+ for (i = 0; i < XEN_UNIFIED_NR_DRIVERS; ++i)
+ if (priv->opened[i] &&
+ drivers[i]->domainSave &&
drivers[i]->domainSave (dom, to) == 0)
return 0;
static int
xenUnifiedDomainRestore (virConnectPtr conn, const char *from)
{
+ GET_PRIVATE(conn);
int i;
- for (i = 0; i < nb_drivers; ++i)
- if (drivers[i]->domainRestore &&
+ for (i = 0; i < XEN_UNIFIED_NR_DRIVERS; ++i)
+ if (priv->opened[i] &&
+ drivers[i]->domainRestore &&
drivers[i]->domainRestore (conn, from) == 0)
return 0;
static int
xenUnifiedDomainCoreDump (virDomainPtr dom, const char *to, int flags)
{
+ GET_PRIVATE(dom->conn);
int i;
- for (i = 0; i < nb_drivers; ++i)
- if (drivers[i]->domainCoreDump &&
+ for (i = 0; i < XEN_UNIFIED_NR_DRIVERS; ++i)
+ if (priv->opened[i] &&
+ drivers[i]->domainCoreDump &&
drivers[i]->domainCoreDump (dom, to, flags) == 0)
return 0;
static int
xenUnifiedDomainSetVcpus (virDomainPtr dom, unsigned int nvcpus)
{
+ GET_PRIVATE(dom->conn);
int i;
/* Try non-hypervisor methods first, then hypervisor direct method
* as a last resort.
*/
- for (i = 0; i < nb_drivers; ++i)
+ for (i = 0; i < XEN_UNIFIED_NR_DRIVERS; ++i)
if (i != hypervisor_offset &&
+ priv->opened[i] &&
drivers[i]->domainSetVcpus &&
drivers[i]->domainSetVcpus (dom, nvcpus) == 0)
return 0;
- if (drivers[hypervisor_offset]->domainSetVcpus &&
+ if (priv->opened[hypervisor_offset] &&
+ drivers[hypervisor_offset]->domainSetVcpus &&
drivers[hypervisor_offset]->domainSetVcpus (dom, nvcpus) == 0)
return 0;
xenUnifiedDomainPinVcpu (virDomainPtr dom, unsigned int vcpu,
unsigned char *cpumap, int maplen)
{
+ GET_PRIVATE(dom->conn);
int i;
- for (i = 0; i < nb_drivers; ++i)
- if (drivers[i]->domainPinVcpu &&
+ for (i = 0; i < XEN_UNIFIED_NR_DRIVERS; ++i)
+ if (priv->opened[i] &&
+ drivers[i]->domainPinVcpu &&
drivers[i]->domainPinVcpu (dom, vcpu, cpumap, maplen) == 0)
return 0;
virVcpuInfoPtr info, int maxinfo,
unsigned char *cpumaps, int maplen)
{
+ GET_PRIVATE(dom->conn);
int i, ret;
- for (i = 0; i < nb_drivers; ++i)
- if (drivers[i]->domainGetVcpus) {
+ for (i = 0; i < XEN_UNIFIED_NR_DRIVERS; ++i)
+ if (priv->opened[i] && drivers[i]->domainGetVcpus) {
ret = drivers[i]->domainGetVcpus (dom, info, maxinfo, cpumaps, maplen);
if (ret > 0)
return ret;
static int
xenUnifiedDomainGetMaxVcpus (virDomainPtr dom)
{
+ GET_PRIVATE(dom->conn);
int i, ret;
- for (i = 0; i < nb_drivers; ++i)
- if (drivers[i]->domainGetMaxVcpus) {
+ for (i = 0; i < XEN_UNIFIED_NR_DRIVERS; ++i)
+ if (priv->opened[i] && drivers[i]->domainGetMaxVcpus) {
ret = drivers[i]->domainGetMaxVcpus (dom);
if (ret != 0) return ret;
}
static char *
xenUnifiedDomainDumpXML (virDomainPtr dom, int flags)
{
+ GET_PRIVATE(dom->conn);
int i;
char *ret;
- for (i = 0; i < nb_drivers; ++i)
- if (drivers[i]->domainDumpXML) {
+ for (i = 0; i < XEN_UNIFIED_NR_DRIVERS; ++i)
+ if (priv->opened[i] && drivers[i]->domainDumpXML) {
ret = drivers[i]->domainDumpXML (dom, flags);
if (ret) return ret;
}
xenUnifiedListDefinedDomains (virConnectPtr conn, char **const names,
int maxnames)
{
+ GET_PRIVATE(conn);
int i;
int ret;
- for (i = 0; i < nb_drivers; ++i)
- if (drivers[i]->listDefinedDomains) {
+ for (i = 0; i < XEN_UNIFIED_NR_DRIVERS; ++i)
+ if (priv->opened[i] && drivers[i]->listDefinedDomains) {
ret = drivers[i]->listDefinedDomains (conn, names, maxnames);
if (ret >= 0) return ret;
}
static int
xenUnifiedNumOfDefinedDomains (virConnectPtr conn)
{
+ GET_PRIVATE(conn);
int i;
int ret;
- for (i = 0; i < nb_drivers; ++i)
- if (drivers[i]->numOfDefinedDomains) {
+ for (i = 0; i < XEN_UNIFIED_NR_DRIVERS; ++i)
+ if (priv->opened[i] && drivers[i]->numOfDefinedDomains) {
ret = drivers[i]->numOfDefinedDomains (conn);
if (ret >= 0) return ret;
}
static int
xenUnifiedDomainCreate (virDomainPtr dom)
{
+ GET_PRIVATE(dom->conn);
int i;
- for (i = 0; i < nb_drivers; ++i)
- if (drivers[i]->domainCreate &&
+ for (i = 0; i < XEN_UNIFIED_NR_DRIVERS; ++i)
+ if (priv->opened[i] && drivers[i]->domainCreate &&
drivers[i]->domainCreate (dom) == 0)
return 0;
static virDomainPtr
xenUnifiedDomainDefineXML (virConnectPtr conn, const char *xml)
{
+ GET_PRIVATE(conn);
int i;
virDomainPtr ret;
- for (i = 0; i < nb_drivers; ++i)
- if (drivers[i]->domainDefineXML) {
+ for (i = 0; i < XEN_UNIFIED_NR_DRIVERS; ++i)
+ if (priv->opened[i] && drivers[i]->domainDefineXML) {
ret = drivers[i]->domainDefineXML (conn, xml);
if (ret) return ret;
}
static int
xenUnifiedDomainUndefine (virDomainPtr dom)
{
+ GET_PRIVATE(dom->conn);
int i;
- for (i = 0; i < nb_drivers; ++i)
- if (drivers[i]->domainUndefine &&
+ for (i = 0; i < XEN_UNIFIED_NR_DRIVERS; ++i)
+ if (priv->opened[i] && drivers[i]->domainUndefine &&
drivers[i]->domainUndefine (dom) == 0)
return 0;
static int
xenUnifiedDomainAttachDevice (virDomainPtr dom, char *xml)
{
+ GET_PRIVATE(dom->conn);
int i;
- for (i = 0; i < nb_drivers; ++i)
- if (drivers[i]->domainAttachDevice &&
+ for (i = 0; i < XEN_UNIFIED_NR_DRIVERS; ++i)
+ if (priv->opened[i] && drivers[i]->domainAttachDevice &&
drivers[i]->domainAttachDevice (dom, xml) == 0)
return 0;
static int
xenUnifiedDomainDetachDevice (virDomainPtr dom, char *xml)
{
+ GET_PRIVATE(dom->conn);
int i;
- for (i = 0; i < nb_drivers; ++i)
- if (drivers[i]->domainDetachDevice &&
+ for (i = 0; i < XEN_UNIFIED_NR_DRIVERS; ++i)
+ if (priv->opened[i] && drivers[i]->domainDetachDevice &&
drivers[i]->domainDetachDevice (dom, xml) == 0)
return 0;
static int
xenUnifiedDomainGetAutostart (virDomainPtr dom, int *autostart)
{
+ GET_PRIVATE(dom->conn);
int i;
- for (i = 0; i < nb_drivers; ++i)
- if (drivers[i]->domainGetAutostart &&
+ for (i = 0; i < XEN_UNIFIED_NR_DRIVERS; ++i)
+ if (priv->opened[i] && drivers[i]->domainGetAutostart &&
drivers[i]->domainGetAutostart (dom, autostart) == 0)
return 0;
static int
xenUnifiedDomainSetAutostart (virDomainPtr dom, int autostart)
{
+ GET_PRIVATE(dom->conn);
int i;
- for (i = 0; i < nb_drivers; ++i)
- if (drivers[i]->domainSetAutostart &&
+ for (i = 0; i < XEN_UNIFIED_NR_DRIVERS; ++i)
+ if (priv->opened[i] && drivers[i]->domainSetAutostart &&
drivers[i]->domainSetAutostart (dom, autostart) == 0)
return 0;