2006-02-24 22:36:10 +00:00
|
|
|
/*
|
|
|
|
* virterror.h:
|
|
|
|
* Summary: error handling interfaces for the libvirt library
|
|
|
|
* Description: Provides the interfaces of the libvirt library to handle
|
|
|
|
* errors raised while using the library.
|
|
|
|
*
|
2010-12-21 22:06:27 +00:00
|
|
|
* Copy: Copyright (C) 2006, 2010 Red Hat, Inc.
|
2006-02-24 22:36:10 +00:00
|
|
|
*
|
|
|
|
* See COPYING.LIB for the License of this software
|
|
|
|
*
|
|
|
|
* Author: Daniel Veillard <veillard@redhat.com>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __VIR_VIRERR_H__
|
2010-03-09 18:22:22 +00:00
|
|
|
# define __VIR_VIRERR_H__
|
2006-02-24 22:36:10 +00:00
|
|
|
|
2010-03-09 18:22:22 +00:00
|
|
|
# include <libvirt/libvirt.h>
|
2006-02-24 22:36:10 +00:00
|
|
|
|
2010-03-09 18:22:22 +00:00
|
|
|
# ifdef __cplusplus
|
2006-02-24 22:36:10 +00:00
|
|
|
extern "C" {
|
2010-03-09 18:22:22 +00:00
|
|
|
# endif
|
2006-02-24 22:36:10 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* virErrorLevel:
|
|
|
|
*
|
|
|
|
* Indicates the level of an error
|
|
|
|
*/
|
|
|
|
typedef enum {
|
|
|
|
VIR_ERR_NONE = 0,
|
|
|
|
VIR_ERR_WARNING = 1, /* A simple warning */
|
|
|
|
VIR_ERR_ERROR = 2 /* An error */
|
|
|
|
} virErrorLevel;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* virErrorDomain:
|
|
|
|
*
|
2010-12-21 22:06:27 +00:00
|
|
|
* Indicates where an error may have come from. This should remain
|
|
|
|
* stable, with all additions placed at the end since libvirt 0.1.0.
|
2006-02-24 22:36:10 +00:00
|
|
|
*/
|
|
|
|
typedef enum {
|
|
|
|
VIR_FROM_NONE = 0,
|
2010-12-21 22:06:27 +00:00
|
|
|
VIR_FROM_XEN = 1, /* Error at Xen hypervisor layer */
|
|
|
|
VIR_FROM_XEND = 2, /* Error at connection with xend daemon */
|
|
|
|
VIR_FROM_XENSTORE = 3, /* Error at connection with xen store */
|
|
|
|
VIR_FROM_SEXPR = 4, /* Error in the S-Expression code */
|
|
|
|
VIR_FROM_XML = 5, /* Error in the XML code */
|
|
|
|
VIR_FROM_DOM = 6, /* Error when operating on a domain */
|
|
|
|
VIR_FROM_RPC = 7, /* Error in the XML-RPC code */
|
|
|
|
VIR_FROM_PROXY = 8, /* Error in the proxy code; unused since
|
|
|
|
0.8.6 */
|
|
|
|
VIR_FROM_CONF = 9, /* Error in the configuration file handling */
|
|
|
|
VIR_FROM_QEMU = 10, /* Error at the QEMU daemon */
|
|
|
|
VIR_FROM_NET = 11, /* Error when operating on a network */
|
|
|
|
VIR_FROM_TEST = 12, /* Error from test driver */
|
|
|
|
VIR_FROM_REMOTE = 13, /* Error from remote driver */
|
|
|
|
VIR_FROM_OPENVZ = 14, /* Error from OpenVZ driver */
|
|
|
|
VIR_FROM_XENXM = 15, /* Error at Xen XM layer */
|
|
|
|
VIR_FROM_STATS_LINUX = 16, /* Error in the Linux Stats code */
|
|
|
|
VIR_FROM_LXC = 17, /* Error from Linux Container driver */
|
|
|
|
VIR_FROM_STORAGE = 18, /* Error from storage driver */
|
|
|
|
VIR_FROM_NETWORK = 19, /* Error from network config */
|
|
|
|
VIR_FROM_DOMAIN = 20, /* Error from domain config */
|
|
|
|
VIR_FROM_UML = 21, /* Error at the UML driver */
|
|
|
|
VIR_FROM_NODEDEV = 22, /* Error from node device monitor */
|
|
|
|
VIR_FROM_XEN_INOTIFY = 23, /* Error from xen inotify layer */
|
|
|
|
VIR_FROM_SECURITY = 24, /* Error from security framework */
|
|
|
|
VIR_FROM_VBOX = 25, /* Error from VirtualBox driver */
|
|
|
|
VIR_FROM_INTERFACE = 26, /* Error when operating on an interface */
|
Remove the Open Nebula driver
The Open Nebula driver has been unmaintained since it was first
introduced. The only commits have been for tree-wide cleanups.
It also has a major design flaw, in that it only knows about guests
that it has created itself, which makes it of very limited use.
Discussions wrt evolution of the VMWare ESX driver, concluded that
it should limit itself to single-node ESX operation and not try to
manage the multi-node architecture of VirtualCenter. Open Nebula
is a cluster like Virtual Center, not a single node system, so
the same reasoning applies.
The DeltaCloud project includes an Open Nebula driver and is a much
better fit architecturally, since it is explicitly targetting the
distributed multihost cluster scenario.
Thus this patch deletes the libvirt Open Nebula driver with the
recommendation that people use DeltaCloud for managing it instead.
* configure.ac: Remove probe for xmlrpc & --with-one arg
* daemon/Makefile.am, daemon/libvirtd.c, src/Makefile.am: Remove
ONE driver build
* src/opennebula/one_client.c, src/opennebula/one_client.h,
src/opennebula/one_conf.c, src/opennebula/one_conf.h,
src/opennebula/one_driver.c, src/opennebula/one_driver.c: Delete
files
* autobuild.sh, libvirt.spec.in, mingw32-libvirt.spec.in: Remove
build rules for Open Nebula
* docs/drivers.html.in, docs/sitemap.html.in: Remove reference
to OpenNebula
* docs/drvone.html.in: Delete file
2011-03-22 16:12:34 +00:00
|
|
|
VIR_FROM_ONE = 27, /* The OpenNebula driver no longer exists. Retained for ABI/API compat only */
|
2010-12-21 22:06:27 +00:00
|
|
|
VIR_FROM_ESX = 28, /* Error from ESX driver */
|
|
|
|
VIR_FROM_PHYP = 29, /* Error from IBM power hypervisor */
|
|
|
|
VIR_FROM_SECRET = 30, /* Error from secret storage */
|
|
|
|
VIR_FROM_CPU = 31, /* Error from CPU driver */
|
|
|
|
VIR_FROM_XENAPI = 32, /* Error from XenAPI */
|
|
|
|
VIR_FROM_NWFILTER = 33, /* Error from network filter driver */
|
|
|
|
VIR_FROM_HOOK = 34, /* Error from Synchronous hooks */
|
|
|
|
VIR_FROM_DOMAIN_SNAPSHOT = 35,/* Error from domain snapshot */
|
|
|
|
VIR_FROM_AUDIT = 36, /* Error from auditing subsystem */
|
|
|
|
VIR_FROM_SYSINFO = 37, /* Error from sysinfo/SMBIOS */
|
|
|
|
VIR_FROM_STREAMS = 38, /* Error from I/O streams */
|
|
|
|
VIR_FROM_VMWARE = 39, /* Error from VMware driver */
|
2011-03-02 16:59:54 +00:00
|
|
|
VIR_FROM_EVENT = 40, /* Error from event loop impl */
|
2011-02-10 22:42:34 +00:00
|
|
|
VIR_FROM_LIBXL = 41, /* Error from libxenlight driver */
|
2006-02-24 22:36:10 +00:00
|
|
|
} virErrorDomain;
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* virError:
|
|
|
|
*
|
|
|
|
* A libvirt Error instance.
|
2008-04-09 14:00:07 +00:00
|
|
|
*
|
|
|
|
* The conn, dom and net fields should be used with extreme care.
|
|
|
|
* Reference counts are not incremented so the underlying objects
|
|
|
|
* may be deleted without notice after the error has been delivered.
|
2006-02-24 22:36:10 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
typedef struct _virError virError;
|
|
|
|
typedef virError *virErrorPtr;
|
|
|
|
struct _virError {
|
2006-02-27 16:27:18 +00:00
|
|
|
int code; /* The error code, a virErrorNumber */
|
2006-02-24 22:36:10 +00:00
|
|
|
int domain; /* What part of the library raised this error */
|
|
|
|
char *message;/* human-readable informative error message */
|
|
|
|
virErrorLevel level;/* how consequent is the error */
|
2008-10-10 09:32:27 +00:00
|
|
|
virConnectPtr conn VIR_DEPRECATED; /* connection if available, deprecated
|
2008-05-23 08:32:08 +00:00
|
|
|
see note above */
|
2008-10-10 09:32:27 +00:00
|
|
|
virDomainPtr dom VIR_DEPRECATED; /* domain if available, deprecated
|
|
|
|
see note above */
|
2006-02-24 22:36:10 +00:00
|
|
|
char *str1; /* extra string information */
|
|
|
|
char *str2; /* extra string information */
|
|
|
|
char *str3; /* extra string information */
|
|
|
|
int int1; /* extra number information */
|
|
|
|
int int2; /* extra number information */
|
2008-10-10 09:32:27 +00:00
|
|
|
virNetworkPtr net VIR_DEPRECATED; /* network if available, deprecated
|
|
|
|
see note above */
|
2006-02-24 22:36:10 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* virErrorNumber:
|
|
|
|
*
|
|
|
|
* The full list of errors the library can generate
|
2010-12-21 22:06:27 +00:00
|
|
|
*
|
|
|
|
* This list should remain stable, with all additions placed at the
|
|
|
|
* end since libvirt 0.1.0. There is one exception: values added
|
|
|
|
* between libvirt 0.7.1 and libvirt 0.7.7 (VIR_WAR_NO_SECRET through
|
|
|
|
* VIR_ERR_MIGRATE_PERSIST_FAILED) were inadvertently relocated by
|
|
|
|
* four positions in 0.8.0. If you suspect version mismatch between a
|
|
|
|
* server and client, then you can decipher values as follows:
|
|
|
|
*
|
|
|
|
* switch (err.code) {
|
|
|
|
* case 60:
|
|
|
|
* // no way to tell VIR_WAR_NO_SECRET apart from VIR_WAR_NO_NWFILTER,
|
|
|
|
* // but both are very similar warnings
|
|
|
|
* break;
|
|
|
|
* case 61: case 62: case 63:
|
|
|
|
* if (err.domain != VIR_FROM_NWFILTER)
|
|
|
|
* err.code += 4;
|
|
|
|
* break;
|
|
|
|
* case 64:
|
|
|
|
* if (err.domain == VIR_FROM_QEMU)
|
|
|
|
* err.code += 4;
|
|
|
|
* break;
|
|
|
|
* case 65:
|
|
|
|
* if (err.domain == VIR_FROM_XEN)
|
|
|
|
* err.code += 4;
|
|
|
|
* break;
|
|
|
|
* default:
|
|
|
|
* }
|
2006-02-24 22:36:10 +00:00
|
|
|
*/
|
|
|
|
typedef enum {
|
|
|
|
VIR_ERR_OK = 0,
|
2010-12-21 22:06:27 +00:00
|
|
|
VIR_ERR_INTERNAL_ERROR = 1, /* internal error */
|
|
|
|
VIR_ERR_NO_MEMORY = 2, /* memory allocation failure */
|
|
|
|
VIR_ERR_NO_SUPPORT = 3, /* no support for this function */
|
|
|
|
VIR_ERR_UNKNOWN_HOST = 4, /* could not resolve hostname */
|
|
|
|
VIR_ERR_NO_CONNECT = 5, /* can't connect to hypervisor */
|
|
|
|
VIR_ERR_INVALID_CONN = 6, /* invalid connection object */
|
|
|
|
VIR_ERR_INVALID_DOMAIN = 7, /* invalid domain object */
|
|
|
|
VIR_ERR_INVALID_ARG = 8, /* invalid function argument */
|
|
|
|
VIR_ERR_OPERATION_FAILED = 9, /* a command to hypervisor failed */
|
|
|
|
VIR_ERR_GET_FAILED = 10, /* a HTTP GET command to failed */
|
|
|
|
VIR_ERR_POST_FAILED = 11, /* a HTTP POST command to failed */
|
|
|
|
VIR_ERR_HTTP_ERROR = 12, /* unexpected HTTP error code */
|
|
|
|
VIR_ERR_SEXPR_SERIAL = 13, /* failure to serialize an S-Expr */
|
|
|
|
VIR_ERR_NO_XEN = 14, /* could not open Xen hypervisor
|
|
|
|
control */
|
|
|
|
VIR_ERR_XEN_CALL = 15, /* failure doing an hypervisor call */
|
|
|
|
VIR_ERR_OS_TYPE = 16, /* unknown OS type */
|
|
|
|
VIR_ERR_NO_KERNEL = 17, /* missing kernel information */
|
|
|
|
VIR_ERR_NO_ROOT = 18, /* missing root device information */
|
|
|
|
VIR_ERR_NO_SOURCE = 19, /* missing source device information */
|
|
|
|
VIR_ERR_NO_TARGET = 20, /* missing target device information */
|
|
|
|
VIR_ERR_NO_NAME = 21, /* missing domain name information */
|
|
|
|
VIR_ERR_NO_OS = 22, /* missing domain OS information */
|
|
|
|
VIR_ERR_NO_DEVICE = 23, /* missing domain devices information */
|
|
|
|
VIR_ERR_NO_XENSTORE = 24, /* could not open Xen Store control */
|
|
|
|
VIR_ERR_DRIVER_FULL = 25, /* too many drivers registered */
|
|
|
|
VIR_ERR_CALL_FAILED = 26, /* not supported by the drivers
|
|
|
|
(DEPRECATED) */
|
|
|
|
VIR_ERR_XML_ERROR = 27, /* an XML description is not well
|
|
|
|
formed or broken */
|
|
|
|
VIR_ERR_DOM_EXIST = 28, /* the domain already exist */
|
|
|
|
VIR_ERR_OPERATION_DENIED = 29, /* operation forbidden on read-only
|
|
|
|
connections */
|
|
|
|
VIR_ERR_OPEN_FAILED = 30, /* failed to open a conf file */
|
|
|
|
VIR_ERR_READ_FAILED = 31, /* failed to read a conf file */
|
|
|
|
VIR_ERR_PARSE_FAILED = 32, /* failed to parse a conf file */
|
|
|
|
VIR_ERR_CONF_SYNTAX = 33, /* failed to parse the syntax of a
|
|
|
|
conf file */
|
|
|
|
VIR_ERR_WRITE_FAILED = 34, /* failed to write a conf file */
|
|
|
|
VIR_ERR_XML_DETAIL = 35, /* detail of an XML error */
|
|
|
|
VIR_ERR_INVALID_NETWORK = 36, /* invalid network object */
|
|
|
|
VIR_ERR_NETWORK_EXIST = 37, /* the network already exist */
|
|
|
|
VIR_ERR_SYSTEM_ERROR = 38, /* general system call failure */
|
|
|
|
VIR_ERR_RPC = 39, /* some sort of RPC error */
|
|
|
|
VIR_ERR_GNUTLS_ERROR = 40, /* error from a GNUTLS call */
|
|
|
|
VIR_WAR_NO_NETWORK = 41, /* failed to start network */
|
|
|
|
VIR_ERR_NO_DOMAIN = 42, /* domain not found or unexpectedly
|
|
|
|
disappeared */
|
|
|
|
VIR_ERR_NO_NETWORK = 43, /* network not found */
|
|
|
|
VIR_ERR_INVALID_MAC = 44, /* invalid MAC address */
|
|
|
|
VIR_ERR_AUTH_FAILED = 45, /* authentication failed */
|
|
|
|
VIR_ERR_INVALID_STORAGE_POOL = 46, /* invalid storage pool object */
|
|
|
|
VIR_ERR_INVALID_STORAGE_VOL = 47, /* invalid storage vol object */
|
|
|
|
VIR_WAR_NO_STORAGE = 48, /* failed to start storage */
|
|
|
|
VIR_ERR_NO_STORAGE_POOL = 49, /* storage pool not found */
|
|
|
|
VIR_ERR_NO_STORAGE_VOL = 50, /* storage pool not found */
|
|
|
|
VIR_WAR_NO_NODE = 51, /* failed to start node driver */
|
|
|
|
VIR_ERR_INVALID_NODE_DEVICE = 52, /* invalid node device object */
|
|
|
|
VIR_ERR_NO_NODE_DEVICE = 53, /* node device not found */
|
|
|
|
VIR_ERR_NO_SECURITY_MODEL = 54, /* security model not found */
|
|
|
|
VIR_ERR_OPERATION_INVALID = 55, /* operation is not applicable at this
|
|
|
|
time */
|
|
|
|
VIR_WAR_NO_INTERFACE = 56, /* failed to start interface driver */
|
|
|
|
VIR_ERR_NO_INTERFACE = 57, /* interface driver not running */
|
|
|
|
VIR_ERR_INVALID_INTERFACE = 58, /* invalid interface object */
|
|
|
|
VIR_ERR_MULTIPLE_INTERFACES = 59, /* more than one matching interface
|
|
|
|
found */
|
|
|
|
VIR_WAR_NO_NWFILTER = 60, /* failed to start nwfilter driver */
|
|
|
|
VIR_ERR_INVALID_NWFILTER = 61, /* invalid nwfilter object */
|
|
|
|
VIR_ERR_NO_NWFILTER = 62, /* nw filter pool not found */
|
|
|
|
VIR_ERR_BUILD_FIREWALL = 63, /* nw filter pool not found */
|
|
|
|
VIR_WAR_NO_SECRET = 64, /* failed to start secret storage */
|
|
|
|
VIR_ERR_INVALID_SECRET = 65, /* invalid secret */
|
|
|
|
VIR_ERR_NO_SECRET = 66, /* secret not found */
|
|
|
|
VIR_ERR_CONFIG_UNSUPPORTED = 67, /* unsupported configuration
|
|
|
|
construct */
|
|
|
|
VIR_ERR_OPERATION_TIMEOUT = 68, /* timeout occurred during operation */
|
|
|
|
VIR_ERR_MIGRATE_PERSIST_FAILED = 69,/* a migration worked, but making the
|
|
|
|
VM persist on the dest host failed */
|
|
|
|
VIR_ERR_HOOK_SCRIPT_FAILED = 70, /* a synchronous hook script failed */
|
|
|
|
VIR_ERR_INVALID_DOMAIN_SNAPSHOT = 71,/* invalid domain snapshot */
|
|
|
|
VIR_ERR_NO_DOMAIN_SNAPSHOT = 72, /* domain snapshot not found */
|
2006-02-24 22:36:10 +00:00
|
|
|
} virErrorNumber;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* virErrorFunc:
|
|
|
|
* @userData: user provided data for the error callback
|
|
|
|
* @error: the error being raised.
|
|
|
|
*
|
|
|
|
* Signature of a function to use when there is an error raised by the library.
|
|
|
|
*/
|
|
|
|
typedef void (*virErrorFunc) (void *userData, virErrorPtr error);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Errors can be handled as asynchronous callbacks or after the routine
|
|
|
|
* failed. They can also be handled globally at the library level, or
|
2007-03-15 17:24:56 +00:00
|
|
|
* at the connection level (which then has priority).
|
2006-02-24 22:36:10 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
virErrorPtr virGetLastError (void);
|
2009-02-09 14:16:23 +00:00
|
|
|
virErrorPtr virSaveLastError (void);
|
2006-02-24 22:36:10 +00:00
|
|
|
void virResetLastError (void);
|
|
|
|
void virResetError (virErrorPtr err);
|
2009-02-09 14:16:23 +00:00
|
|
|
void virFreeError (virErrorPtr err);
|
2006-02-24 22:36:10 +00:00
|
|
|
|
|
|
|
virErrorPtr virConnGetLastError (virConnectPtr conn);
|
|
|
|
void virConnResetLastError (virConnectPtr conn);
|
|
|
|
int virCopyLastError (virErrorPtr to);
|
|
|
|
|
2006-02-27 21:34:28 +00:00
|
|
|
void virDefaultErrorFunc (virErrorPtr err);
|
2006-02-24 22:36:10 +00:00
|
|
|
void virSetErrorFunc (void *userData,
|
2008-04-10 16:54:54 +00:00
|
|
|
virErrorFunc handler);
|
2006-02-24 22:36:10 +00:00
|
|
|
void virConnSetErrorFunc (virConnectPtr conn,
|
2008-04-10 16:54:54 +00:00
|
|
|
void *userData,
|
|
|
|
virErrorFunc handler);
|
2006-02-24 22:36:10 +00:00
|
|
|
int virConnCopyLastError (virConnectPtr conn,
|
2008-04-10 16:54:54 +00:00
|
|
|
virErrorPtr to);
|
2010-03-09 18:22:22 +00:00
|
|
|
# ifdef __cplusplus
|
2006-02-24 22:36:10 +00:00
|
|
|
}
|
2010-03-09 18:22:22 +00:00
|
|
|
# endif
|
2006-02-24 22:36:10 +00:00
|
|
|
|
|
|
|
#endif /* __VIR_VIRERR_H__ */
|