]> git.proxmox.com Git - mirror_qemu.git/blame - include/sysemu/sysemu.h
hmp: Name HMP info handler functions hmp_info_SUBCOMMAND()
[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/typedefs.h"
6#include "qemu/option.h"
7#include "qemu/queue.h"
8#include "qemu/timer.h"
1fa9a5e4 9#include "qapi-types.h"
1de7afc9
PB
10#include "qemu/notify.h"
11#include "qemu/main-loop.h"
8c85901e 12#include "qemu/bitmap.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;
8fcb1b90 20extern uint8_t qemu_uuid[];
fc3b3295 21extern bool qemu_uuid_set;
c4be29ff 22int qemu_uuid_parse(const char *str, uint8_t *uuid);
5accc840 23
8fcb1b90 24#define UUID_FMT "%02hhx%02hhx%02hhx%02hhx-%02hhx%02hhx-%02hhx%02hhx-%02hhx%02hhx-%02hhx%02hhx%02hhx%02hhx%02hhx%02hhx"
5accc840 25#define UUID_NONE "00000000-0000-0000-0000-000000000000"
87ecb68b 26
f5bbfba1
LC
27bool runstate_check(RunState state);
28void runstate_set(RunState new_state);
1354869c 29int runstate_is_running(void);
ede085b3 30bool runstate_needs_reset(void);
87ecb68b 31typedef struct vm_change_state_entry VMChangeStateEntry;
1dfb4dd9 32typedef void VMChangeStateHandler(void *opaque, int running, RunState state);
87ecb68b
PB
33
34VMChangeStateEntry *qemu_add_vm_change_state_handler(VMChangeStateHandler *cb,
35 void *opaque);
36void qemu_del_vm_change_state_handler(VMChangeStateEntry *e);
1dfb4dd9 37void vm_state_notify(int running, RunState state);
e07bbac5 38
e063eb1f
JK
39#define VMRESET_SILENT false
40#define VMRESET_REPORT true
41
87ecb68b 42void vm_start(void);
56983463
KW
43int vm_stop(RunState state);
44int vm_stop_force_state(RunState state);
87ecb68b 45
95b363b5 46typedef enum WakeupReason {
4bc78a87
LJ
47 /* Always keep QEMU_WAKEUP_REASON_NONE = 0 */
48 QEMU_WAKEUP_REASON_NONE = 0,
62aeb0f7 49 QEMU_WAKEUP_REASON_RTC,
6595abc0 50 QEMU_WAKEUP_REASON_PMTIMER,
4bc78a87 51 QEMU_WAKEUP_REASON_OTHER,
95b363b5
GH
52} WakeupReason;
53
87ecb68b 54void qemu_system_reset_request(void);
95b363b5
GH
55void qemu_system_suspend_request(void);
56void qemu_register_suspend_notifier(Notifier *notifier);
57void qemu_system_wakeup_request(WakeupReason reason);
58void qemu_system_wakeup_enable(WakeupReason reason, bool enabled);
59void qemu_register_wakeup_notifier(Notifier *notifier);
87ecb68b
PB
60void qemu_system_shutdown_request(void);
61void qemu_system_powerdown_request(void);
a9552c8e 62void qemu_register_powerdown_notifier(Notifier *notifier);
8cf71710 63void qemu_system_debug_request(void);
1dfb4dd9 64void qemu_system_vmstop_request(RunState reason);
74892d24 65void qemu_system_vmstop_request_prepare(void);
1291eb35
AP
66int qemu_shutdown_requested_get(void);
67int qemu_reset_requested_get(void);
f64622c4 68void qemu_system_killed(int signal, pid_t pid);
be522029 69void qemu_devices_reset(void);
e063eb1f 70void qemu_system_reset(bool report);
87ecb68b 71
fd42deeb
GH
72void qemu_add_exit_notifier(Notifier *notify);
73void qemu_remove_exit_notifier(Notifier *notify);
74
4cab946a
GN
75void qemu_add_machine_init_done_notifier(Notifier *notify);
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
e1c37d0e 84bool qemu_savevm_state_blocked(Error **errp);
47c8c17a
PB
85void qemu_savevm_state_begin(QEMUFile *f,
86 const MigrationParams *params);
539de124 87int qemu_savevm_state_iterate(QEMUFile *f);
47c8c17a 88void qemu_savevm_state_complete(QEMUFile *f);
6522773f 89void qemu_savevm_state_cancel(void);
e4ed1541 90uint64_t qemu_savevm_state_pending(QEMUFile *f, uint64_t max_size);
9366f418
AL
91int qemu_loadvm_state(QEMUFile *f);
92
993fbfdb
AL
93typedef enum DisplayType
94{
95 DT_DEFAULT,
96 DT_CURSES,
97 DT_SDL,
a4ccabcf 98 DT_GTK,
993fbfdb 99 DT_NOGRAPHIC,
4171d32e 100 DT_NONE,
993fbfdb
AL
101} DisplayType;
102
d399f677 103extern int autostart;
86176759
ZA
104
105typedef enum {
a19cbfb3 106 VGA_NONE, VGA_STD, VGA_CIRRUS, VGA_VMWARE, VGA_XENFB, VGA_QXL,
d44229c5 107 VGA_TCX, VGA_CG3, VGA_DEVICE
86176759
ZA
108} VGAInterfaceType;
109
110extern int vga_interface_type;
86176759 111#define xenfb_enabled (vga_interface_type == VGA_XENFB)
86176759 112
87ecb68b
PB
113extern int graphic_width;
114extern int graphic_height;
115extern int graphic_depth;
993fbfdb 116extern DisplayType display_type;
87ecb68b
PB
117extern const char *keyboard_layout;
118extern int win2k_install_hack;
119extern int alt_grab;
0ca9f8a4 120extern int ctrl_grab;
87ecb68b 121extern int smp_cpus;
6be68d7e 122extern int max_cpus;
87ecb68b
PB
123extern int cursor_hide;
124extern int graphic_rotate;
125extern int no_quit;
a691d41a 126extern int no_shutdown;
87ecb68b 127extern int semihosting_enabled;
87ecb68b 128extern int old_param;
95387491 129extern int boot_menu;
bc74112f 130extern bool boot_strict;
3d3b8303 131extern uint8_t *boot_splash_filedata;
d09acb9b 132extern size_t boot_splash_filedata_size;
3d3b8303 133extern uint8_t qemu_extra_params_fw[2];
884f17c2 134extern QEMUClockType rtc_clock;
e1c57ab8
PB
135extern const char *mem_path;
136extern int mem_prealloc;
87ecb68b 137
45e30bf3 138#define MAX_NODES 128
d2995916
EH
139
140/* The following shall be true for all CPUs:
141 * cpu->cpu_index < max_cpus <= MAX_CPUMASK_BITS
142 *
143 * Note that cpu->get_arch_id() may be larger than MAX_CPUMASK_BITS.
144 */
ee785fed 145#define MAX_CPUMASK_BITS 255
d2995916 146
1af878e0
EH
147extern int nb_numa_nodes; /* Number of NUMA nodes */
148extern int max_numa_nodeid; /* Highest specified NUMA node ID, plus one.
149 * For all nodes, nodeid < max_numa_nodeid
150 */
151
8c85901e
WG
152typedef struct node_info {
153 uint64_t node_mem;
154 DECLARE_BITMAP(node_cpu, MAX_CPUMASK_BITS);
7febe36f 155 struct HostMemoryBackend *node_memdev;
1af878e0 156 bool present;
8c85901e
WG
157} NodeInfo;
158extern NodeInfo numa_info[MAX_NODES];
96d0e26c
WG
159void set_numa_nodes(void);
160void set_numa_modes(void);
5b009e40 161void query_numa_node_mem(uint64_t node_mem[]);
0042109a
WG
162extern QemuOptsList qemu_numa_opts;
163int numa_init_func(QemuOpts *opts, void *opaque);
268a362c 164
87ecb68b 165#define MAX_OPTION_ROMS 16
2e55e842
GN
166typedef struct QEMUOptionRom {
167 const char *name;
168 int32_t bootindex;
169} QEMUOptionRom;
170extern QEMUOptionRom option_rom[MAX_OPTION_ROMS];
87ecb68b
PB
171extern int nb_option_roms;
172
87ecb68b
PB
173#define MAX_PROM_ENVS 128
174extern const char *prom_envs[MAX_PROM_ENVS];
175extern unsigned int nb_prom_envs;
87ecb68b 176
6f338c34 177/* pci-hotplug */
3e5a50d6 178void hmp_pci_add(Monitor *mon, const QDict *qdict);
4dbd84e2 179int pci_drive_hot_add(Monitor *mon, const QDict *qdict, DriveInfo *dinfo);
3e5a50d6 180void hmp_pci_del(Monitor *mon, const QDict *qdict);
6f338c34 181
dd97aa8a 182/* generic hotplug */
3e5a50d6 183void hmp_drive_add(Monitor *mon, const QDict *qdict);
dd97aa8a 184
2ae63bda
IY
185/* pcie aer error injection */
186void pcie_aer_inject_error_print(Monitor *mon, const QObject *data);
3e5a50d6 187int hmp_pcie_aer_inject_error(Monitor *mon,
2ae63bda
IY
188 const QDict *qdict, QObject **ret_data);
189
87ecb68b
PB
190/* serial ports */
191
192#define MAX_SERIAL_PORTS 4
193
194extern CharDriverState *serial_hds[MAX_SERIAL_PORTS];
195
196/* parallel ports */
197
198#define MAX_PARALLEL_PORTS 3
199
200extern CharDriverState *parallel_hds[MAX_PARALLEL_PORTS];
201
3e5a50d6
MA
202void hmp_usb_add(Monitor *mon, const QDict *qdict);
203void hmp_usb_del(Monitor *mon, const QDict *qdict);
1ce6be24 204void hmp_info_usb(Monitor *mon, const QDict *qdict);
87ecb68b 205
1ca4d09a
GN
206void add_boot_device_path(int32_t bootindex, DeviceState *dev,
207 const char *suffix);
30e32af7 208char *get_boot_devices_list(size_t *size, bool ignore_suffixes);
094b287f 209
7dc5af55 210DeviceState *get_boot_device(uint32_t position);
694fb857 211void check_boot_index(int32_t bootindex, Error **errp);
9d27572d 212void del_boot_device_path(DeviceState *dev, const char *suffix);
12da3097
GA
213void device_add_bootindex_property(Object *obj, int32_t *bootindex,
214 const char *name, const char *suffix,
215 DeviceState *dev, Error **errp);
9816833d 216void restore_boot_order(void *opaque);
703008e8 217void validate_bootdevices(const char *devices, Error **errp);
9816833d
GA
218
219/* handler to set the boot_device order for a specific type of QEMUMachine */
ddcd5531
GA
220typedef void QEMUBootSetHandler(void *opaque, const char *boot_order,
221 Error **errp);
9816833d 222void qemu_register_boot_set(QEMUBootSetHandler *func, void *opaque);
f1839938 223void qemu_boot_set(const char *boot_order, Error **errp);
7dc5af55 224
7f9d6e54
MA
225QemuOpts *qemu_get_machine_opts(void);
226
f8b6f8ed 227bool defaults_enabled(void);
de77a243 228bool usb_enabled(void);
094b287f 229
968854c8
AK
230extern QemuOptsList qemu_legacy_drive_opts;
231extern QemuOptsList qemu_common_drive_opts;
4d454574
PB
232extern QemuOptsList qemu_drive_opts;
233extern QemuOptsList qemu_chardev_opts;
234extern QemuOptsList qemu_device_opts;
235extern QemuOptsList qemu_netdev_opts;
236extern QemuOptsList qemu_net_opts;
237extern QemuOptsList qemu_global_opts;
238extern QemuOptsList qemu_mon_opts;
239
87ecb68b 240#endif