Wed Jun 20 18:23:00 BST 2007 Richard W.M. Jones <rjones@redhat.com>

* src/libvirt.c, src/qemu_internal.c, src/test.c,
	  src/xen_unified.c, src/xend_internal.c,
	  src/libvirt.c, include/libvirt/virterror.h:
	  VIR_ERR_NO_SUPPORT means the function is not supported by
	  the hypervisor.  VIR_ERR_NO_CONNECT means the connection
	  failed.  VIR_ERR_CALL_FAILED is deprecated.  Drivers which
	  decline a URI now no longer produce an error.  Make
	  xen_unified.c ignore naked URI strings like "foo".
This commit is contained in:
Richard W.M. Jones 2007-06-20 17:25:39 +00:00
parent 17e1ee3cc7
commit e2df281e6c
8 changed files with 86 additions and 62 deletions

View File

@ -1,3 +1,14 @@
Wed Jun 20 18:23:00 BST 2007 Richard W.M. Jones <rjones@redhat.com>
* src/libvirt.c, src/qemu_internal.c, src/test.c,
src/xen_unified.c, src/xend_internal.c,
src/libvirt.c, include/libvirt/virterror.h:
VIR_ERR_NO_SUPPORT means the function is not supported by
the hypervisor. VIR_ERR_NO_CONNECT means the connection
failed. VIR_ERR_CALL_FAILED is deprecated. Drivers which
decline a URI now no longer produce an error. Make
xen_unified.c ignore naked URI strings like "foo".
Wed Jun 20 18:21:00 BST 2007 Richard W.M. Jones <rjones@redhat.com> Wed Jun 20 18:21:00 BST 2007 Richard W.M. Jones <rjones@redhat.com>
* src/virsh.c: 'virsh help command' now works even if we could * src/virsh.c: 'virsh help command' now works even if we could

View File

