mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-10 14:57:42 +00:00
New APIs for checking some object properties
Introduce a number of new APIs to expose some boolean properties of objects, which cannot otherwise reliably determined, nor are aspects of the XML configuration. * virDomainIsActive: Checking virDomainGetID is not reliable since it is not possible to distinguish between error condition and inactive domain for ID of -1. * virDomainIsPersistent: Check whether a persistent config exists for the domain * virNetworkIsActive: Check whether the network is active * virNetworkIsPersistent: Check whether a persistent config exists for the network * virStoragePoolIsActive: Check whether the storage pool is active * virStoragePoolIsPersistent: Check whether a persistent config exists for the storage pool * virInterfaceIsActive: Check whether the host interface is active * virConnectIsSecure: whether the communication channel to the hypervisor is secure * virConnectIsEncrypted: whether any network based commnunication channels are encrypted NB, a channel can be secure, even if not encrypted, eg if it does not involve the network, like a UNIX socket, or pipe. * include/libvirt/libvirt.h.in: Define public API * src/driver.h: Define internal driver API * src/libvirt.c: Implement public API entry point * src/libvirt_public.syms: Export API symbols * src/esx/esx_driver.c, src/lxc/lxc_driver.c, src/interface/netcf_driver.c, src/network/bridge_driver.c, src/opennebula/one_driver.c, src/openvz/openvz_driver.c, src/phyp/phyp_driver.c, src/qemu/qemu_driver.c, src/remote/remote_driver.c, src/test/test_driver.c, src/uml/uml_driver.c, src/vbox/vbox_tmpl.c, src/xen/xen_driver.c: Stub out driver tables
This commit is contained in:
parent
117aa0d874
commit
c04498b305
@ -1653,6 +1653,22 @@ int virStreamAbort(virStreamPtr st);
|
|||||||
int virStreamFree(virStreamPtr st);
|
int virStreamFree(virStreamPtr st);
|
||||||
|
|
||||||
|
|
||||||
|
int virDomainIsActive(virDomainPtr dom);
|
||||||
|
int virDomainIsPersistent(virDomainPtr dom);
|
||||||
|
|
||||||
|
int virNetworkIsActive(virNetworkPtr net);
|
||||||
|
int virNetworkIsPersistent(virNetworkPtr net);
|
||||||
|
|
||||||
|
int virStoragePoolIsActive(virStoragePoolPtr pool);
|
||||||
|
int virStoragePoolIsPersistent(virStoragePoolPtr pool);
|
||||||
|
|
||||||
|
int virInterfaceIsActive(virInterfacePtr iface);
|
||||||
|
|
||||||
|
int virConnectIsEncrypted(virConnectPtr conn);
|
||||||
|
int virConnectIsSecure(virConnectPtr conn);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
34
src/driver.h
34
src/driver.h
@ -337,6 +337,15 @@ typedef int
|
|||||||
unsigned long resource,
|
unsigned long resource,
|
||||||
const char *dom_xml);
|
const char *dom_xml);
|
||||||
|
|
||||||
|
typedef int
|
||||||
|
(*virDrvConnectIsEncrypted)(virConnectPtr conn);
|
||||||
|
typedef int
|
||||||
|
(*virDrvConnectIsSecure)(virConnectPtr conn);
|
||||||
|
typedef int
|
||||||
|
(*virDrvDomainIsActive)(virDomainPtr dom);
|
||||||
|
typedef int
|
||||||
|
(*virDrvDomainIsPersistent)(virDomainPtr dom);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* _virDriver:
|
* _virDriver:
|
||||||
*
|
*
|
||||||
@ -418,6 +427,10 @@ struct _virDriver {
|
|||||||
virDrvNodeDeviceReAttach nodeDeviceReAttach;
|
virDrvNodeDeviceReAttach nodeDeviceReAttach;
|
||||||
virDrvNodeDeviceReset nodeDeviceReset;
|
virDrvNodeDeviceReset nodeDeviceReset;
|
||||||
virDrvDomainMigratePrepareTunnel domainMigratePrepareTunnel;
|
virDrvDomainMigratePrepareTunnel domainMigratePrepareTunnel;
|
||||||
|
virDrvConnectIsEncrypted isEncrypted;
|
||||||
|
virDrvConnectIsSecure isSecure;
|
||||||
|
virDrvDomainIsActive domainIsActive;
|
||||||
|
virDrvDomainIsPersistent domainIsPersistent;
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef int
|
typedef int
|
||||||
@ -462,6 +475,12 @@ typedef int
|
|||||||
(*virDrvNetworkSetAutostart) (virNetworkPtr network,
|
(*virDrvNetworkSetAutostart) (virNetworkPtr network,
|
||||||
int autostart);
|
int autostart);
|
||||||
|
|
||||||
|
typedef int
|
||||||
|
(*virDrvNetworkIsActive)(virNetworkPtr net);
|
||||||
|
typedef int
|
||||||
|
(*virDrvNetworkIsPersistent)(virNetworkPtr net);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
typedef struct _virNetworkDriver virNetworkDriver;
|
typedef struct _virNetworkDriver virNetworkDriver;
|
||||||
typedef virNetworkDriver *virNetworkDriverPtr;
|
typedef virNetworkDriver *virNetworkDriverPtr;
|
||||||
@ -495,6 +514,8 @@ struct _virNetworkDriver {
|
|||||||
virDrvNetworkGetBridgeName networkGetBridgeName;
|
virDrvNetworkGetBridgeName networkGetBridgeName;
|
||||||
virDrvNetworkGetAutostart networkGetAutostart;
|
virDrvNetworkGetAutostart networkGetAutostart;
|
||||||
virDrvNetworkSetAutostart networkSetAutostart;
|
virDrvNetworkSetAutostart networkSetAutostart;
|
||||||
|
virDrvNetworkIsActive networkIsActive;
|
||||||
|
virDrvNetworkIsPersistent networkIsPersistent;
|
||||||
};
|
};
|
||||||
|
|
||||||
/*-------*/
|
/*-------*/
|
||||||
@ -534,6 +555,10 @@ typedef int
|
|||||||
(*virDrvInterfaceDestroy) (virInterfacePtr iface,
|
(*virDrvInterfaceDestroy) (virInterfacePtr iface,
|
||||||
unsigned int flags);
|
unsigned int flags);
|
||||||
|
|
||||||
|
typedef int
|
||||||
|
(*virDrvInterfaceIsActive)(virInterfacePtr iface);
|
||||||
|
|
||||||
|
|
||||||
typedef struct _virInterfaceDriver virInterfaceDriver;
|
typedef struct _virInterfaceDriver virInterfaceDriver;
|
||||||
typedef virInterfaceDriver *virInterfaceDriverPtr;
|
typedef virInterfaceDriver *virInterfaceDriverPtr;
|
||||||
|
|
||||||
@ -562,6 +587,7 @@ struct _virInterfaceDriver {
|
|||||||
virDrvInterfaceUndefine interfaceUndefine;
|
virDrvInterfaceUndefine interfaceUndefine;
|
||||||
virDrvInterfaceCreate interfaceCreate;
|
virDrvInterfaceCreate interfaceCreate;
|
||||||
virDrvInterfaceDestroy interfaceDestroy;
|
virDrvInterfaceDestroy interfaceDestroy;
|
||||||
|
virDrvInterfaceIsActive interfaceIsActive;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
@ -668,6 +694,12 @@ typedef virStorageVolPtr
|
|||||||
virStorageVolPtr clone,
|
virStorageVolPtr clone,
|
||||||
unsigned int flags);
|
unsigned int flags);
|
||||||
|
|
||||||
|
typedef int
|
||||||
|
(*virDrvStoragePoolIsActive)(virStoragePoolPtr pool);
|
||||||
|
typedef int
|
||||||
|
(*virDrvStoragePoolIsPersistent)(virStoragePoolPtr pool);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
typedef struct _virStorageDriver virStorageDriver;
|
typedef struct _virStorageDriver virStorageDriver;
|
||||||
typedef virStorageDriver *virStorageDriverPtr;
|
typedef virStorageDriver *virStorageDriverPtr;
|
||||||
@ -719,6 +751,8 @@ struct _virStorageDriver {
|
|||||||
virDrvStorageVolGetInfo volGetInfo;
|
virDrvStorageVolGetInfo volGetInfo;
|
||||||
virDrvStorageVolGetXMLDesc volGetXMLDesc;
|
virDrvStorageVolGetXMLDesc volGetXMLDesc;
|
||||||
virDrvStorageVolGetPath volGetPath;
|
virDrvStorageVolGetPath volGetPath;
|
||||||
|
virDrvStoragePoolIsActive poolIsActive;
|
||||||
|
virDrvStoragePoolIsPersistent poolIsPersistent;
|
||||||
};
|
};
|
||||||
|
|
||||||
#ifdef WITH_LIBVIRTD
|
#ifdef WITH_LIBVIRTD
|
||||||
|
@ -3313,6 +3313,10 @@ static virDriver esxDriver = {
|
|||||||
NULL, /* nodeDeviceReAttach */
|
NULL, /* nodeDeviceReAttach */
|
||||||
NULL, /* nodeDeviceReset */
|
NULL, /* nodeDeviceReset */
|
||||||
NULL, /* domainMigratePrepareTunnel */
|
NULL, /* domainMigratePrepareTunnel */
|
||||||
|
NULL, /* isEncrypted */
|
||||||
|
NULL, /* isSecure */
|
||||||
|
NULL, /* domainIsActive */
|
||||||
|
NULL, /* domainIsPersistent */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -526,6 +526,7 @@ static virInterfaceDriver interfaceDriver = {
|
|||||||
interfaceUndefine, /* interfaceUndefine */
|
interfaceUndefine, /* interfaceUndefine */
|
||||||
interfaceCreate, /* interfaceCreate */
|
interfaceCreate, /* interfaceCreate */
|
||||||
interfaceDestroy, /* interfaceDestroy */
|
interfaceDestroy, /* interfaceDestroy */
|
||||||
|
NULL, /* interfaceIsActive */
|
||||||
};
|
};
|
||||||
|
|
||||||
int interfaceRegister(void) {
|
int interfaceRegister(void) {
|
||||||
|
310
src/libvirt.c
310
src/libvirt.c
@ -10334,3 +10334,313 @@ int virStreamFree(virStreamPtr stream)
|
|||||||
return (-1);
|
return (-1);
|
||||||
return (0);
|
return (0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* virDomainIsActive:
|
||||||
|
* @dom: pointer to the domain object
|
||||||
|
*
|
||||||
|
* Determine if the domain is currently running
|
||||||
|
*
|
||||||
|
* Returns 1 if running, 0 if inactive, -1 on error
|
||||||
|
*/
|
||||||
|
int virDomainIsActive(virDomainPtr dom)
|
||||||
|
{
|
||||||
|
DEBUG("dom=%p", dom);
|
||||||
|
|
||||||
|
virResetLastError();
|
||||||
|
|
||||||
|
if (!VIR_IS_CONNECTED_DOMAIN(dom)) {
|
||||||
|
virLibConnError(NULL, VIR_ERR_INVALID_CONN, __FUNCTION__);
|
||||||
|
return (-1);
|
||||||
|
}
|
||||||
|
if (dom->conn->driver->domainIsActive) {
|
||||||
|
int ret;
|
||||||
|
ret = dom->conn->driver->domainIsActive(dom);
|
||||||
|
if (ret < 0)
|
||||||
|
goto error;
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
virLibConnError(dom->conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
|
||||||
|
error:
|
||||||
|
/* Copy to connection error object for back compatability */
|
||||||
|
virSetConnError(dom->conn);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* virDomainIsPersistent:
|
||||||
|
* @dom: pointer to the domain object
|
||||||
|
*
|
||||||
|
* Determine if the domain has a persistent configuration
|
||||||
|
* which means it will still exist after shutting down
|
||||||
|
*
|
||||||
|
* Returns 1 if persistent, 0 if transient, -1 on error
|
||||||
|
*/
|
||||||
|
int virDomainIsPersistent(virDomainPtr dom)
|
||||||
|
{
|
||||||
|
DEBUG("dom=%p", dom);
|
||||||
|
|
||||||
|
virResetLastError();
|
||||||
|
|
||||||
|
if (!VIR_IS_CONNECTED_DOMAIN(dom)) {
|
||||||
|
virLibConnError(NULL, VIR_ERR_INVALID_CONN, __FUNCTION__);
|
||||||
|
return (-1);
|
||||||
|
}
|
||||||
|
if (dom->conn->driver->domainIsPersistent) {
|
||||||
|
int ret;
|
||||||
|
ret = dom->conn->driver->domainIsPersistent(dom);
|
||||||
|
if (ret < 0)
|
||||||
|
goto error;
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
virLibConnError(dom->conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
|
||||||
|
error:
|
||||||
|
/* Copy to connection error object for back compatability */
|
||||||
|
virSetConnError(dom->conn);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* virNetworkIsActive:
|
||||||
|
* @net: pointer to the network object
|
||||||
|
*
|
||||||
|
* Determine if the network is currently running
|
||||||
|
*
|
||||||
|
* Returns 1 if running, 0 if inactive, -1 on error
|
||||||
|
*/
|
||||||
|
int virNetworkIsActive(virNetworkPtr net)
|
||||||
|
{
|
||||||
|
DEBUG("net=%p", net);
|
||||||
|
|
||||||
|
virResetLastError();
|
||||||
|
|
||||||
|
if (!VIR_IS_CONNECTED_NETWORK(net)) {
|
||||||
|
virLibConnError(NULL, VIR_ERR_INVALID_CONN, __FUNCTION__);
|
||||||
|
return (-1);
|
||||||
|
}
|
||||||
|
if (net->conn->networkDriver->networkIsActive) {
|
||||||
|
int ret;
|
||||||
|
ret = net->conn->networkDriver->networkIsActive(net);
|
||||||
|
if (ret < 0)
|
||||||
|
goto error;
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
virLibConnError(net->conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
|
||||||
|
error:
|
||||||
|
/* Copy to connection error object for back compatability */
|
||||||
|
virSetConnError(net->conn);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* virNetworkIsPersistent:
|
||||||
|
* @net: pointer to the network object
|
||||||
|
*
|
||||||
|
* Determine if the network has a persistent configuration
|
||||||
|
* which means it will still exist after shutting down
|
||||||
|
*
|
||||||
|
* Returns 1 if persistent, 0 if transient, -1 on error
|
||||||
|
*/
|
||||||
|
int virNetworkIsPersistent(virNetworkPtr net)
|
||||||
|
{
|
||||||
|
DEBUG("net=%p", net);
|
||||||
|
|
||||||
|
virResetLastError();
|
||||||
|
|
||||||
|
if (!VIR_IS_CONNECTED_NETWORK(net)) {
|
||||||
|
virLibConnError(NULL, VIR_ERR_INVALID_CONN, __FUNCTION__);
|
||||||
|
return (-1);
|
||||||
|
}
|
||||||
|
if (net->conn->networkDriver->networkIsPersistent) {
|
||||||
|
int ret;
|
||||||
|
ret = net->conn->networkDriver->networkIsPersistent(net);
|
||||||
|
if (ret < 0)
|
||||||
|
goto error;
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
virLibConnError(net->conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
|
||||||
|
error:
|
||||||
|
/* Copy to connection error object for back compatability */
|
||||||
|
virSetConnError(net->conn);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* virStoragePoolIsActive:
|
||||||
|
* @pool: pointer to the storage pool object
|
||||||
|
*
|
||||||
|
* Determine if the storage pool is currently running
|
||||||
|
*
|
||||||
|
* Returns 1 if running, 0 if inactive, -1 on error
|
||||||
|
*/
|
||||||
|
int virStoragePoolIsActive(virStoragePoolPtr pool)
|
||||||
|
{
|
||||||
|
DEBUG("pool=%p", pool);
|
||||||
|
|
||||||
|
virResetLastError();
|
||||||
|
|
||||||
|
if (!VIR_IS_CONNECTED_STORAGE_POOL(pool)) {
|
||||||
|
virLibConnError(NULL, VIR_ERR_INVALID_CONN, __FUNCTION__);
|
||||||
|
return (-1);
|
||||||
|
}
|
||||||
|
if (pool->conn->storageDriver->poolIsActive) {
|
||||||
|
int ret;
|
||||||
|
ret = pool->conn->storageDriver->poolIsActive(pool);
|
||||||
|
if (ret < 0)
|
||||||
|
goto error;
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
virLibConnError(pool->conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
|
||||||
|
error:
|
||||||
|
/* Copy to connection error object for back compatability */
|
||||||
|
virSetConnError(pool->conn);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* virStoragePoolIsPersistent:
|
||||||
|
* @pool: pointer to the storage pool object
|
||||||
|
*
|
||||||
|
* Determine if the storage pool has a persistent configuration
|
||||||
|
* which means it will still exist after shutting down
|
||||||
|
*
|
||||||
|
* Returns 1 if persistent, 0 if transient, -1 on error
|
||||||
|
*/
|
||||||
|
int virStoragePoolIsPersistent(virStoragePoolPtr pool)
|
||||||
|
{
|
||||||
|
DEBUG("pool=%p", pool);
|
||||||
|
|
||||||
|
virResetLastError();
|
||||||
|
|
||||||
|
if (!VIR_IS_CONNECTED_STORAGE_POOL(pool)) {
|
||||||
|
virLibConnError(NULL, VIR_ERR_INVALID_CONN, __FUNCTION__);
|
||||||
|
return (-1);
|
||||||
|
}
|
||||||
|
if (pool->conn->storageDriver->poolIsPersistent) {
|
||||||
|
int ret;
|
||||||
|
ret = pool->conn->storageDriver->poolIsPersistent(pool);
|
||||||
|
if (ret < 0)
|
||||||
|
goto error;
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
virLibConnError(pool->conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
|
||||||
|
error:
|
||||||
|
/* Copy to connection error object for back compatability */
|
||||||
|
virSetConnError(pool->conn);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* virInterfaceIsActive:
|
||||||
|
* @iface: pointer to the interface object
|
||||||
|
*
|
||||||
|
* Determine if the interface is currently running
|
||||||
|
*
|
||||||
|
* Returns 1 if running, 0 if inactive, -1 on error
|
||||||
|
*/
|
||||||
|
int virInterfaceIsActive(virInterfacePtr iface)
|
||||||
|
{
|
||||||
|
DEBUG("iface=%p", iface);
|
||||||
|
|
||||||
|
virResetLastError();
|
||||||
|
|
||||||
|
if (!VIR_IS_CONNECTED_INTERFACE(iface)) {
|
||||||
|
virLibConnError(NULL, VIR_ERR_INVALID_CONN, __FUNCTION__);
|
||||||
|
return (-1);
|
||||||
|
}
|
||||||
|
if (iface->conn->interfaceDriver->interfaceIsActive) {
|
||||||
|
int ret;
|
||||||
|
ret = iface->conn->interfaceDriver->interfaceIsActive(iface);
|
||||||
|
if (ret < 0)
|
||||||
|
goto error;
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
virLibConnError(iface->conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
|
||||||
|
error:
|
||||||
|
/* Copy to connection error object for back compatability */
|
||||||
|
virSetConnError(iface->conn);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* virConnectIsEncrypted:
|
||||||
|
* @conn: pointer to the connection object
|
||||||
|
*
|
||||||
|
* Determine if the connection to the hypervisor is encrypted
|
||||||
|
*
|
||||||
|
* Returns 1 if encrypted, 0 if not encrypted, -1 on error
|
||||||
|
*/
|
||||||
|
int virConnectIsEncrypted(virConnectPtr conn)
|
||||||
|
{
|
||||||
|
DEBUG("conn=%p", conn);
|
||||||
|
|
||||||
|
virResetLastError();
|
||||||
|
|
||||||
|
if (!VIR_IS_CONNECT(conn)) {
|
||||||
|
virLibConnError(NULL, VIR_ERR_INVALID_CONN, __FUNCTION__);
|
||||||
|
return (-1);
|
||||||
|
}
|
||||||
|
if (conn->driver->isEncrypted) {
|
||||||
|
int ret;
|
||||||
|
ret = conn->driver->isEncrypted(conn);
|
||||||
|
if (ret < 0)
|
||||||
|
goto error;
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
virLibConnError(conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
|
||||||
|
error:
|
||||||
|
/* Copy to connection error object for back compatability */
|
||||||
|
virSetConnError(conn);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* virConnectIsSecure:
|
||||||
|
* @conn: pointer to the connection object
|
||||||
|
*
|
||||||
|
* Determine if the connection to the hypervisor is secure
|
||||||
|
*
|
||||||
|
* A connection will be classed as secure if it is either
|
||||||
|
* encrypted, or running over a channel which is not exposed
|
||||||
|
* to eavesdropping (eg a UNIX domain socket, or pipe)
|
||||||
|
*
|
||||||
|
* Returns 1 if secure, 0 if secure, -1 on error
|
||||||
|
*/
|
||||||
|
int virConnectIsSecure(virConnectPtr conn)
|
||||||
|
{
|
||||||
|
DEBUG("conn=%p", conn);
|
||||||
|
|
||||||
|
virResetLastError();
|
||||||
|
|
||||||
|
if (!VIR_IS_CONNECT(conn)) {
|
||||||
|
virLibConnError(NULL, VIR_ERR_INVALID_CONN, __FUNCTION__);
|
||||||
|
return (-1);
|
||||||
|
}
|
||||||
|
if (conn->driver->isSecure) {
|
||||||
|
int ret;
|
||||||
|
ret = conn->driver->isSecure(conn);
|
||||||
|
if (ret < 0)
|
||||||
|
goto error;
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
virLibConnError(conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
|
||||||
|
error:
|
||||||
|
/* Copy to connection error object for back compatability */
|
||||||
|
virSetConnError(conn);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
@ -329,4 +329,17 @@ LIBVIRT_0.7.2 {
|
|||||||
virDomainMigrateToURI;
|
virDomainMigrateToURI;
|
||||||
} LIBVIRT_0.7.1;
|
} LIBVIRT_0.7.1;
|
||||||
|
|
||||||
|
LIBVIRT_0.7.3 {
|
||||||
|
global:
|
||||||
|
virConnectIsEncrypted;
|
||||||
|
virConnectIsSecure;
|
||||||
|
virDomainIsActive;
|
||||||
|
virDomainIsPersistent;
|
||||||
|
virNetworkIsActive;
|
||||||
|
virNetworkIsPersistent;
|
||||||
|
virStoragePoolIsActive;
|
||||||
|
virStoragePoolIsPersistent;
|
||||||
|
virInterfaceIsActive;
|
||||||
|
} LIBVIRT_0.7.2;
|
||||||
|
|
||||||
# .... define new API here using predicted next version number ....
|
# .... define new API here using predicted next version number ....
|
||||||
|
@ -2278,6 +2278,10 @@ static virDriver lxcDriver = {
|
|||||||
NULL, /* nodeDeviceReAttach */
|
NULL, /* nodeDeviceReAttach */
|
||||||
NULL, /* nodeDeviceReset */
|
NULL, /* nodeDeviceReset */
|
||||||
NULL, /* domainMigratePrepareTunnel */
|
NULL, /* domainMigratePrepareTunnel */
|
||||||
|
NULL, /* isEncrypted */
|
||||||
|
NULL, /* isSecure */
|
||||||
|
NULL, /* domainIsActive */
|
||||||
|
NULL, /* domainIsPersistent */
|
||||||
};
|
};
|
||||||
|
|
||||||
static virStateDriver lxcStateDriver = {
|
static virStateDriver lxcStateDriver = {
|
||||||
|
@ -1515,6 +1515,8 @@ static virNetworkDriver networkDriver = {
|
|||||||
networkGetBridgeName, /* networkGetBridgeName */
|
networkGetBridgeName, /* networkGetBridgeName */
|
||||||
networkGetAutostart, /* networkGetAutostart */
|
networkGetAutostart, /* networkGetAutostart */
|
||||||
networkSetAutostart, /* networkSetAutostart */
|
networkSetAutostart, /* networkSetAutostart */
|
||||||
|
NULL, /* networkIsActive */
|
||||||
|
NULL, /* networkIsPersistent */
|
||||||
};
|
};
|
||||||
|
|
||||||
static virStateDriver networkStateDriver = {
|
static virStateDriver networkStateDriver = {
|
||||||
|
@ -761,6 +761,10 @@ static virDriver oneDriver = {
|
|||||||
NULL, /* nodeDeviceReAttach; */
|
NULL, /* nodeDeviceReAttach; */
|
||||||
NULL, /* nodeDeviceReset; */
|
NULL, /* nodeDeviceReset; */
|
||||||
NULL, /* domainMigratePrepareTunnel */
|
NULL, /* domainMigratePrepareTunnel */
|
||||||
|
NULL, /* isEncrypted */
|
||||||
|
NULL, /* isSecure */
|
||||||
|
NULL, /* domainIsActive */
|
||||||
|
NULL, /* domainIsPersistent */
|
||||||
};
|
};
|
||||||
|
|
||||||
static virStateDriver oneStateDriver = {
|
static virStateDriver oneStateDriver = {
|
||||||
|
@ -1471,6 +1471,10 @@ static virDriver openvzDriver = {
|
|||||||
NULL, /* nodeDeviceReAttach */
|
NULL, /* nodeDeviceReAttach */
|
||||||
NULL, /* nodeDeviceReset */
|
NULL, /* nodeDeviceReset */
|
||||||
NULL, /* domainMigratePrepareTunnel */
|
NULL, /* domainMigratePrepareTunnel */
|
||||||
|
NULL, /* isEncrypted */
|
||||||
|
NULL, /* isSecure */
|
||||||
|
NULL, /* domainIsActive */
|
||||||
|
NULL, /* domainIsPersistent */
|
||||||
};
|
};
|
||||||
|
|
||||||
int openvzRegister(void) {
|
int openvzRegister(void) {
|
||||||
|
@ -1625,6 +1625,10 @@ virDriver phypDriver = {
|
|||||||
NULL, /* nodeDeviceReAttach */
|
NULL, /* nodeDeviceReAttach */
|
||||||
NULL, /* nodeDeviceReset */
|
NULL, /* nodeDeviceReset */
|
||||||
NULL, /* domainMigratePrepareTunnel */
|
NULL, /* domainMigratePrepareTunnel */
|
||||||
|
NULL, /* isEncrypted */
|
||||||
|
NULL, /* isSecure */
|
||||||
|
NULL, /* domainIsActive */
|
||||||
|
NULL, /* domainIsPersistent */
|
||||||
};
|
};
|
||||||
|
|
||||||
int
|
int
|
||||||
|
@ -7465,6 +7465,10 @@ static virDriver qemuDriver = {
|
|||||||
qemudNodeDeviceReAttach, /* nodeDeviceReAttach */
|
qemudNodeDeviceReAttach, /* nodeDeviceReAttach */
|
||||||
qemudNodeDeviceReset, /* nodeDeviceReset */
|
qemudNodeDeviceReset, /* nodeDeviceReset */
|
||||||
qemudDomainMigratePrepareTunnel, /* domainMigratePrepareTunnel */
|
qemudDomainMigratePrepareTunnel, /* domainMigratePrepareTunnel */
|
||||||
|
NULL, /* isEncrypted */
|
||||||
|
NULL, /* isSecure */
|
||||||
|
NULL, /* domainIsActive */
|
||||||
|
NULL, /* domainIsPersistent */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -8554,6 +8554,10 @@ static virDriver remote_driver = {
|
|||||||
remoteNodeDeviceReAttach, /* nodeDeviceReAttach */
|
remoteNodeDeviceReAttach, /* nodeDeviceReAttach */
|
||||||
remoteNodeDeviceReset, /* nodeDeviceReset */
|
remoteNodeDeviceReset, /* nodeDeviceReset */
|
||||||
remoteDomainMigratePrepareTunnel, /* domainMigratePrepareTunnel */
|
remoteDomainMigratePrepareTunnel, /* domainMigratePrepareTunnel */
|
||||||
|
NULL, /* isEncrypted */
|
||||||
|
NULL, /* isSecure */
|
||||||
|
NULL, /* domainIsActive */
|
||||||
|
NULL, /* domainIsPersistent */
|
||||||
};
|
};
|
||||||
|
|
||||||
static virNetworkDriver network_driver = {
|
static virNetworkDriver network_driver = {
|
||||||
@ -8575,6 +8579,8 @@ static virNetworkDriver network_driver = {
|
|||||||
.networkGetBridgeName = remoteNetworkGetBridgeName,
|
.networkGetBridgeName = remoteNetworkGetBridgeName,
|
||||||
.networkGetAutostart = remoteNetworkGetAutostart,
|
.networkGetAutostart = remoteNetworkGetAutostart,
|
||||||
.networkSetAutostart = remoteNetworkSetAutostart,
|
.networkSetAutostart = remoteNetworkSetAutostart,
|
||||||
|
.networkIsActive = NULL,
|
||||||
|
.networkIsPersistent = NULL,
|
||||||
};
|
};
|
||||||
|
|
||||||
static virInterfaceDriver interface_driver = {
|
static virInterfaceDriver interface_driver = {
|
||||||
@ -8592,6 +8598,7 @@ static virInterfaceDriver interface_driver = {
|
|||||||
.interfaceUndefine = remoteInterfaceUndefine,
|
.interfaceUndefine = remoteInterfaceUndefine,
|
||||||
.interfaceCreate = remoteInterfaceCreate,
|
.interfaceCreate = remoteInterfaceCreate,
|
||||||
.interfaceDestroy = remoteInterfaceDestroy,
|
.interfaceDestroy = remoteInterfaceDestroy,
|
||||||
|
.interfaceIsActive = NULL, /* interfaceIsActive */
|
||||||
};
|
};
|
||||||
|
|
||||||
static virStorageDriver storage_driver = {
|
static virStorageDriver storage_driver = {
|
||||||
@ -8630,6 +8637,9 @@ static virStorageDriver storage_driver = {
|
|||||||
.volGetInfo = remoteStorageVolGetInfo,
|
.volGetInfo = remoteStorageVolGetInfo,
|
||||||
.volGetXMLDesc = remoteStorageVolDumpXML,
|
.volGetXMLDesc = remoteStorageVolDumpXML,
|
||||||
.volGetPath = remoteStorageVolGetPath,
|
.volGetPath = remoteStorageVolGetPath,
|
||||||
|
|
||||||
|
.poolIsActive = NULL, /* poolIsActive */
|
||||||
|
.poolIsPersistent = NULL, /* poolIsEncrypted */
|
||||||
};
|
};
|
||||||
|
|
||||||
static virSecretDriver secret_driver = {
|
static virSecretDriver secret_driver = {
|
||||||
|
@ -5064,6 +5064,10 @@ static virDriver testDriver = {
|
|||||||
NULL, /* nodeDeviceReAttach */
|
NULL, /* nodeDeviceReAttach */
|
||||||
NULL, /* nodeDeviceReset */
|
NULL, /* nodeDeviceReset */
|
||||||
NULL, /* domainMigratePrepareTunnel */
|
NULL, /* domainMigratePrepareTunnel */
|
||||||
|
NULL, /* isEncrypted */
|
||||||
|
NULL, /* isSecure */
|
||||||
|
NULL, /* domainIsActive */
|
||||||
|
NULL, /* domainIsPersistent */
|
||||||
};
|
};
|
||||||
|
|
||||||
static virNetworkDriver testNetworkDriver = {
|
static virNetworkDriver testNetworkDriver = {
|
||||||
@ -5085,6 +5089,8 @@ static virNetworkDriver testNetworkDriver = {
|
|||||||
testNetworkGetBridgeName, /* networkGetBridgeName */
|
testNetworkGetBridgeName, /* networkGetBridgeName */
|
||||||
testNetworkGetAutostart, /* networkGetAutostart */
|
testNetworkGetAutostart, /* networkGetAutostart */
|
||||||
testNetworkSetAutostart, /* networkSetAutostart */
|
testNetworkSetAutostart, /* networkSetAutostart */
|
||||||
|
NULL, /* networkIsActive */
|
||||||
|
NULL, /* networkIsPersistent */
|
||||||
};
|
};
|
||||||
|
|
||||||
static virInterfaceDriver testInterfaceDriver = {
|
static virInterfaceDriver testInterfaceDriver = {
|
||||||
@ -5102,6 +5108,7 @@ static virInterfaceDriver testInterfaceDriver = {
|
|||||||
testInterfaceUndefine, /* interfaceUndefine */
|
testInterfaceUndefine, /* interfaceUndefine */
|
||||||
testInterfaceCreate, /* interfaceCreate */
|
testInterfaceCreate, /* interfaceCreate */
|
||||||
testInterfaceDestroy, /* interfaceDestroy */
|
testInterfaceDestroy, /* interfaceDestroy */
|
||||||
|
NULL, /* interfaceIsActive */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
@ -5142,6 +5149,9 @@ static virStorageDriver testStorageDriver = {
|
|||||||
.volGetInfo = testStorageVolumeGetInfo,
|
.volGetInfo = testStorageVolumeGetInfo,
|
||||||
.volGetXMLDesc = testStorageVolumeGetXMLDesc,
|
.volGetXMLDesc = testStorageVolumeGetXMLDesc,
|
||||||
.volGetPath = testStorageVolumeGetPath,
|
.volGetPath = testStorageVolumeGetPath,
|
||||||
|
|
||||||
|
.poolIsActive = NULL, /* poolIsActive */
|
||||||
|
.poolIsPersistent = NULL, /* poolIsPersistent */
|
||||||
};
|
};
|
||||||
|
|
||||||
static virDeviceMonitor testDevMonitor = {
|
static virDeviceMonitor testDevMonitor = {
|
||||||
|
@ -1824,6 +1824,10 @@ static virDriver umlDriver = {
|
|||||||
NULL, /* nodeDeviceReAttach */
|
NULL, /* nodeDeviceReAttach */
|
||||||
NULL, /* nodeDeviceReset */
|
NULL, /* nodeDeviceReset */
|
||||||
NULL, /* domainMigratePrepareTunnel */
|
NULL, /* domainMigratePrepareTunnel */
|
||||||
|
NULL, /* isEncrypted */
|
||||||
|
NULL, /* isSecure */
|
||||||
|
NULL, /* domainIsActive */
|
||||||
|
NULL, /* domainIsPersistent */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -6469,6 +6469,10 @@ virDriver NAME(Driver) = {
|
|||||||
NULL, /* nodeDeviceReAttach */
|
NULL, /* nodeDeviceReAttach */
|
||||||
NULL, /* nodeDeviceReset */
|
NULL, /* nodeDeviceReset */
|
||||||
NULL, /* domainMigratePrepareTunnel */
|
NULL, /* domainMigratePrepareTunnel */
|
||||||
|
NULL, /* isEncrypted */
|
||||||
|
NULL, /* isSecure */
|
||||||
|
NULL, /* domainIsActive */
|
||||||
|
NULL, /* domainIsPerrsistent */
|
||||||
};
|
};
|
||||||
|
|
||||||
virNetworkDriver NAME(NetworkDriver) = {
|
virNetworkDriver NAME(NetworkDriver) = {
|
||||||
|
@ -1709,6 +1709,10 @@ static virDriver xenUnifiedDriver = {
|
|||||||
xenUnifiedNodeDeviceReAttach, /* nodeDeviceReAttach */
|
xenUnifiedNodeDeviceReAttach, /* nodeDeviceReAttach */
|
||||||
xenUnifiedNodeDeviceReset, /* nodeDeviceReset */
|
xenUnifiedNodeDeviceReset, /* nodeDeviceReset */
|
||||||
NULL, /* domainMigratePrepareTunnel */
|
NULL, /* domainMigratePrepareTunnel */
|
||||||
|
NULL, /* isEncrypted */
|
||||||
|
NULL, /* isSecure */
|
||||||
|
NULL, /* domainIsActive */
|
||||||
|
NULL, /* domainIsPersistent */
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Loading…
Reference in New Issue
Block a user