/* * xen_unified.c: Unified Xen driver. * * Copyright (C) 2007 Red Hat, Inc. * * See COPYING.LIB for the License of this software * * Richard W.M. Jones */ #ifndef __VIR_XEN_UNIFIED_H__ #define __VIR_XEN_UNIFIED_H__ #include "internal.h" #include "capabilities.h" #include "driver.h" #include "domain_conf.h" #include "xs_internal.h" #if WITH_XEN_INOTIFY #include "xen_inotify.h" #endif #include "domain_event.h" #include "hash.h" #ifndef HAVE_WINSOCK2_H #include #include #else #include #endif extern int xenRegister (void); #define XEN_UNIFIED_HYPERVISOR_OFFSET 0 #define XEN_UNIFIED_PROXY_OFFSET 1 #define XEN_UNIFIED_XEND_OFFSET 2 #define XEN_UNIFIED_XS_OFFSET 3 #define XEN_UNIFIED_XM_OFFSET 4 #if WITH_XEN_INOTIFY #define XEN_UNIFIED_INOTIFY_OFFSET 5 #define XEN_UNIFIED_NR_DRIVERS 6 #else #define XEN_UNIFIED_NR_DRIVERS 5 #endif #define MIN_XEN_GUEST_SIZE 64 /* 64 megabytes */ /* _xenUnifiedDriver: * * Entry points into the underlying Xen drivers. This structure * will eventually go away and instead xen unified will make direct * calls to the underlying Xen drivers. * * To reiterate - the goal is to remove elements from this structure * until it is empty, replacing indirect calls through this * structure with direct calls in xen_unified.c. */ struct xenUnifiedDriver { virDrvOpen open; virDrvClose close; virDrvGetVersion version; virDrvGetHostname getHostname; virDrvGetURI getURI; virDrvNodeGetInfo nodeGetInfo; virDrvGetCapabilities getCapabilities; virDrvListDomains listDomains; virDrvNumOfDomains numOfDomains; virDrvDomainCreateXML domainCreateXML; virDrvDomainSuspend domainSuspend; virDrvDomainResume domainResume; virDrvDomainShutdown domainShutdown; virDrvDomainReboot domainReboot; virDrvDomainDestroy domainDestroy; virDrvDomainGetOSType domainGetOSType; virDrvDomainGetMaxMemory domainGetMaxMemory; virDrvDomainSetMaxMemory domainSetMaxMemory; virDrvDomainSetMemory domainSetMemory; virDrvDomainGetInfo domainGetInfo; virDrvDomainSave domainSave; virDrvDomainRestore domainRestore; virDrvDomainCoreDump domainCoreDump; virDrvDomainSetVcpus domainSetVcpus; virDrvDomainPinVcpu domainPinVcpu; virDrvDomainGetVcpus domainGetVcpus; virDrvDomainGetMaxVcpus domainGetMaxVcpus; virDrvListDefinedDomains listDefinedDomains; virDrvNumOfDefinedDomains numOfDefinedDomains; virDrvDomainCreate domainCreate; virDrvDomainDefineXML domainDefineXML; virDrvDomainUndefine domainUndefine; virDrvDomainAttachDevice domainAttachDevice; virDrvDomainDetachDevice domainDetachDevice; virDrvDomainGetAutostart domainGetAutostart; virDrvDomainSetAutostart domainSetAutostart; virDrvDomainGetSchedulerType domainGetSchedulerType; virDrvDomainGetSchedulerParameters domainGetSchedulerParameters; virDrvDomainSetSchedulerParameters domainSetSchedulerParameters; }; typedef struct xenXMConfCache *xenXMConfCachePtr; typedef struct xenXMConfCache { time_t refreshedAt; char filename[PATH_MAX]; virDomainDefPtr def; } xenXMConfCache; /* xenUnifiedDomainInfoPtr: * The minimal state we have about active domains * This is the minmal info necessary to still get a * virDomainPtr when the domain goes away */ struct _xenUnifiedDomainInfo { int id; char *name; unsigned char uuid[VIR_UUID_BUFLEN]; }; typedef struct _xenUnifiedDomainInfo xenUnifiedDomainInfo; typedef xenUnifiedDomainInfo *xenUnifiedDomainInfoPtr; struct _xenUnifiedDomainInfoList { unsigned int count; xenUnifiedDomainInfoPtr *doms; }; typedef struct _xenUnifiedDomainInfoList xenUnifiedDomainInfoList; typedef xenUnifiedDomainInfoList *xenUnifiedDomainInfoListPtr; /* xenUnifiedPrivatePtr: * * Per-connection private data, stored in conn->privateData. All Xen * low-level drivers access parts of this structure. */ struct _xenUnifiedPrivate { virMutex lock; /* These initial vars are initialized in Open method * and readonly thereafter, so can be used without * holding the lock */ virCapsPtr caps; int handle; /* Xen hypervisor handle */ int xendConfigVersion; /* XenD config version */ /* connection to xend */ struct sockaddr_storage addr; socklen_t addrlen; int addrfamily; int addrprotocol; /* Keep track of the drivers which opened. We keep a yes/no flag * here for each driver, corresponding to the array drivers in * xen_unified.c. */ int opened[XEN_UNIFIED_NR_DRIVERS]; /* * Everything from this point onwards must be protected * by the lock when used */ struct xs_handle *xshandle; /* handle to talk to the xenstore */ int proxy; /* fd of proxy. */ /* A list of xenstore watches */ xenStoreWatchListPtr xsWatchList; int xsWatch; /* A list of active domain name/uuids */ xenUnifiedDomainInfoListPtr activeDomainList; /* NUMA topology info cache */ int nbNodeCells; int nbNodeCpus; /* An list of callbacks */ virDomainEventCallbackListPtr domainEventCallbacks; int domainEventDispatching; /* Location of config files, either /etc * or /var/lib/xen */ const char *configDir; #if WITH_XEN_INOTIFY /* The inotify fd */ int inotifyFD; int inotifyWatch; int useXenConfigCache ; xenUnifiedDomainInfoListPtr configInfoList; #endif /* For the 'xm' driver */ /* Primary config file name -> virDomainDef map */ virHashTablePtr configCache; /* Domain name to config file name */ virHashTablePtr nameConfigMap; /* So we don't refresh too often */ time_t lastRefresh; }; typedef struct _xenUnifiedPrivate *xenUnifiedPrivatePtr; char *xenDomainUsedCpus(virDomainPtr dom); void xenUnifiedDomainInfoListFree(xenUnifiedDomainInfoListPtr info); int xenUnifiedAddDomainInfo(xenUnifiedDomainInfoListPtr info, int id, char *name, unsigned char *uuid); int xenUnifiedRemoveDomainInfo(xenUnifiedDomainInfoListPtr info, int id, char *name, unsigned char *uuid); void xenUnifiedDomainEventDispatch (xenUnifiedPrivatePtr priv, virDomainEventPtr event); unsigned long xenUnifiedVersion(void); #ifndef PROXY void xenUnifiedLock(xenUnifiedPrivatePtr priv); void xenUnifiedUnlock(xenUnifiedPrivatePtr priv); #else #define xenUnifiedLock(p) do {} while(0) #define xenUnifiedUnlock(p) do {} while(0) #endif #endif /* __VIR_XEN_UNIFIED_H__ */