@ -86,7 +86,7 @@ typedef enum {
VIR_ERR_OK = 0, VIR_ERR_OK = 0,
VIR_ERR_INTERNAL_ERROR, /* internal error */ VIR_ERR_INTERNAL_ERROR, /* internal error */
VIR_ERR_NO_MEMORY, /* memory allocation failure */ VIR_ERR_NO_MEMORY, /* memory allocation failure */
VIR_ERR_NO_SUPPORT, /* no support for this connection */ VIR_ERR_NO_SUPPORT, /* no support for this function */
VIR_ERR_UNKNOWN_HOST,/* could not resolve hostname */ VIR_ERR_UNKNOWN_HOST,/* could not resolve hostname */
VIR_ERR_NO_CONNECT, /* can't connect to hypervisor */ VIR_ERR_NO_CONNECT, /* can't connect to hypervisor */
VIR_ERR_INVALID_CONN,/* invalid connection object */ VIR_ERR_INVALID_CONN,/* invalid connection object */
@ -109,7 +109,7 @@ typedef enum {
VIR_ERR_NO_DEVICE, /* missing domain devices information */ VIR_ERR_NO_DEVICE, /* missing domain devices information */
VIR_ERR_NO_XENSTORE,/* could not open Xen Store control */ VIR_ERR_NO_XENSTORE,/* could not open Xen Store control */
VIR_ERR_DRIVER_FULL, /* too many drivers registered */ VIR_ERR_DRIVER_FULL, /* too many drivers registered */
VIR_ERR_CALL_FAILED, /* not supported by the drivers */ VIR_ERR_CALL_FAILED, /* not supported by the drivers (DEPRECATED) */
VIR_ERR_XML_ERROR, /* an XML description is not well formed or broken */ VIR_ERR_XML_ERROR, /* an XML description is not well formed or broken */
VIR_ERR_DOM_EXIST,/* the domain already exist */ VIR_ERR_DOM_EXIST,/* the domain already exist */
VIR_ERR_OPERATION_DENIED, /* operation forbidden on read-only connections */ VIR_ERR_OPERATION_DENIED, /* operation forbidden on read-only connections */

View File

@ -314,7 +314,8 @@ do_open (const char *name, int flags)
} }
if (!ret->driver) { if (!ret->driver) {
virLibConnError (NULL, VIR_ERR_NO_SUPPORT, name); /* If we reach here, then all drivers declined the connection. */
virLibConnError (NULL, VIR_ERR_NO_CONNECT, name);
goto failed; goto failed;
} }
@ -344,12 +345,14 @@ failed:
/** /**
* virConnectOpen: * virConnectOpen:
* @name: optional argument currently unused, pass NULL * @name: URI of the hypervisor
* *
* This function should be called first to get a connection to the * This function should be called first to get a connection to the
* Hypervisor and xen store * Hypervisor and xen store
* *
* Returns a pointer to the hypervisor connection or NULL in case of error * Returns a pointer to the hypervisor connection or NULL in case of error
*
* URIs are documented at http://libvirt.org/uri.html
*/ */
virConnectPtr virConnectPtr
virConnectOpen (const char *name) virConnectOpen (const char *name)
@ -359,13 +362,15 @@ virConnectOpen (const char *name)
/** /**
* virConnectOpenReadOnly: * virConnectOpenReadOnly:
* @name: optional argument currently unused, pass NULL * @name: URI of the hypervisor
* *
* This function should be called first to get a restricted connection to the * This function should be called first to get a restricted connection to the
* libbrary functionalities. The set of APIs usable are then restricted * libbrary functionalities. The set of APIs usable are then restricted
* on the available methods to control the domains. * on the available methods to control the domains.
* *
* Returns a pointer to the hypervisor connection or NULL in case of error * Returns a pointer to the hypervisor connection or NULL in case of error
*
* URIs are documented at http://libvirt.org/uri.html
*/ */
virConnectPtr virConnectPtr
virConnectOpenReadOnly(const char *name) virConnectOpenReadOnly(const char *name)
@ -889,7 +894,7 @@ virDomainSave(virDomainPtr domain, const char *to)
if (conn->driver->domainSave) if (conn->driver->domainSave)
return conn->driver->domainSave (domain, to); return conn->driver->domainSave (domain, to);
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return -1; return -1;
} }
@ -942,7 +947,7 @@ virDomainRestore(virConnectPtr conn, const char *from)
if (conn->driver->domainRestore) if (conn->driver->domainRestore)
return conn->driver->domainRestore (conn, from); return conn->driver->domainRestore (conn, from);
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return -1; return -1;
} }
@ -1001,7 +1006,7 @@ virDomainCoreDump(virDomainPtr domain, const char *to, int flags)
if (conn->driver->domainCoreDump) if (conn->driver->domainCoreDump)
return conn->driver->domainCoreDump (domain, to, flags); return conn->driver->domainCoreDump (domain, to, flags);
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return -1; return -1;
} }
@ -1037,7 +1042,7 @@ virDomainShutdown(virDomainPtr domain)
if (conn->driver->domainShutdown) if (conn->driver->domainShutdown)
return conn->driver->domainShutdown (domain); return conn->driver->domainShutdown (domain);
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return -1; return -1;
} }
@ -1071,7 +1076,7 @@ virDomainReboot(virDomainPtr domain, unsigned int flags)
if (conn->driver->domainReboot) if (conn->driver->domainReboot)
return conn->driver->domainReboot (domain, flags); return conn->driver->domainReboot (domain, flags);
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return -1; return -1;
} }
@ -1217,7 +1222,7 @@ virDomainGetOSType(virDomainPtr domain)
if (conn->driver->domainGetOSType) if (conn->driver->domainGetOSType)
return conn->driver->domainGetOSType (domain); return conn->driver->domainGetOSType (domain);
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return NULL; return NULL;
} }
@ -1246,7 +1251,7 @@ virDomainGetMaxMemory(virDomainPtr domain)
if (conn->driver->domainGetMaxMemory) if (conn->driver->domainGetMaxMemory)
return conn->driver->domainGetMaxMemory (domain); return conn->driver->domainGetMaxMemory (domain);
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return 0; return 0;
} }
@ -1288,7 +1293,7 @@ virDomainSetMaxMemory(virDomainPtr domain, unsigned long memory)
if (conn->driver->domainSetMaxMemory) if (conn->driver->domainSetMaxMemory)
return conn->driver->domainSetMaxMemory (domain, memory); return conn->driver->domainSetMaxMemory (domain, memory);
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return -1; return -1;
} }
@ -1331,7 +1336,7 @@ virDomainSetMemory(virDomainPtr domain, unsigned long memory)
if (conn->driver->domainSetMemory) if (conn->driver->domainSetMemory)
return conn->driver->domainSetMemory (domain, memory); return conn->driver->domainSetMemory (domain, memory);
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return -1; return -1;
} }
@ -1367,7 +1372,7 @@ virDomainGetInfo(virDomainPtr domain, virDomainInfoPtr info)
if (conn->driver->domainGetInfo) if (conn->driver->domainGetInfo)
return conn->driver->domainGetInfo (domain, info); return conn->driver->domainGetInfo (domain, info);
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return -1; return -1;
} }
@ -1401,7 +1406,7 @@ virDomainGetXMLDesc(virDomainPtr domain, int flags)
if (conn->driver->domainDumpXML) if (conn->driver->domainDumpXML)
return conn->driver->domainDumpXML (domain, flags); return conn->driver->domainDumpXML (domain, flags);
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return NULL; return NULL;
} }
@ -1429,7 +1434,7 @@ virNodeGetInfo(virConnectPtr conn, virNodeInfoPtr info)
if (conn->driver->nodeGetInfo) if (conn->driver->nodeGetInfo)
return conn->driver->nodeGetInfo (conn, info); return conn->driver->nodeGetInfo (conn, info);
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return -1; return -1;
} }
@ -1454,7 +1459,7 @@ virConnectGetCapabilities (virConnectPtr conn)
if (conn->driver->getCapabilities) if (conn->driver->getCapabilities)
return conn->driver->getCapabilities (conn); return conn->driver->getCapabilities (conn);
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return NULL; return NULL;
} }
@ -1489,7 +1494,7 @@ virDomainGetSchedulerType(virDomainPtr domain, int *nparams)
return schedtype; return schedtype;
} }
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return NULL; return NULL;
} }
@ -1528,7 +1533,7 @@ virDomainGetSchedulerParameters(virDomainPtr domain,
if (conn->driver->domainGetSchedulerParameters) if (conn->driver->domainGetSchedulerParameters)
return conn->driver->domainGetSchedulerParameters (domain, params, nparams); return conn->driver->domainGetSchedulerParameters (domain, params, nparams);
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return -1; return -1;
} }
@ -1564,7 +1569,7 @@ virDomainSetSchedulerParameters(virDomainPtr domain,
if (conn->driver->domainSetSchedulerParameters) if (conn->driver->domainSetSchedulerParameters)
return conn->driver->domainSetSchedulerParameters (domain, params, nparams); return conn->driver->domainSetSchedulerParameters (domain, params, nparams);
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return -1; return -1;
} }
@ -1603,7 +1608,7 @@ virDomainDefineXML(virConnectPtr conn, const char *xml) {
if (conn->driver->domainDefineXML) if (conn->driver->domainDefineXML)
return conn->driver->domainDefineXML (conn, xml); return conn->driver->domainDefineXML (conn, xml);
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return NULL; return NULL;
} }
@ -1632,7 +1637,7 @@ virDomainUndefine(virDomainPtr domain) {
if (conn->driver->domainUndefine) if (conn->driver->domainUndefine)
return conn->driver->domainUndefine (domain); return conn->driver->domainUndefine (domain);
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return -1; return -1;
} }
@ -1655,7 +1660,7 @@ virConnectNumOfDefinedDomains(virConnectPtr conn)
if (conn->driver->numOfDefinedDomains) if (conn->driver->numOfDefinedDomains)
return conn->driver->numOfDefinedDomains (conn); return conn->driver->numOfDefinedDomains (conn);
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return -1; return -1;
} }
@ -1685,7 +1690,7 @@ virConnectListDefinedDomains(virConnectPtr conn, char **const names,
if (conn->driver->listDefinedDomains) if (conn->driver->listDefinedDomains)
return conn->driver->listDefinedDomains (conn, names, maxnames); return conn->driver->listDefinedDomains (conn, names, maxnames);
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return -1; return -1;
} }
@ -1719,7 +1724,7 @@ virDomainCreate(virDomainPtr domain) {
if (conn->driver->domainCreate) if (conn->driver->domainCreate)
return conn->driver->domainCreate (domain); return conn->driver->domainCreate (domain);
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return -1; return -1;
} }
@ -1754,7 +1759,7 @@ virDomainGetAutostart(virDomainPtr domain,
if (conn->driver->domainGetAutostart) if (conn->driver->domainGetAutostart)
return conn->driver->domainGetAutostart (domain, autostart); return conn->driver->domainGetAutostart (domain, autostart);
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return -1; return -1;
} }
@ -1784,7 +1789,7 @@ virDomainSetAutostart(virDomainPtr domain,
if (conn->driver->domainSetAutostart) if (conn->driver->domainSetAutostart)
return conn->driver->domainSetAutostart (domain, autostart); return conn->driver->domainSetAutostart (domain, autostart);
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return -1; return -1;
} }
@ -1828,7 +1833,7 @@ virDomainSetVcpus(virDomainPtr domain, unsigned int nvcpus)
if (conn->driver->domainSetVcpus) if (conn->driver->domainSetVcpus)
return conn->driver->domainSetVcpus (domain, nvcpus); return conn->driver->domainSetVcpus (domain, nvcpus);
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return -1; return -1;
} }
@ -1879,7 +1884,7 @@ virDomainPinVcpu(virDomainPtr domain, unsigned int vcpu,
if (conn->driver->domainPinVcpu) if (conn->driver->domainPinVcpu)
return conn->driver->domainPinVcpu (domain, vcpu, cpumap, maplen); return conn->driver->domainPinVcpu (domain, vcpu, cpumap, maplen);
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return -1; return -1;
} }
@ -1933,7 +1938,7 @@ virDomainGetVcpus(virDomainPtr domain, virVcpuInfoPtr info, int maxinfo,
return conn->driver->domainGetVcpus (domain, info, maxinfo, return conn->driver->domainGetVcpus (domain, info, maxinfo,
cpumaps, maplen); cpumaps, maplen);
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return -1; return -1;
} }
@ -1964,7 +1969,7 @@ virDomainGetMaxVcpus(virDomainPtr domain)
if (conn->driver->domainGetMaxVcpus) if (conn->driver->domainGetMaxVcpus)
return conn->driver->domainGetMaxVcpus (domain); return conn->driver->domainGetMaxVcpus (domain);
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return -1; return -1;
} }
@ -1996,7 +2001,7 @@ virDomainAttachDevice(virDomainPtr domain, char *xml)
if (conn->driver->domainAttachDevice) if (conn->driver->domainAttachDevice)
return conn->driver->domainAttachDevice (domain, xml); return conn->driver->domainAttachDevice (domain, xml);
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return -1; return -1;
} }
@ -2027,7 +2032,7 @@ virDomainDetachDevice(virDomainPtr domain, char *xml)
if (conn->driver->domainDetachDevice) if (conn->driver->domainDetachDevice)
return conn->driver->domainDetachDevice (domain, xml); return conn->driver->domainDetachDevice (domain, xml);
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return -1; return -1;
} }
@ -2050,7 +2055,7 @@ virConnectNumOfNetworks(virConnectPtr conn)
if (conn->networkDriver && conn->networkDriver->numOfNetworks) if (conn->networkDriver && conn->networkDriver->numOfNetworks)
return conn->networkDriver->numOfNetworks (conn); return conn->networkDriver->numOfNetworks (conn);
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return -1; return -1;
} }
@ -2080,7 +2085,7 @@ virConnectListNetworks(virConnectPtr conn, char **const names, int maxnames)
if (conn->networkDriver && conn->networkDriver->listNetworks) if (conn->networkDriver && conn->networkDriver->listNetworks)
return conn->networkDriver->listNetworks (conn, names, maxnames); return conn->networkDriver->listNetworks (conn, names, maxnames);
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return -1; return -1;
} }
@ -2103,7 +2108,7 @@ virConnectNumOfDefinedNetworks(virConnectPtr conn)
if (conn->networkDriver && conn->networkDriver->numOfDefinedNetworks) if (conn->networkDriver && conn->networkDriver->numOfDefinedNetworks)
return conn->networkDriver->numOfDefinedNetworks (conn); return conn->networkDriver->numOfDefinedNetworks (conn);
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return -1; return -1;
} }
@ -2135,7 +2140,7 @@ virConnectListDefinedNetworks(virConnectPtr conn, char **const names,
return conn->networkDriver->listDefinedNetworks (conn, return conn->networkDriver->listDefinedNetworks (conn,
names, maxnames); names, maxnames);
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return -1; return -1;
} }
@ -2163,7 +2168,7 @@ virNetworkLookupByName(virConnectPtr conn, const char *name)
if (conn->networkDriver && conn->networkDriver->networkLookupByName) if (conn->networkDriver && conn->networkDriver->networkLookupByName)
return conn->networkDriver->networkLookupByName (conn, name); return conn->networkDriver->networkLookupByName (conn, name);
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return NULL; return NULL;
} }
@ -2191,7 +2196,7 @@ virNetworkLookupByUUID(virConnectPtr conn, const unsigned char *uuid)
if (conn->networkDriver && conn->networkDriver->networkLookupByUUID) if (conn->networkDriver && conn->networkDriver->networkLookupByUUID)
return conn->networkDriver->networkLookupByUUID (conn, uuid); return conn->networkDriver->networkLookupByUUID (conn, uuid);
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return NULL; return NULL;
} }
@ -2273,7 +2278,7 @@ virNetworkCreateXML(virConnectPtr conn, const char *xmlDesc)
if (conn->networkDriver && conn->networkDriver->networkCreateXML) if (conn->networkDriver && conn->networkDriver->networkCreateXML)
return conn->networkDriver->networkCreateXML (conn, xmlDesc); return conn->networkDriver->networkCreateXML (conn, xmlDesc);
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return NULL; return NULL;
} }
@ -2305,7 +2310,7 @@ virNetworkDefineXML(virConnectPtr conn, const char *xml)
if (conn->networkDriver && conn->networkDriver->networkDefineXML) if (conn->networkDriver && conn->networkDriver->networkDefineXML)
return conn->networkDriver->networkDefineXML (conn, xml); return conn->networkDriver->networkDefineXML (conn, xml);
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return NULL; return NULL;
} }
@ -2334,7 +2339,7 @@ virNetworkUndefine(virNetworkPtr network) {
if (conn->networkDriver && conn->networkDriver->networkUndefine) if (conn->networkDriver && conn->networkDriver->networkUndefine)
return conn->networkDriver->networkUndefine (network); return conn->networkDriver->networkUndefine (network);
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return -1; return -1;
} }
@ -2368,7 +2373,7 @@ virNetworkCreate(virNetworkPtr network)
if (conn->networkDriver && conn->networkDriver->networkCreate) if (conn->networkDriver && conn->networkDriver->networkCreate)
return conn->networkDriver->networkCreate (network); return conn->networkDriver->networkCreate (network);
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return -1; return -1;
} }
@ -2403,7 +2408,7 @@ virNetworkDestroy(virNetworkPtr network)
if (conn->networkDriver && conn->networkDriver->networkDestroy) if (conn->networkDriver && conn->networkDriver->networkDestroy)
return conn->networkDriver->networkDestroy (network); return conn->networkDriver->networkDestroy (network);
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return -1; return -1;
} }
@ -2539,7 +2544,7 @@ virNetworkGetXMLDesc(virNetworkPtr network, int flags)
if (conn->networkDriver && conn->networkDriver->networkDumpXML) if (conn->networkDriver && conn->networkDriver->networkDumpXML)
return conn->networkDriver->networkDumpXML (network, flags); return conn->networkDriver->networkDumpXML (network, flags);
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return NULL; return NULL;
} }
@ -2568,7 +2573,7 @@ virNetworkGetBridgeName(virNetworkPtr network)
if (conn->networkDriver && conn->networkDriver->networkGetBridgeName) if (conn->networkDriver && conn->networkDriver->networkGetBridgeName)
return conn->networkDriver->networkGetBridgeName (network); return conn->networkDriver->networkGetBridgeName (network);
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return NULL; return NULL;
} }
@ -2603,7 +2608,7 @@ virNetworkGetAutostart(virNetworkPtr network,
if (conn->networkDriver && conn->networkDriver->networkGetAutostart) if (conn->networkDriver && conn->networkDriver->networkGetAutostart)
return conn->networkDriver->networkGetAutostart (network, autostart); return conn->networkDriver->networkGetAutostart (network, autostart);
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return -1; return -1;
} }
@ -2633,7 +2638,7 @@ virNetworkSetAutostart(virNetworkPtr network,
if (conn->networkDriver && conn->networkDriver->networkSetAutostart) if (conn->networkDriver && conn->networkDriver->networkSetAutostart)
return conn->networkDriver->networkSetAutostart (network, autostart); return conn->networkDriver->networkSetAutostart (network, autostart);
virLibConnError (conn, VIR_ERR_CALL_FAILED, __FUNCTION__); virLibConnError (conn, VIR_ERR_NO_SUPPORT, __FUNCTION__);
return -1; return -1;
} }

