2009-11-19 09:05:30 +08:00
|
|
|
/*
|
2010-05-13 03:34:42 +08:00
|
|
|
* QError Module
|
2009-11-19 09:05:30 +08:00
|
|
|
*
|
|
|
|
* Copyright (C) 2009 Red Hat Inc.
|
|
|
|
*
|
|
|
|
* Authors:
|
|
|
|
* Luiz Capitulino <lcapitulino@redhat.com>
|
|
|
|
*
|
|
|
|
* This work is licensed under the terms of the GNU LGPL, version 2.1 or later.
|
|
|
|
* See the COPYING.LIB file in the top-level directory.
|
|
|
|
*/
|
|
|
|
#ifndef QERROR_H
|
|
|
|
#define QERROR_H
|
|
|
|
|
|
|
|
#include "qdict.h"
|
2009-12-08 04:37:16 +08:00
|
|
|
#include "qstring.h"
|
2010-02-19 02:46:49 +08:00
|
|
|
#include "qemu-error.h"
|
2011-09-03 01:34:45 +08:00
|
|
|
#include "error.h"
|
2009-11-19 09:05:30 +08:00
|
|
|
#include <stdarg.h>
|
|
|
|
|
|
|
|
typedef struct QErrorStringTable {
|
|
|
|
const char *desc;
|
|
|
|
const char *error_fmt;
|
|
|
|
} QErrorStringTable;
|
|
|
|
|
|
|
|
typedef struct QError {
|
|
|
|
QObject_HEAD;
|
|
|
|
QDict *error;
|
2010-02-19 02:46:49 +08:00
|
|
|
Location loc;
|
2009-11-19 09:05:30 +08:00
|
|
|
int linenr;
|
|
|
|
const char *file;
|
|
|
|
const char *func;
|
|
|
|
const QErrorStringTable *entry;
|
|
|
|
} QError;
|
|
|
|
|
|
|
|
QError *qerror_new(void);
|
|
|
|
QError *qerror_from_info(const char *file, int linenr, const char *func,
|
2010-09-24 03:28:05 +08:00
|
|
|
const char *fmt, va_list *va) GCC_FMT_ATTR(4, 0);
|
2009-12-08 04:37:16 +08:00
|
|
|
QString *qerror_human(const QError *qerror);
|
2010-02-19 02:46:49 +08:00
|
|
|
void qerror_print(QError *qerror);
|
2010-03-22 17:29:05 +08:00
|
|
|
void qerror_report_internal(const char *file, int linenr, const char *func,
|
2010-09-24 03:28:03 +08:00
|
|
|
const char *fmt, ...) GCC_FMT_ATTR(4, 5);
|
2011-09-03 01:34:45 +08:00
|
|
|
void qerror_report_err(Error *err);
|
2011-06-02 01:14:48 +08:00
|
|
|
QString *qerror_format(const char *fmt, QDict *error);
|
2010-03-22 17:29:05 +08:00
|
|
|
#define qerror_report(fmt, ...) \
|
|
|
|
qerror_report_internal(__FILE__, __LINE__, __func__, fmt, ## __VA_ARGS__)
|
2009-11-19 09:05:30 +08:00
|
|
|
QError *qobject_to_qerror(const QObject *obj);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* QError class list
|
2010-03-26 00:22:30 +08:00
|
|
|
* Please keep the definitions in alphabetical order.
|
|
|
|
* Use "grep '^#define QERR_' qerror.h | sort -c" to check.
|
2009-11-19 09:05:30 +08:00
|
|
|
*/
|
2010-02-20 02:52:45 +08:00
|
|
|
#define QERR_BAD_BUS_FOR_DEVICE \
|
|
|
|
"{ 'class': 'BadBusForDevice', 'data': { 'device': %s, 'bad_bus_type': %s } }"
|
|
|
|
|
2010-02-20 01:05:39 +08:00
|
|
|
#define QERR_BUS_NOT_FOUND \
|
|
|
|
"{ 'class': 'BusNotFound', 'data': { 'bus': %s } }"
|
|
|
|
|
2010-02-20 02:53:36 +08:00
|
|
|
#define QERR_BUS_NO_HOTPLUG \
|
|
|
|
"{ 'class': 'BusNoHotplug', 'data': { 'bus': %s } }"
|
|
|
|
|
2009-11-27 08:58:57 +08:00
|
|
|
#define QERR_COMMAND_NOT_FOUND \
|
2009-12-08 04:37:02 +08:00
|
|
|
"{ 'class': 'CommandNotFound', 'data': { 'name': %s } }"
|
2009-11-27 08:58:57 +08:00
|
|
|
|
2009-12-08 04:36:59 +08:00
|
|
|
#define QERR_DEVICE_ENCRYPTED \
|
2009-12-08 04:37:02 +08:00
|
|
|
"{ 'class': 'DeviceEncrypted', 'data': { 'device': %s } }"
|
2009-11-19 09:05:30 +08:00
|
|
|
|
2010-02-20 02:53:54 +08:00
|
|
|
#define QERR_DEVICE_INIT_FAILED \
|
|
|
|
"{ 'class': 'DeviceInitFailed', 'data': { 'device': %s } }"
|
|
|
|
|
2010-03-26 00:22:39 +08:00
|
|
|
#define QERR_DEVICE_IN_USE \
|
|
|
|
"{ 'class': 'DeviceInUse', 'data': { 'device': %s } }"
|
|
|
|
|
2010-02-20 00:42:46 +08:00
|
|
|
#define QERR_DEVICE_LOCKED \
|
2009-12-08 04:37:03 +08:00
|
|
|
"{ 'class': 'DeviceLocked', 'data': { 'device': %s } }"
|
|
|
|
|
2010-02-20 01:05:59 +08:00
|
|
|
#define QERR_DEVICE_MULTIPLE_BUSSES \
|
|
|
|
"{ 'class': 'DeviceMultipleBusses', 'data': { 'device': %s } }"
|
|
|
|
|
2009-11-19 09:05:34 +08:00
|
|
|
#define QERR_DEVICE_NOT_ACTIVE \
|
2009-12-08 04:37:02 +08:00
|
|
|
"{ 'class': 'DeviceNotActive', 'data': { 'device': %s } }"
|
|
|
|
|
2010-03-26 00:22:30 +08:00
|
|
|
#define QERR_DEVICE_NOT_ENCRYPTED \
|
|
|
|
"{ 'class': 'DeviceNotEncrypted', 'data': { 'device': %s } }"
|
|
|
|
|
2009-12-08 04:37:02 +08:00
|
|
|
#define QERR_DEVICE_NOT_FOUND \
|
|
|
|
"{ 'class': 'DeviceNotFound', 'data': { 'device': %s } }"
|
2009-11-19 09:05:34 +08:00
|
|
|
|
2009-12-08 04:37:04 +08:00
|
|
|
#define QERR_DEVICE_NOT_REMOVABLE \
|
|
|
|
"{ 'class': 'DeviceNotRemovable', 'data': { 'device': %s } }"
|
|
|
|
|
2010-02-20 01:06:18 +08:00
|
|
|
#define QERR_DEVICE_NO_BUS \
|
|
|
|
"{ 'class': 'DeviceNoBus', 'data': { 'device': %s } }"
|
|
|
|
|
2011-01-06 22:14:37 +08:00
|
|
|
#define QERR_DEVICE_NO_HOTPLUG \
|
|
|
|
"{ 'class': 'DeviceNoHotplug', 'data': { 'device': %s } }"
|
|
|
|
|
2010-03-26 00:22:31 +08:00
|
|
|
#define QERR_DUPLICATE_ID \
|
|
|
|
"{ 'class': 'DuplicateId', 'data': { 'id': %s, 'object': %s } }"
|
|
|
|
|
2009-12-08 04:37:10 +08:00
|
|
|
#define QERR_FD_NOT_FOUND \
|
2009-12-08 20:33:54 +08:00
|
|
|
"{ 'class': 'FdNotFound', 'data': { 'name': %s } }"
|
2009-12-08 04:37:10 +08:00
|
|
|
|
2009-12-08 04:37:12 +08:00
|
|
|
#define QERR_FD_NOT_SUPPLIED \
|
2009-12-08 20:33:54 +08:00
|
|
|
"{ 'class': 'FdNotSupplied', 'data': {} }"
|
2009-12-08 04:37:12 +08:00
|
|
|
|
2009-12-08 04:37:06 +08:00
|
|
|
#define QERR_INVALID_BLOCK_FORMAT \
|
|
|
|
"{ 'class': 'InvalidBlockFormat', 'data': { 'name': %s } }"
|
|
|
|
|
2009-12-08 04:37:13 +08:00
|
|
|
#define QERR_INVALID_PARAMETER \
|
2009-12-08 20:33:54 +08:00
|
|
|
"{ 'class': 'InvalidParameter', 'data': { 'name': %s } }"
|
2009-12-08 04:37:13 +08:00
|
|
|
|
2009-11-27 08:58:57 +08:00
|
|
|
#define QERR_INVALID_PARAMETER_TYPE \
|
2009-12-08 04:37:02 +08:00
|
|
|
"{ 'class': 'InvalidParameterType', 'data': { 'name': %s,'expected': %s } }"
|
2009-11-27 08:58:57 +08:00
|
|
|
|
2010-03-26 00:22:33 +08:00
|
|
|
#define QERR_INVALID_PARAMETER_VALUE \
|
|
|
|
"{ 'class': 'InvalidParameterValue', 'data': { 'name': %s, 'expected': %s } }"
|
|
|
|
|
2009-12-05 01:24:08 +08:00
|
|
|
#define QERR_INVALID_PASSWORD \
|
2009-12-08 04:37:02 +08:00
|
|
|
"{ 'class': 'InvalidPassword', 'data': {} }"
|
|
|
|
|
|
|
|
#define QERR_JSON_PARSING \
|
|
|
|
"{ 'class': 'JSONParsing', 'data': {} }"
|
2009-12-05 01:24:08 +08:00
|
|
|
|
2011-06-02 01:14:50 +08:00
|
|
|
#define QERR_JSON_PARSE_ERROR \
|
|
|
|
"{ 'class': 'JSONParseError', 'data': { 'message': %s } }"
|
|
|
|
|
2011-07-20 03:50:33 +08:00
|
|
|
#define QERR_BUFFER_OVERRUN \
|
|
|
|
"{ 'class': 'BufferOverrun', 'data': {} }"
|
|
|
|
|
2009-11-19 09:05:35 +08:00
|
|
|
#define QERR_KVM_MISSING_CAP \
|
2009-12-08 04:37:02 +08:00
|
|
|
"{ 'class': 'KVMMissingCap', 'data': { 'capability': %s, 'feature': %s } }"
|
2009-11-19 09:05:35 +08:00
|
|
|
|
2010-07-27 18:19:19 +08:00
|
|
|
#define QERR_MIGRATION_EXPECTED \
|
|
|
|
"{ 'class': 'MigrationExpected', 'data': {} }"
|
|
|
|
|
2009-11-27 08:58:57 +08:00
|
|
|
#define QERR_MISSING_PARAMETER \
|
2009-12-08 04:37:02 +08:00
|
|
|
"{ 'class': 'MissingParameter', 'data': { 'name': %s } }"
|
2009-11-27 08:58:57 +08:00
|
|
|
|
2010-02-20 02:54:06 +08:00
|
|
|
#define QERR_NO_BUS_FOR_DEVICE \
|
|
|
|
"{ 'class': 'NoBusForDevice', 'data': { 'device': %s, 'bus': %s } }"
|
|
|
|
|
2010-02-20 00:42:46 +08:00
|
|
|
#define QERR_OPEN_FILE_FAILED \
|
|
|
|
"{ 'class': 'OpenFileFailed', 'data': { 'filename': %s } }"
|
|
|
|
|
2010-02-19 20:11:41 +08:00
|
|
|
#define QERR_PROPERTY_NOT_FOUND \
|
|
|
|
"{ 'class': 'PropertyNotFound', 'data': { 'device': %s, 'property': %s } }"
|
|
|
|
|
2010-02-19 20:17:58 +08:00
|
|
|
#define QERR_PROPERTY_VALUE_BAD \
|
|
|
|
"{ 'class': 'PropertyValueBad', 'data': { 'device': %s, 'property': %s, 'value': %s } }"
|
|
|
|
|
2010-03-17 00:40:48 +08:00
|
|
|
#define QERR_PROPERTY_VALUE_IN_USE \
|
|
|
|
"{ 'class': 'PropertyValueInUse', 'data': { 'device': %s, 'property': %s, 'value': %s } }"
|
|
|
|
|
2010-03-17 00:44:38 +08:00
|
|
|
#define QERR_PROPERTY_VALUE_NOT_FOUND \
|
|
|
|
"{ 'class': 'PropertyValueNotFound', 'data': { 'device': %s, 'property': %s, 'value': %s } }"
|
|
|
|
|
2009-11-27 08:58:57 +08:00
|
|
|
#define QERR_QMP_BAD_INPUT_OBJECT \
|
2009-12-08 04:37:02 +08:00
|
|
|
"{ 'class': 'QMPBadInputObject', 'data': { 'expected': %s } }"
|
2009-11-27 08:58:57 +08:00
|
|
|
|
2010-04-08 01:46:33 +08:00
|
|
|
#define QERR_QMP_BAD_INPUT_OBJECT_MEMBER \
|
|
|
|
"{ 'class': 'QMPBadInputObjectMember', 'data': { 'member': %s, 'expected': %s } }"
|
|
|
|
|
2010-06-02 03:15:23 +08:00
|
|
|
#define QERR_QMP_EXTRA_MEMBER \
|
|
|
|
"{ 'class': 'QMPExtraInputObjectMember', 'data': { 'member': %s } }"
|
|
|
|
|
2011-07-30 02:57:54 +08:00
|
|
|
#define QERR_RESET_REQUIRED \
|
|
|
|
"{ 'class': 'ResetRequired', 'data': {} }"
|
|
|
|
|
2009-12-08 04:37:07 +08:00
|
|
|
#define QERR_SET_PASSWD_FAILED \
|
|
|
|
"{ 'class': 'SetPasswdFailed', 'data': {} }"
|
|
|
|
|
Introduce a 'client_add' monitor command accepting an open FD
Allow client connections for VNC and socket based character
devices to be passed in over the monitor using SCM_RIGHTS.
One intended usage scenario is to start QEMU with VNC on a
UNIX domain socket. An unprivileged user which cannot access
the UNIX domain socket, can then connect to QEMU's VNC server
by passing an open FD to libvirt, which passes it onto QEMU.
{ "execute": "get_fd", "arguments": { "fdname": "myclient" } }
{ "return": {} }
{ "execute": "add_client", "arguments": { "protocol": "vnc",
"fdname": "myclient",
"skipauth": true } }
{ "return": {} }
In this case 'protocol' can be 'vnc' or 'spice', or the name
of a character device (eg from -chardev id=XXXX)
The 'skipauth' parameter can be used to skip any configured
VNC authentication scheme, which is useful if the mgmt layer
talking to the monitor has already authenticated the client
in another way.
* console.h: Define 'vnc_display_add_client' method
* monitor.c: Implement 'client_add' command
* qemu-char.c, qemu-char.h: Add 'qemu_char_add_client' method
* qerror.c, qerror.h: Add QERR_ADD_CLIENT_FAILED
* qmp-commands.hx: Declare 'client_add' command
* ui/vnc.c: Implement 'vnc_display_add_client' method
Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
2011-06-23 20:31:42 +08:00
|
|
|
#define QERR_ADD_CLIENT_FAILED \
|
|
|
|
"{ 'class': 'AddClientFailed', 'data': {} }"
|
|
|
|
|
2009-12-08 04:37:14 +08:00
|
|
|
#define QERR_TOO_MANY_FILES \
|
2009-12-08 20:33:54 +08:00
|
|
|
"{ 'class': 'TooManyFiles', 'data': {} }"
|
2009-12-08 04:37:14 +08:00
|
|
|
|
2010-02-20 00:42:46 +08:00
|
|
|
#define QERR_UNDEFINED_ERROR \
|
|
|
|
"{ 'class': 'UndefinedError', 'data': {} }"
|
|
|
|
|
2011-03-07 17:05:04 +08:00
|
|
|
#define QERR_UNSUPPORTED \
|
|
|
|
"{ 'class': 'Unsupported', 'data': {} }"
|
|
|
|
|
2011-02-09 18:09:38 +08:00
|
|
|
#define QERR_UNKNOWN_BLOCK_FORMAT_FEATURE \
|
|
|
|
"{ 'class': 'UnknownBlockFormatFeature', 'data': { 'device': %s, 'format': %s, 'feature': %s } }"
|
|
|
|
|
2009-12-08 04:37:08 +08:00
|
|
|
#define QERR_VNC_SERVER_FAILED \
|
|
|
|
"{ 'class': 'VNCServerFailed', 'data': { 'target': %s } }"
|
|
|
|
|
2011-03-16 20:33:36 +08:00
|
|
|
#define QERR_FEATURE_DISABLED \
|
|
|
|
"{ 'class': 'FeatureDisabled', 'data': { 'name': %s } }"
|
|
|
|
|
2011-07-20 04:41:55 +08:00
|
|
|
#define QERR_QGA_LOGGING_FAILED \
|
|
|
|
"{ 'class': 'QgaLoggingFailed', 'data': {} }"
|
|
|
|
|
|
|
|
#define QERR_QGA_COMMAND_FAILED \
|
|
|
|
"{ 'class': 'QgaCommandFailed', 'data': { 'message': %s } }"
|
|
|
|
|
2009-11-19 09:05:30 +08:00
|
|
|
#endif /* QERROR_H */
|