]> git.proxmox.com Git - mirror_qemu.git/blame - include/sysemu/sysemu.h
vl: Switch qemu_uuid to QemuUUID
[mirror_qemu.git] / include / sysemu / sysemu.h
CommitLineData
87ecb68b
PB
1#ifndef SYSEMU_H
2#define SYSEMU_H
3/* Misc. things related to the system emulator. */
4
1de7afc9
PB
5#include "qemu/option.h"
6#include "qemu/queue.h"
7#include "qemu/timer.h"
1fa9a5e4 8#include "qapi-types.h"
1de7afc9
PB
9#include "qemu/notify.h"
10#include "qemu/main-loop.h"
8c85901e 11#include "qemu/bitmap.h"
9c5ce8db 12#include "qemu/uuid.h"
dfabb8b9 13#include "qom/object.h"
376253ec 14
87ecb68b 15/* vl.c */
1dfb4dd9 16
87ecb68b 17extern const char *bios_name;
5cea8590 18
87ecb68b 19extern const char *qemu_name;
9c5ce8db 20extern QemuUUID qemu_uuid;
fc3b3295 21extern bool qemu_uuid_set;
87ecb68b 22
f5bbfba1
LC
23bool runstate_check(RunState state);
24void runstate_set(RunState new_state);
1354869c 25int runstate_is_running(void);
ede085b3 26bool runstate_needs_reset(void);
5e0f1940 27bool runstate_store(char *str, size_t size);
87ecb68b 28typedef struct vm_change_state_entry VMChangeStateEntry;
1dfb4dd9 29typedef void VMChangeStateHandler(void *opaque, int running, RunState state);
87ecb68b
PB
30
31VMChangeStateEntry *qemu_add_vm_change_state_handler(VMChangeStateHandler *cb,
32 void *opaque);
33void qemu_del_vm_change_state_handler(VMChangeStateEntry *e);
1dfb4dd9 34void vm_state_notify(int running, RunState state);
e07bbac5 35
e063eb1f
JK
36#define VMRESET_SILENT false
37#define VMRESET_REPORT true
38
87ecb68b 39void vm_start(void);
56983463
KW
40int vm_stop(RunState state);
41int vm_stop_force_state(RunState state);
87ecb68b 42
95b363b5 43typedef enum WakeupReason {
4bc78a87
LJ
44 /* Always keep QEMU_WAKEUP_REASON_NONE = 0 */
45 QEMU_WAKEUP_REASON_NONE = 0,
62aeb0f7 46 QEMU_WAKEUP_REASON_RTC,
6595abc0 47 QEMU_WAKEUP_REASON_PMTIMER,
4bc78a87 48 QEMU_WAKEUP_REASON_OTHER,
95b363b5
GH
49} WakeupReason;
50
87ecb68b 51void qemu_system_reset_request(void);
95b363b5
GH
52void qemu_system_suspend_request(void);
53void qemu_register_suspend_notifier(Notifier *notifier);
54void qemu_system_wakeup_request(WakeupReason reason);
55void qemu_system_wakeup_enable(WakeupReason reason, bool enabled);
56void qemu_register_wakeup_notifier(Notifier *notifier);
87ecb68b
PB
57void qemu_system_shutdown_request(void);
58void qemu_system_powerdown_request(void);
a9552c8e 59void qemu_register_powerdown_notifier(Notifier *notifier);
8cf71710 60void qemu_system_debug_request(void);
1dfb4dd9 61void qemu_system_vmstop_request(RunState reason);
74892d24 62void qemu_system_vmstop_request_prepare(void);
1291eb35
AP
63int qemu_shutdown_requested_get(void);
64int qemu_reset_requested_get(void);
f64622c4 65void qemu_system_killed(int signal, pid_t pid);
be522029 66void qemu_devices_reset(void);
e063eb1f 67void qemu_system_reset(bool report);
5f5b5942 68void qemu_system_guest_panicked(void);
038629a6 69size_t qemu_target_page_bits(void);
87ecb68b 70
fd42deeb
GH
71void qemu_add_exit_notifier(Notifier *notify);
72void qemu_remove_exit_notifier(Notifier *notify);
73
4cab946a 74void qemu_add_machine_init_done_notifier(Notifier *notify);
b86eacb8 75void qemu_remove_machine_init_done_notifier(Notifier *notify);
4cab946a 76
3e5a50d6 77void hmp_savevm(Monitor *mon, const QDict *qdict);
03cd4655 78int load_vmstate(const char *name);
3e5a50d6 79void hmp_delvm(Monitor *mon, const QDict *qdict);
1ce6be24 80void hmp_info_snapshots(Monitor *mon, const QDict *qdict);
87ecb68b 81
210f41ba
AL
82void qemu_announce_self(void);
83
c76ca188
DDAG
84/* Subcommands for QEMU_VM_COMMAND */
85enum qemu_vm_cmd {
86 MIG_CMD_INVALID = 0, /* Must be 0 */
2e37701e
DDAG
87 MIG_CMD_OPEN_RETURN_PATH, /* Tell the dest to open the Return path */
88 MIG_CMD_PING, /* Request a PONG on the RP */
093e3c42
DDAG
89
90 MIG_CMD_POSTCOPY_ADVISE, /* Prior to any page transfers, just
91 warn we might want to do PC */
92 MIG_CMD_POSTCOPY_LISTEN, /* Start listening for incoming
93 pages as it's running. */
94 MIG_CMD_POSTCOPY_RUN, /* Start execution */
95
96 MIG_CMD_POSTCOPY_RAM_DISCARD, /* A list of pages to discard that
97 were previously sent during
98 precopy but are dirty. */
11cf1d98 99 MIG_CMD_PACKAGED, /* Send a wrapped stream within this stream */
c76ca188
DDAG
100 MIG_CMD_MAX
101};
102
11cf1d98
DDAG
103#define MAX_VM_CMD_PACKAGED_SIZE (1ul << 24)
104
e1c37d0e 105bool qemu_savevm_state_blocked(Error **errp);
47c8c17a
PB
106void qemu_savevm_state_begin(QEMUFile *f,
107 const MigrationParams *params);
f796baa1 108void qemu_savevm_state_header(QEMUFile *f);
35ecd943 109int qemu_savevm_state_iterate(QEMUFile *f, bool postcopy);
ea7415fa 110void qemu_savevm_state_cleanup(void);
763c906b 111void qemu_savevm_state_complete_postcopy(QEMUFile *f);
1c0d249d 112void qemu_savevm_state_complete_precopy(QEMUFile *f, bool iterable_only);
c31b098f
DDAG
113void qemu_savevm_state_pending(QEMUFile *f, uint64_t max_size,
114 uint64_t *res_non_postcopiable,
115 uint64_t *res_postcopiable);
c76ca188
DDAG
116void qemu_savevm_command_send(QEMUFile *f, enum qemu_vm_cmd command,
117 uint16_t len, uint8_t *data);
2e37701e
DDAG
118void qemu_savevm_send_ping(QEMUFile *f, uint32_t value);
119void qemu_savevm_send_open_return_path(QEMUFile *f);
61b67d47 120int qemu_savevm_send_packaged(QEMUFile *f, const uint8_t *buf, size_t len);
093e3c42
DDAG
121void qemu_savevm_send_postcopy_advise(QEMUFile *f);
122void qemu_savevm_send_postcopy_listen(QEMUFile *f);
123void qemu_savevm_send_postcopy_run(QEMUFile *f);
124
125void qemu_savevm_send_postcopy_ram_discard(QEMUFile *f, const char *name,
126 uint16_t len,
127 uint64_t *start_list,
128 uint64_t *length_list);
129
9366f418
AL
130int qemu_loadvm_state(QEMUFile *f);
131
d399f677 132extern int autostart;
86176759
ZA
133
134typedef enum {
a19cbfb3 135 VGA_NONE, VGA_STD, VGA_CIRRUS, VGA_VMWARE, VGA_XENFB, VGA_QXL,
a94f0c5c 136 VGA_TCX, VGA_CG3, VGA_DEVICE, VGA_VIRTIO,
8c9a2b71 137 VGA_TYPE_MAX,
86176759
ZA
138} VGAInterfaceType;
139
140extern int vga_interface_type;
86176759 141#define xenfb_enabled (vga_interface_type == VGA_XENFB)
86176759 142
87ecb68b
PB
143extern int graphic_width;
144extern int graphic_height;
145extern int graphic_depth;
da076ffe 146extern int display_opengl;
87ecb68b
PB
147extern const char *keyboard_layout;
148extern int win2k_install_hack;
149extern int alt_grab;
0ca9f8a4 150extern int ctrl_grab;
87ecb68b 151extern int smp_cpus;
6be68d7e 152extern int max_cpus;
87ecb68b
PB
153extern int cursor_hide;
154extern int graphic_rotate;
155extern int no_quit;
a691d41a 156extern int no_shutdown;
87ecb68b 157extern int old_param;
95387491 158extern int boot_menu;
bc74112f 159extern bool boot_strict;
3d3b8303 160extern uint8_t *boot_splash_filedata;
d09acb9b 161extern size_t boot_splash_filedata_size;
58b7c17e 162extern bool enable_mlock;
3d3b8303 163extern uint8_t qemu_extra_params_fw[2];
884f17c2 164extern QEMUClockType rtc_clock;
e1c57ab8
PB
165extern const char *mem_path;
166extern int mem_prealloc;
87ecb68b 167
45e30bf3 168#define MAX_NODES 128
6a3042b2 169#define NUMA_NODE_UNASSIGNED MAX_NODES
d2995916
EH
170
171/* The following shall be true for all CPUs:
172 * cpu->cpu_index < max_cpus <= MAX_CPUMASK_BITS
173 *
174 * Note that cpu->get_arch_id() may be larger than MAX_CPUMASK_BITS.
175 */
ee785fed 176#define MAX_CPUMASK_BITS 255
d2995916 177
87ecb68b 178#define MAX_OPTION_ROMS 16
2e55e842
GN
179typedef struct QEMUOptionRom {
180 const char *name;
181 int32_t bootindex;
182} QEMUOptionRom;
183extern QEMUOptionRom option_rom[MAX_OPTION_ROMS];
87ecb68b
PB
184extern int nb_option_roms;
185
87ecb68b
PB
186#define MAX_PROM_ENVS 128
187extern const char *prom_envs[MAX_PROM_ENVS];
188extern unsigned int nb_prom_envs;
87ecb68b 189
dd97aa8a 190/* generic hotplug */
3e5a50d6 191void hmp_drive_add(Monitor *mon, const QDict *qdict);
dd97aa8a 192
2ae63bda 193/* pcie aer error injection */
04e00c92 194void hmp_pcie_aer_inject_error(Monitor *mon, const QDict *qdict);
2ae63bda 195
87ecb68b
PB
196/* serial ports */
197
198#define MAX_SERIAL_PORTS 4
199
200extern CharDriverState *serial_hds[MAX_SERIAL_PORTS];
201
202/* parallel ports */
203
204#define MAX_PARALLEL_PORTS 3
205
206extern CharDriverState *parallel_hds[MAX_PARALLEL_PORTS];
207
3e5a50d6
MA
208void hmp_usb_add(Monitor *mon, const QDict *qdict);
209void hmp_usb_del(Monitor *mon, const QDict *qdict);
1ce6be24 210void hmp_info_usb(Monitor *mon, const QDict *qdict);
87ecb68b 211
1ca4d09a
GN
212void add_boot_device_path(int32_t bootindex, DeviceState *dev,
213 const char *suffix);
30e32af7 214char *get_boot_devices_list(size_t *size, bool ignore_suffixes);
094b287f 215
7dc5af55 216DeviceState *get_boot_device(uint32_t position);
694fb857 217void check_boot_index(int32_t bootindex, Error **errp);
9d27572d 218void del_boot_device_path(DeviceState *dev, const char *suffix);
12da3097
GA
219void device_add_bootindex_property(Object *obj, int32_t *bootindex,
220 const char *name, const char *suffix,
221 DeviceState *dev, Error **errp);
9816833d 222void restore_boot_order(void *opaque);
703008e8 223void validate_bootdevices(const char *devices, Error **errp);
9816833d 224
3b53e45f 225/* handler to set the boot_device order for a specific type of MachineClass */
ddcd5531
GA
226typedef void QEMUBootSetHandler(void *opaque, const char *boot_order,
227 Error **errp);
9816833d 228void qemu_register_boot_set(QEMUBootSetHandler *func, void *opaque);
f1839938 229void qemu_boot_set(const char *boot_order, Error **errp);
7dc5af55 230
7f9d6e54
MA
231QemuOpts *qemu_get_machine_opts(void);
232
f8b6f8ed 233bool defaults_enabled(void);
094b287f 234
968854c8
AK
235extern QemuOptsList qemu_legacy_drive_opts;
236extern QemuOptsList qemu_common_drive_opts;
4d454574
PB
237extern QemuOptsList qemu_drive_opts;
238extern QemuOptsList qemu_chardev_opts;
239extern QemuOptsList qemu_device_opts;
240extern QemuOptsList qemu_netdev_opts;
241extern QemuOptsList qemu_net_opts;
242extern QemuOptsList qemu_global_opts;
243extern QemuOptsList qemu_mon_opts;
244
87ecb68b 245#endif