ab02ab2aa7
Given an object recieved via QMP, this code uses the dispatch table provided by qmp_registry.c to call the corresponding marshalling/dispatch function and format return values/errors for delivery to the QMP. Currently only synchronous QMP functions are supported, but this will also be used for async QMP functions and QMP guest proxy dispatch as well. Signed-off-by: Michael Roth <mdroth@linux.vnet.ibm.com> Signed-off-by: Luiz Capitulino <lcapitulino@gmail.com>
42 lines
822 B
C
42 lines
822 B
C
/*
|
|
* Core Definitions for QAPI/QMP Dispatch
|
|
*
|
|
* Copyright IBM, Corp. 2011
|
|
*
|
|
* Authors:
|
|
* Anthony Liguori <aliguori@us.ibm.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 QMP_CORE_H
|
|
#define QMP_CORE_H
|
|
|
|
#include "qobject.h"
|
|
#include "qdict.h"
|
|
#include "error.h"
|
|
|
|
typedef void (QmpCommandFunc)(QDict *, QObject **, Error **);
|
|
|
|
typedef enum QmpCommandType
|
|
{
|
|
QCT_NORMAL,
|
|
} QmpCommandType;
|
|
|
|
typedef struct QmpCommand
|
|
{
|
|
const char *name;
|
|
QmpCommandType type;
|
|
QmpCommandFunc *fn;
|
|
QTAILQ_ENTRY(QmpCommand) node;
|
|
} QmpCommand;
|
|
|
|
void qmp_register_command(const char *name, QmpCommandFunc *fn);
|
|
QmpCommand *qmp_find_command(const char *name);
|
|
QObject *qmp_dispatch(QObject *request);
|
|
|
|
#endif
|
|
|