| #ifndef MONITOR_H |
| #define MONITOR_H |
| |
| #include "qemu-common.h" |
| #include "sysemu/char.h" |
| #include "qapi/qmp/qerror.h" |
| #include "qapi/qmp/qdict.h" |
| #include "block/block.h" |
| |
| extern Monitor *cur_mon; |
| extern Monitor *default_mon; |
| |
| /* flags for monitor_init */ |
| #define MONITOR_IS_DEFAULT 0x01 |
| #define MONITOR_USE_READLINE 0x02 |
| #define MONITOR_USE_CONTROL 0x04 |
| #define MONITOR_USE_PRETTY 0x08 |
| #define MONITOR_QUIT_DOESNT_EXIT 0x80 /* prevent 'quit' from exiting the emulator */ |
| |
| /* flags for monitor commands */ |
| #define MONITOR_CMD_ASYNC 0x0001 |
| #define MONITOR_CMD_USER_ONLY 0x0002 |
| |
| /* QMP events */ |
| typedef enum MonitorEvent { |
| QEVENT_SHUTDOWN, |
| QEVENT_RESET, |
| QEVENT_POWERDOWN, |
| QEVENT_STOP, |
| QEVENT_RESUME, |
| QEVENT_VNC_CONNECTED, |
| QEVENT_VNC_INITIALIZED, |
| QEVENT_VNC_DISCONNECTED, |
| QEVENT_BLOCK_IO_ERROR, |
| QEVENT_RTC_CHANGE, |
| QEVENT_WATCHDOG, |
| QEVENT_SPICE_CONNECTED, |
| QEVENT_SPICE_INITIALIZED, |
| QEVENT_SPICE_DISCONNECTED, |
| QEVENT_MAX, |
| } MonitorEvent; |
| |
| int monitor_cur_is_qmp(void); |
| |
| void monitor_protocol_event(MonitorEvent event, QObject *data); |
| void monitor_init(CharDriverState *chr, int flags); |
| |
| int monitor_suspend(Monitor *mon); |
| void monitor_resume(Monitor *mon); |
| |
| int monitor_read_bdrv_key_start(Monitor *mon, BlockDriverState *bs, |
| BlockDriverCompletionFunc *completion_cb, |
| void *opaque); |
| |
| int monitor_get_fd(Monitor *mon, const char *fdname); |
| |
| void monitor_vprintf(Monitor *mon, const char *fmt, va_list ap) |
| GCC_FMT_ATTR(2, 0); |
| void monitor_printf(Monitor *mon, const char *fmt, ...) GCC_FMT_ATTR(2, 3); |
| void monitor_print_filename(Monitor *mon, const char *filename); |
| void monitor_flush(Monitor *mon); |
| |
| typedef void (MonitorCompletion)(void *opaque, QObject *ret_data); |
| |
| void monitor_set_error(Monitor *mon, QError *qerror); |
| |
| #ifdef CONFIG_ANDROID |
| typedef int (*MonitorFakeFunc)(void* opaque, const char* str, int strsize); |
| |
| /* Create a new fake Monitor object to send all output to an internal |
| * buffer. This is used to send snapshot save/load errors (produced in |
| * savevm.c) to the Android console when 'avd snapshot save' or |
| * 'avd snapshot load' are used. |
| */ |
| Monitor* monitor_fake_new(void* opaque, MonitorFakeFunc cb); |
| int monitor_fake_get_bytes(Monitor* mon); |
| void monitor_fake_free(Monitor* mon); |
| #endif |
| |
| #endif /* !MONITOR_H */ |