View File

@ -473,7 +473,6 @@ static int qemuOpen(virConnectPtr conn,
uri = xmlParseURI(name); uri = xmlParseURI(name);
if (uri == NULL) { if (uri == NULL) {
qemuError(NULL, NULL, VIR_ERR_NO_SUPPORT, name);
return VIR_DRV_OPEN_DECLINED; return VIR_DRV_OPEN_DECLINED;
} }

View File

@ -720,7 +720,6 @@ int testOpen(virConnectPtr conn,
uri = xmlParseURI(name); uri = xmlParseURI(name);
if (uri == NULL) { if (uri == NULL) {
testError(NULL, NULL, VIR_ERR_NO_SUPPORT, name);
return VIR_DRV_OPEN_DECLINED; return VIR_DRV_OPEN_DECLINED;
} }

View File

@ -410,10 +410,10 @@ __virErrorMsg(virErrorNumber error, const char *info)
errmsg = _("out of memory"); errmsg = _("out of memory");
break; break;
case VIR_ERR_NO_SUPPORT: case VIR_ERR_NO_SUPPORT:
if (info != NULL) if (info == NULL)
errmsg = _("no support for hypervisor"); errmsg = _("this function is not supported by the hypervisor");
else else
errmsg = _("no support for hypervisor %s"); errmsg = _("this function is not supported by the hypervisor: %s");
break; break;
case VIR_ERR_NO_CONNECT: case VIR_ERR_NO_CONNECT:
if (info == NULL) if (info == NULL)
@ -538,7 +538,7 @@ __virErrorMsg(virErrorNumber error, const char *info)
else else
errmsg = _("too many drivers registered in %s"); errmsg = _("too many drivers registered in %s");
break; break;
case VIR_ERR_CALL_FAILED: case VIR_ERR_CALL_FAILED: /* DEPRECATED, use VIR_ERR_NO_SUPPORT */
if (info == NULL) if (info == NULL)
errmsg = _("library call failed, possibly not supported"); errmsg = _("library call failed, possibly not supported");
else else

View File

@ -99,23 +99,33 @@ xenUnifiedOpen (virConnectPtr conn, const char *name, int flags)
uri = xmlParseURI(name); uri = xmlParseURI(name);
if (uri == NULL) { if (uri == NULL) {
xenUnifiedError(NULL, VIR_ERR_NO_SUPPORT, name);
return VIR_DRV_OPEN_DECLINED; return VIR_DRV_OPEN_DECLINED;
} }
/* Refuse any URI which doesn't start xen:///, / or http:// */ /* Refuse any scheme which isn't "xen://" or "http://". */
if (uri->scheme && if (uri->scheme &&
strcasecmp(uri->scheme, "xen") != 0 && strcasecmp(uri->scheme, "xen") != 0 &&
strcasecmp(uri->scheme, "http")) { strcasecmp(uri->scheme, "http") != 0) {
xmlFreeURI(uri);
return VIR_DRV_OPEN_DECLINED;
}
/* xmlParseURI will parse a naked string like "foo" as a URI with
* a NULL scheme. That's not useful for us because we want to only
* allow full pathnames (eg. ///var/lib/xen/xend-socket). Decline
* anything else.
*/
if (!uri->scheme && name[0] != '/') {
xmlFreeURI(uri); xmlFreeURI(uri);
return VIR_DRV_OPEN_DECLINED; return VIR_DRV_OPEN_DECLINED;
} }
/* Refuse any xen:// URI with a server specified - allow remote to do it */ /* Refuse any xen:// URI with a server specified - allow remote to do it */
if (uri->scheme && !strcasecmp(uri->scheme, "xen") && uri->server) { if (uri->scheme && strcasecmp(uri->scheme, "xen") == 0 && uri->server) {
xmlFreeURI(uri); xmlFreeURI(uri);
return VIR_DRV_OPEN_DECLINED; return VIR_DRV_OPEN_DECLINED;
} }
xmlFreeURI(uri); xmlFreeURI(uri);
/* Allocate per-connection private data. */ /* Allocate per-connection private data. */

View File

@ -1975,14 +1975,14 @@ xenDaemonOpen(virConnectPtr conn, const char *name,
*/ */
uri = xmlParseURI(name); uri = xmlParseURI(name);
if (uri == NULL) { if (uri == NULL) {
virXendError(NULL, VIR_ERR_NO_SUPPORT, name); virXendError(NULL, VIR_ERR_NO_CONNECT, name);
goto failed; goto failed;
} }
if (uri->scheme == NULL) { if (uri->scheme == NULL) {
/* It should be a file access */ /* It should be a file access */
if (uri->path == NULL) { if (uri->path == NULL) {
virXendError(NULL, VIR_ERR_NO_SUPPORT, name); virXendError(NULL, VIR_ERR_NO_CONNECT, name);
goto failed; goto failed;
} }
ret = xenDaemonOpen_unix(conn, uri->path); ret = xenDaemonOpen_unix(conn, uri->path);
@ -2000,7 +2000,7 @@ xenDaemonOpen(virConnectPtr conn, const char *name,
if (ret == -1) if (ret == -1)
goto failed; goto failed;
} else { } else {
virXendError(NULL, VIR_ERR_NO_SUPPORT, name); virXendError(NULL, VIR_ERR_NO_CONNECT, name);
goto failed; goto failed;
} }
} }