2007-11-17 20:14:51 +03:00
|
|
|
#ifndef SYSEMU_H
|
|
|
|
#define SYSEMU_H
|
|
|
|
/* Misc. things related to the system emulator. */
|
|
|
|
|
2012-12-17 21:20:00 +04:00
|
|
|
#include "qemu/option.h"
|
|
|
|
#include "qemu/queue.h"
|
|
|
|
#include "qemu/timer.h"
|
2011-09-13 00:54:20 +04:00
|
|
|
#include "qapi-types.h"
|
2012-12-17 21:20:00 +04:00
|
|
|
#include "qemu/notify.h"
|
|
|
|
#include "qemu/main-loop.h"
|
2014-05-14 13:43:07 +04:00
|
|
|
#include "qemu/bitmap.h"
|
2016-09-21 07:27:22 +03:00
|
|
|
#include "qemu/uuid.h"
|
2014-05-14 13:43:15 +04:00
|
|
|
#include "qom/object.h"
|
2009-03-06 02:01:23 +03:00
|
|
|
|
2007-11-17 20:14:51 +03:00
|
|
|
/* vl.c */
|
2011-07-29 21:26:33 +04:00
|
|
|
|
2007-11-17 20:14:51 +03:00
|
|
|
extern const char *bios_name;
|
2009-05-30 03:52:44 +04:00
|
|
|
|
2007-11-17 20:14:51 +03:00
|
|
|
extern const char *qemu_name;
|
2016-09-21 07:27:22 +03:00
|
|
|
extern QemuUUID qemu_uuid;
|
smbios: Make multiple -smbios type= accumulate sanely
Currently, -smbios type=T,NAME=VAL,... adds one field (T,NAME) with
value VAL to fw_cfg for each unique NAME. If NAME occurs multiple
times, the last one's VAL is used (before the QemuOpts conversion, the
first one was used).
Multiple -smbios can add multiple fields with the same (T, NAME).
SeaBIOS reads all of them from fw_cfg, but uses only the first field
(T, NAME). The others are ignored.
"First one wins, subsequent ones get ignored silently" isn't nice. We
commonly let the last option win. Useful, because it lets you
-readconfig first, then selectively override with command line
options.
Clean up -smbios to work the common way. Accumulate the settings,
with later ones overwriting earlier ones. Put the result into fw_cfg
(no more useless duplicates).
Bonus cleanup: qemu_uuid_parse() no longer sets SMBIOS system uuid by
side effect.
Signed-off-by: Markus Armbruster <armbru@redhat.com>
Reviewed-by: Eric Blake <eblake@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2013-08-16 17:18:31 +04:00
|
|
|
extern bool qemu_uuid_set;
|
2007-11-17 20:14:51 +03:00
|
|
|
|
2011-07-29 22:04:45 +04:00
|
|
|
bool runstate_check(RunState state);
|
|
|
|
void runstate_set(RunState new_state);
|
2011-07-29 22:36:43 +04:00
|
|
|
int runstate_is_running(void);
|
2013-04-26 07:24:40 +04:00
|
|
|
bool runstate_needs_reset(void);
|
2014-10-08 13:53:22 +04:00
|
|
|
bool runstate_store(char *str, size_t size);
|
2007-11-17 20:14:51 +03:00
|
|
|
typedef struct vm_change_state_entry VMChangeStateEntry;
|
2011-07-29 21:26:33 +04:00
|
|
|
typedef void VMChangeStateHandler(void *opaque, int running, RunState state);
|
2007-11-17 20:14:51 +03:00
|
|
|
|
|
|
|
VMChangeStateEntry *qemu_add_vm_change_state_handler(VMChangeStateHandler *cb,
|
|
|
|
void *opaque);
|
|
|
|
void qemu_del_vm_change_state_handler(VMChangeStateEntry *e);
|
2011-07-29 21:26:33 +04:00
|
|
|
void vm_state_notify(int running, RunState state);
|
2011-02-09 18:29:40 +03:00
|
|
|
|
2011-06-14 20:29:43 +04:00
|
|
|
#define VMRESET_SILENT false
|
|
|
|
#define VMRESET_REPORT true
|
|
|
|
|
2007-11-17 20:14:51 +03:00
|
|
|
void vm_start(void);
|
2013-07-05 15:49:54 +04:00
|
|
|
int vm_stop(RunState state);
|
|
|
|
int vm_stop_force_state(RunState state);
|
2007-11-17 20:14:51 +03:00
|
|
|
|
2012-02-23 16:45:19 +04:00
|
|
|
typedef enum WakeupReason {
|
2013-09-25 20:38:29 +04:00
|
|
|
/* Always keep QEMU_WAKEUP_REASON_NONE = 0 */
|
|
|
|
QEMU_WAKEUP_REASON_NONE = 0,
|
2012-02-23 16:45:24 +04:00
|
|
|
QEMU_WAKEUP_REASON_RTC,
|
2012-02-23 16:45:25 +04:00
|
|
|
QEMU_WAKEUP_REASON_PMTIMER,
|
2013-09-25 20:38:29 +04:00
|
|
|
QEMU_WAKEUP_REASON_OTHER,
|
2012-02-23 16:45:19 +04:00
|
|
|
} WakeupReason;
|
|
|
|
|
2007-11-17 20:14:51 +03:00
|
|
|
void qemu_system_reset_request(void);
|
2012-02-23 16:45:19 +04:00
|
|
|
void qemu_system_suspend_request(void);
|
|
|
|
void qemu_register_suspend_notifier(Notifier *notifier);
|
|
|
|
void qemu_system_wakeup_request(WakeupReason reason);
|
|
|
|
void qemu_system_wakeup_enable(WakeupReason reason, bool enabled);
|
|
|
|
void qemu_register_wakeup_notifier(Notifier *notifier);
|
2007-11-17 20:14:51 +03:00
|
|
|
void qemu_system_shutdown_request(void);
|
|
|
|
void qemu_system_powerdown_request(void);
|
2012-09-06 01:06:21 +04:00
|
|
|
void qemu_register_powerdown_notifier(Notifier *notifier);
|
2011-02-07 14:19:16 +03:00
|
|
|
void qemu_system_debug_request(void);
|
2011-07-29 21:26:33 +04:00
|
|
|
void qemu_system_vmstop_request(RunState reason);
|
2014-06-05 16:53:58 +04:00
|
|
|
void qemu_system_vmstop_request_prepare(void);
|
2010-07-22 18:52:48 +04:00
|
|
|
int qemu_shutdown_requested_get(void);
|
|
|
|
int qemu_reset_requested_get(void);
|
2011-03-15 14:56:04 +03:00
|
|
|
void qemu_system_killed(int signal, pid_t pid);
|
2011-06-14 20:29:43 +04:00
|
|
|
void qemu_system_reset(bool report);
|
2015-07-03 15:01:42 +03:00
|
|
|
void qemu_system_guest_panicked(void);
|
2015-11-05 21:10:29 +03:00
|
|
|
size_t qemu_target_page_bits(void);
|
2007-11-17 20:14:51 +03:00
|
|
|
|
2010-06-04 16:08:07 +04:00
|
|
|
void qemu_add_exit_notifier(Notifier *notify);
|
|
|
|
void qemu_remove_exit_notifier(Notifier *notify);
|
|
|
|
|
2010-12-08 14:35:08 +03:00
|
|
|
void qemu_add_machine_init_done_notifier(Notifier *notify);
|
2016-06-27 18:38:32 +03:00
|
|
|
void qemu_remove_machine_init_done_notifier(Notifier *notify);
|
2010-12-08 14:35:08 +03:00
|
|
|
|
hmp: Name HMP command handler functions hmp_COMMAND()
Some are called do_COMMAND() (old ones, usually), some hmp_COMMAND(),
and sometimes COMMAND pointlessly differs in spelling.
Normalize to hmp_COMMAND(), where COMMAND is exactly the command name
with '-' replaced by '_'.
Exceptions:
* do_device_add() and client_migrate_info() *not* renamed to
hmp_device_add(), hmp_client_migrate_info(), because they're also
QMP handlers. They still need to be converted to QAPI.
* do_memory_dump(), do_physical_memory_dump(), do_ioport_read(),
do_ioport_write() renamed do hmp_* instead of hmp_x(), hmp_xp(),
hmp_i(), hmp_o(), because those names are too cryptic for my taste.
* do_info_help() renamed to hmp_info_help() instead of hmp_info(),
because it only covers help.
Signed-off-by: Markus Armbruster <armbru@redhat.com>
2015-02-06 15:55:43 +03:00
|
|
|
void hmp_savevm(Monitor *mon, const QDict *qdict);
|
2017-01-24 10:17:41 +03:00
|
|
|
int save_vmstate(Monitor *mon, const char *name);
|
2010-02-17 18:24:10 +03:00
|
|
|
int load_vmstate(const char *name);
|
hmp: Name HMP command handler functions hmp_COMMAND()
Some are called do_COMMAND() (old ones, usually), some hmp_COMMAND(),
and sometimes COMMAND pointlessly differs in spelling.
Normalize to hmp_COMMAND(), where COMMAND is exactly the command name
with '-' replaced by '_'.
Exceptions:
* do_device_add() and client_migrate_info() *not* renamed to
hmp_device_add(), hmp_client_migrate_info(), because they're also
QMP handlers. They still need to be converted to QAPI.
* do_memory_dump(), do_physical_memory_dump(), do_ioport_read(),
do_ioport_write() renamed do hmp_* instead of hmp_x(), hmp_xp(),
hmp_i(), hmp_o(), because those names are too cryptic for my taste.
* do_info_help() renamed to hmp_info_help() instead of hmp_info(),
because it only covers help.
Signed-off-by: Markus Armbruster <armbru@redhat.com>
2015-02-06 15:55:43 +03:00
|
|
|
void hmp_delvm(Monitor *mon, const QDict *qdict);
|
2015-02-06 16:18:24 +03:00
|
|
|
void hmp_info_snapshots(Monitor *mon, const QDict *qdict);
|
2007-11-17 20:14:51 +03:00
|
|
|
|
2008-10-13 07:13:12 +04:00
|
|
|
void qemu_announce_self(void);
|
|
|
|
|
2015-11-05 21:10:45 +03:00
|
|
|
/* Subcommands for QEMU_VM_COMMAND */
|
|
|
|
enum qemu_vm_cmd {
|
|
|
|
MIG_CMD_INVALID = 0, /* Must be 0 */
|
2015-11-05 21:10:46 +03:00
|
|
|
MIG_CMD_OPEN_RETURN_PATH, /* Tell the dest to open the Return path */
|
|
|
|
MIG_CMD_PING, /* Request a PONG on the RP */
|
2015-11-05 21:10:52 +03:00
|
|
|
|
|
|
|
MIG_CMD_POSTCOPY_ADVISE, /* Prior to any page transfers, just
|
|
|
|
warn we might want to do PC */
|
|
|
|
MIG_CMD_POSTCOPY_LISTEN, /* Start listening for incoming
|
|
|
|
pages as it's running. */
|
|
|
|
MIG_CMD_POSTCOPY_RUN, /* Start execution */
|
|
|
|
|
|
|
|
MIG_CMD_POSTCOPY_RAM_DISCARD, /* A list of pages to discard that
|
|
|
|
were previously sent during
|
|
|
|
precopy but are dirty. */
|
2015-11-05 21:10:53 +03:00
|
|
|
MIG_CMD_PACKAGED, /* Send a wrapped stream within this stream */
|
2015-11-05 21:10:45 +03:00
|
|
|
MIG_CMD_MAX
|
|
|
|
};
|
|
|
|
|
2015-11-05 21:10:53 +03:00
|
|
|
#define MAX_VM_CMD_PACKAGED_SIZE (1ul << 24)
|
|
|
|
|
2011-12-05 20:48:01 +04:00
|
|
|
bool qemu_savevm_state_blocked(Error **errp);
|
2013-02-22 20:36:13 +04:00
|
|
|
void qemu_savevm_state_begin(QEMUFile *f,
|
|
|
|
const MigrationParams *params);
|
2015-05-21 15:24:12 +03:00
|
|
|
void qemu_savevm_state_header(QEMUFile *f);
|
2015-11-05 21:11:14 +03:00
|
|
|
int qemu_savevm_state_iterate(QEMUFile *f, bool postcopy);
|
2015-11-02 10:37:01 +03:00
|
|
|
void qemu_savevm_state_cleanup(void);
|
2015-11-05 21:11:00 +03:00
|
|
|
void qemu_savevm_state_complete_postcopy(QEMUFile *f);
|
2015-11-11 17:02:27 +03:00
|
|
|
void qemu_savevm_state_complete_precopy(QEMUFile *f, bool iterable_only);
|
2015-11-05 21:10:54 +03:00
|
|
|
void qemu_savevm_state_pending(QEMUFile *f, uint64_t max_size,
|
|
|
|
uint64_t *res_non_postcopiable,
|
|
|
|
uint64_t *res_postcopiable);
|
2015-11-05 21:10:45 +03:00
|
|
|
void qemu_savevm_command_send(QEMUFile *f, enum qemu_vm_cmd command,
|
|
|
|
uint16_t len, uint8_t *data);
|
2015-11-05 21:10:46 +03:00
|
|
|
void qemu_savevm_send_ping(QEMUFile *f, uint32_t value);
|
|
|
|
void qemu_savevm_send_open_return_path(QEMUFile *f);
|
2016-04-27 13:05:01 +03:00
|
|
|
int qemu_savevm_send_packaged(QEMUFile *f, const uint8_t *buf, size_t len);
|
2015-11-05 21:10:52 +03:00
|
|
|
void qemu_savevm_send_postcopy_advise(QEMUFile *f);
|
|
|
|
void qemu_savevm_send_postcopy_listen(QEMUFile *f);
|
|
|
|
void qemu_savevm_send_postcopy_run(QEMUFile *f);
|
|
|
|
|
|
|
|
void qemu_savevm_send_postcopy_ram_discard(QEMUFile *f, const char *name,
|
|
|
|
uint16_t len,
|
|
|
|
uint64_t *start_list,
|
|
|
|
uint64_t *length_list);
|
|
|
|
|
2008-10-06 18:53:52 +04:00
|
|
|
int qemu_loadvm_state(QEMUFile *f);
|
|
|
|
|
2009-07-28 01:17:51 +04:00
|
|
|
extern int autostart;
|
2009-07-30 14:15:02 +04:00
|
|
|
|
|
|
|
typedef enum {
|
2010-04-27 13:50:11 +04:00
|
|
|
VGA_NONE, VGA_STD, VGA_CIRRUS, VGA_VMWARE, VGA_XENFB, VGA_QXL,
|
2014-09-10 16:28:48 +04:00
|
|
|
VGA_TCX, VGA_CG3, VGA_DEVICE, VGA_VIRTIO,
|
2015-10-29 00:19:58 +03:00
|
|
|
VGA_TYPE_MAX,
|
2009-07-30 14:15:02 +04:00
|
|
|
} VGAInterfaceType;
|
|
|
|
|
|
|
|
extern int vga_interface_type;
|
|
|
|
#define xenfb_enabled (vga_interface_type == VGA_XENFB)
|
|
|
|
|
2007-11-17 20:14:51 +03:00
|
|
|
extern int graphic_width;
|
|
|
|
extern int graphic_height;
|
|
|
|
extern int graphic_depth;
|
2014-11-20 11:49:44 +03:00
|
|
|
extern int display_opengl;
|
2007-11-17 20:14:51 +03:00
|
|
|
extern const char *keyboard_layout;
|
|
|
|
extern int win2k_install_hack;
|
|
|
|
extern int alt_grab;
|
2009-09-18 00:48:04 +04:00
|
|
|
extern int ctrl_grab;
|
2007-11-17 20:14:51 +03:00
|
|
|
extern int smp_cpus;
|
2009-07-23 19:03:42 +04:00
|
|
|
extern int max_cpus;
|
2007-11-17 20:14:51 +03:00
|
|
|
extern int cursor_hide;
|
|
|
|
extern int graphic_rotate;
|
|
|
|
extern int no_quit;
|
2010-05-12 01:07:04 +04:00
|
|
|
extern int no_shutdown;
|
2007-11-17 20:14:51 +03:00
|
|
|
extern int old_param;
|
2009-07-02 02:19:02 +04:00
|
|
|
extern int boot_menu;
|
2014-10-07 12:00:05 +04:00
|
|
|
extern bool boot_strict;
|
2011-07-27 14:04:55 +04:00
|
|
|
extern uint8_t *boot_splash_filedata;
|
2013-01-23 21:25:08 +04:00
|
|
|
extern size_t boot_splash_filedata_size;
|
2015-11-05 21:11:22 +03:00
|
|
|
extern bool enable_mlock;
|
2011-07-27 14:04:55 +04:00
|
|
|
extern uint8_t qemu_extra_params_fw[2];
|
2013-08-21 19:03:04 +04:00
|
|
|
extern QEMUClockType rtc_clock;
|
2014-05-14 13:43:18 +04:00
|
|
|
extern const char *mem_path;
|
|
|
|
extern int mem_prealloc;
|
2007-11-17 20:14:51 +03:00
|
|
|
|
2014-05-14 13:43:09 +04:00
|
|
|
#define MAX_NODES 128
|
2015-06-02 14:23:09 +03:00
|
|
|
#define NUMA_NODE_UNASSIGNED MAX_NODES
|
2014-03-18 23:29:23 +04:00
|
|
|
|
2007-11-17 20:14:51 +03:00
|
|
|
#define MAX_OPTION_ROMS 16
|
2010-12-08 14:35:07 +03:00
|
|
|
typedef struct QEMUOptionRom {
|
|
|
|
const char *name;
|
|
|
|
int32_t bootindex;
|
|
|
|
} QEMUOptionRom;
|
|
|
|
extern QEMUOptionRom option_rom[MAX_OPTION_ROMS];
|
2007-11-17 20:14:51 +03:00
|
|
|
extern int nb_option_roms;
|
|
|
|
|
|
|
|
#define MAX_PROM_ENVS 128
|
|
|
|
extern const char *prom_envs[MAX_PROM_ENVS];
|
|
|
|
extern unsigned int nb_prom_envs;
|
|
|
|
|
2010-08-24 01:43:10 +04:00
|
|
|
/* generic hotplug */
|
hmp: Name HMP command handler functions hmp_COMMAND()
Some are called do_COMMAND() (old ones, usually), some hmp_COMMAND(),
and sometimes COMMAND pointlessly differs in spelling.
Normalize to hmp_COMMAND(), where COMMAND is exactly the command name
with '-' replaced by '_'.
Exceptions:
* do_device_add() and client_migrate_info() *not* renamed to
hmp_device_add(), hmp_client_migrate_info(), because they're also
QMP handlers. They still need to be converted to QAPI.
* do_memory_dump(), do_physical_memory_dump(), do_ioport_read(),
do_ioport_write() renamed do hmp_* instead of hmp_x(), hmp_xp(),
hmp_i(), hmp_o(), because those names are too cryptic for my taste.
* do_info_help() renamed to hmp_info_help() instead of hmp_info(),
because it only covers help.
Signed-off-by: Markus Armbruster <armbru@redhat.com>
2015-02-06 15:55:43 +03:00
|
|
|
void hmp_drive_add(Monitor *mon, const QDict *qdict);
|
2010-08-24 01:43:10 +04:00
|
|
|
|
2010-12-24 06:14:14 +03:00
|
|
|
/* pcie aer error injection */
|
2015-03-05 19:48:49 +03:00
|
|
|
void hmp_pcie_aer_inject_error(Monitor *mon, const QDict *qdict);
|
2010-12-24 06:14:14 +03:00
|
|
|
|
2007-11-17 20:14:51 +03:00
|
|
|
/* serial ports */
|
|
|
|
|
|
|
|
#define MAX_SERIAL_PORTS 4
|
|
|
|
|
2016-12-07 16:20:22 +03:00
|
|
|
extern Chardev *serial_hds[MAX_SERIAL_PORTS];
|
2007-11-17 20:14:51 +03:00
|
|
|
|
|
|
|
/* parallel ports */
|
|
|
|
|
|
|
|
#define MAX_PARALLEL_PORTS 3
|
|
|
|
|
2016-12-07 16:20:22 +03:00
|
|
|
extern Chardev *parallel_hds[MAX_PARALLEL_PORTS];
|
2007-11-17 20:14:51 +03:00
|
|
|
|
hmp: Name HMP command handler functions hmp_COMMAND()
Some are called do_COMMAND() (old ones, usually), some hmp_COMMAND(),
and sometimes COMMAND pointlessly differs in spelling.
Normalize to hmp_COMMAND(), where COMMAND is exactly the command name
with '-' replaced by '_'.
Exceptions:
* do_device_add() and client_migrate_info() *not* renamed to
hmp_device_add(), hmp_client_migrate_info(), because they're also
QMP handlers. They still need to be converted to QAPI.
* do_memory_dump(), do_physical_memory_dump(), do_ioport_read(),
do_ioport_write() renamed do hmp_* instead of hmp_x(), hmp_xp(),
hmp_i(), hmp_o(), because those names are too cryptic for my taste.
* do_info_help() renamed to hmp_info_help() instead of hmp_info(),
because it only covers help.
Signed-off-by: Markus Armbruster <armbru@redhat.com>
2015-02-06 15:55:43 +03:00
|
|
|
void hmp_usb_add(Monitor *mon, const QDict *qdict);
|
|
|
|
void hmp_usb_del(Monitor *mon, const QDict *qdict);
|
2015-02-06 16:18:24 +03:00
|
|
|
void hmp_info_usb(Monitor *mon, const QDict *qdict);
|
2007-11-17 20:14:51 +03:00
|
|
|
|
2010-12-08 14:35:05 +03:00
|
|
|
void add_boot_device_path(int32_t bootindex, DeviceState *dev,
|
|
|
|
const char *suffix);
|
2014-03-17 06:40:22 +04:00
|
|
|
char *get_boot_devices_list(size_t *size, bool ignore_suffixes);
|
2012-09-02 23:25:28 +04:00
|
|
|
|
2013-04-26 06:12:49 +04:00
|
|
|
DeviceState *get_boot_device(uint32_t position);
|
2014-10-07 12:00:06 +04:00
|
|
|
void check_boot_index(int32_t bootindex, Error **errp);
|
2014-10-07 12:00:07 +04:00
|
|
|
void del_boot_device_path(DeviceState *dev, const char *suffix);
|
2014-10-07 12:00:11 +04:00
|
|
|
void device_add_bootindex_property(Object *obj, int32_t *bootindex,
|
|
|
|
const char *name, const char *suffix,
|
|
|
|
DeviceState *dev, Error **errp);
|
2014-12-03 19:49:46 +03:00
|
|
|
void restore_boot_order(void *opaque);
|
2014-12-03 20:11:39 +03:00
|
|
|
void validate_bootdevices(const char *devices, Error **errp);
|
2014-12-03 19:49:46 +03:00
|
|
|
|
2015-09-04 21:37:09 +03:00
|
|
|
/* handler to set the boot_device order for a specific type of MachineClass */
|
2014-12-03 22:04:02 +03:00
|
|
|
typedef void QEMUBootSetHandler(void *opaque, const char *boot_order,
|
|
|
|
Error **errp);
|
2014-12-03 19:49:46 +03:00
|
|
|
void qemu_register_boot_set(QEMUBootSetHandler *func, void *opaque);
|
2014-12-03 21:20:58 +03:00
|
|
|
void qemu_boot_set(const char *boot_order, Error **errp);
|
2013-04-26 06:12:49 +04:00
|
|
|
|
2013-07-04 17:09:19 +04:00
|
|
|
QemuOpts *qemu_get_machine_opts(void);
|
|
|
|
|
2015-01-06 16:29:12 +03:00
|
|
|
bool defaults_enabled(void);
|
2012-09-02 23:25:28 +04:00
|
|
|
|
2013-11-09 08:15:47 +04:00
|
|
|
extern QemuOptsList qemu_legacy_drive_opts;
|
|
|
|
extern QemuOptsList qemu_common_drive_opts;
|
2012-11-26 19:03:42 +04:00
|
|
|
extern QemuOptsList qemu_drive_opts;
|
2016-10-06 12:33:17 +03:00
|
|
|
extern QemuOptsList bdrv_runtime_opts;
|
2012-11-26 19:03:42 +04:00
|
|
|
extern QemuOptsList qemu_chardev_opts;
|
|
|
|
extern QemuOptsList qemu_device_opts;
|
|
|
|
extern QemuOptsList qemu_netdev_opts;
|
|
|
|
extern QemuOptsList qemu_net_opts;
|
|
|
|
extern QemuOptsList qemu_global_opts;
|
|
|
|
extern QemuOptsList qemu_mon_opts;
|
|
|
|
|
2007-11-17 20:14:51 +03:00
|
|
|
#endif
|