]>
Commit | Line | Data |
---|---|---|
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 | 17 | extern const char *bios_name; |
5cea8590 | 18 | |
87ecb68b | 19 | extern const char *qemu_name; |
9c5ce8db | 20 | extern QemuUUID qemu_uuid; |
fc3b3295 | 21 | extern bool qemu_uuid_set; |
87ecb68b | 22 | |
f5bbfba1 LC |
23 | bool runstate_check(RunState state); |
24 | void runstate_set(RunState new_state); | |
1354869c | 25 | int runstate_is_running(void); |
ede085b3 | 26 | bool runstate_needs_reset(void); |
5e0f1940 | 27 | bool runstate_store(char *str, size_t size); |
87ecb68b | 28 | typedef struct vm_change_state_entry VMChangeStateEntry; |
1dfb4dd9 | 29 | typedef void VMChangeStateHandler(void *opaque, int running, RunState state); |
87ecb68b PB |
30 | |
31 | VMChangeStateEntry *qemu_add_vm_change_state_handler(VMChangeStateHandler *cb, | |
32 | void *opaque); | |
33 | void qemu_del_vm_change_state_handler(VMChangeStateEntry *e); | |
1dfb4dd9 | 34 | void vm_state_notify(int running, RunState state); |
e07bbac5 | 35 | |
e063eb1f JK |
36 | #define VMRESET_SILENT false |
37 | #define VMRESET_REPORT true | |
38 | ||
87ecb68b | 39 | void vm_start(void); |
56983463 KW |
40 | int vm_stop(RunState state); |
41 | int vm_stop_force_state(RunState state); | |
87ecb68b | 42 | |
95b363b5 | 43 | typedef 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 | 51 | void qemu_system_reset_request(void); |
95b363b5 GH |
52 | void qemu_system_suspend_request(void); |
53 | void qemu_register_suspend_notifier(Notifier *notifier); | |
54 | void qemu_system_wakeup_request(WakeupReason reason); | |
55 | void qemu_system_wakeup_enable(WakeupReason reason, bool enabled); | |
56 | void qemu_register_wakeup_notifier(Notifier *notifier); | |
87ecb68b PB |
57 | void qemu_system_shutdown_request(void); |
58 | void qemu_system_powerdown_request(void); | |
a9552c8e | 59 | void qemu_register_powerdown_notifier(Notifier *notifier); |
8cf71710 | 60 | void qemu_system_debug_request(void); |
1dfb4dd9 | 61 | void qemu_system_vmstop_request(RunState reason); |
74892d24 | 62 | void qemu_system_vmstop_request_prepare(void); |
1291eb35 AP |
63 | int qemu_shutdown_requested_get(void); |
64 | int qemu_reset_requested_get(void); | |
f64622c4 | 65 | void qemu_system_killed(int signal, pid_t pid); |
be522029 | 66 | void qemu_devices_reset(void); |
e063eb1f | 67 | void qemu_system_reset(bool report); |
5f5b5942 | 68 | void qemu_system_guest_panicked(void); |
038629a6 | 69 | size_t qemu_target_page_bits(void); |
87ecb68b | 70 | |
fd42deeb GH |
71 | void qemu_add_exit_notifier(Notifier *notify); |
72 | void qemu_remove_exit_notifier(Notifier *notify); | |
73 | ||
4cab946a | 74 | void qemu_add_machine_init_done_notifier(Notifier *notify); |
b86eacb8 | 75 | void qemu_remove_machine_init_done_notifier(Notifier *notify); |
4cab946a | 76 | |
3e5a50d6 | 77 | void hmp_savevm(Monitor *mon, const QDict *qdict); |
03cd4655 | 78 | int load_vmstate(const char *name); |
3e5a50d6 | 79 | void hmp_delvm(Monitor *mon, const QDict *qdict); |
1ce6be24 | 80 | void hmp_info_snapshots(Monitor *mon, const QDict *qdict); |
87ecb68b | 81 | |
210f41ba AL |
82 | void qemu_announce_self(void); |
83 | ||
c76ca188 DDAG |
84 | /* Subcommands for QEMU_VM_COMMAND */ |
85 | enum 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 | 105 | bool qemu_savevm_state_blocked(Error **errp); |
47c8c17a PB |
106 | void qemu_savevm_state_begin(QEMUFile *f, |
107 | const MigrationParams *params); | |
f796baa1 | 108 | void qemu_savevm_state_header(QEMUFile *f); |
35ecd943 | 109 | int qemu_savevm_state_iterate(QEMUFile *f, bool postcopy); |
ea7415fa | 110 | void qemu_savevm_state_cleanup(void); |
763c906b | 111 | void qemu_savevm_state_complete_postcopy(QEMUFile *f); |
1c0d249d | 112 | void qemu_savevm_state_complete_precopy(QEMUFile *f, bool iterable_only); |
c31b098f DDAG |
113 | void qemu_savevm_state_pending(QEMUFile *f, uint64_t max_size, |
114 | uint64_t *res_non_postcopiable, | |
115 | uint64_t *res_postcopiable); | |
c76ca188 DDAG |
116 | void qemu_savevm_command_send(QEMUFile *f, enum qemu_vm_cmd command, |
117 | uint16_t len, uint8_t *data); | |
2e37701e DDAG |
118 | void qemu_savevm_send_ping(QEMUFile *f, uint32_t value); |
119 | void qemu_savevm_send_open_return_path(QEMUFile *f); | |
61b67d47 | 120 | int qemu_savevm_send_packaged(QEMUFile *f, const uint8_t *buf, size_t len); |
093e3c42 DDAG |
121 | void qemu_savevm_send_postcopy_advise(QEMUFile *f); |
122 | void qemu_savevm_send_postcopy_listen(QEMUFile *f); | |
123 | void qemu_savevm_send_postcopy_run(QEMUFile *f); | |
124 | ||
125 | void 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 |
130 | int qemu_loadvm_state(QEMUFile *f); |
131 | ||
d399f677 | 132 | extern int autostart; |
86176759 ZA |
133 | |
134 | typedef 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 | ||
140 | extern int vga_interface_type; | |
86176759 | 141 | #define xenfb_enabled (vga_interface_type == VGA_XENFB) |
86176759 | 142 | |
87ecb68b PB |
143 | extern int graphic_width; |
144 | extern int graphic_height; | |
145 | extern int graphic_depth; | |
da076ffe | 146 | extern int display_opengl; |
87ecb68b PB |
147 | extern const char *keyboard_layout; |
148 | extern int win2k_install_hack; | |
149 | extern int alt_grab; | |
0ca9f8a4 | 150 | extern int ctrl_grab; |
87ecb68b | 151 | extern int smp_cpus; |
6be68d7e | 152 | extern int max_cpus; |
87ecb68b PB |
153 | extern int cursor_hide; |
154 | extern int graphic_rotate; | |
155 | extern int no_quit; | |
a691d41a | 156 | extern int no_shutdown; |
87ecb68b | 157 | extern int old_param; |
95387491 | 158 | extern int boot_menu; |
bc74112f | 159 | extern bool boot_strict; |
3d3b8303 | 160 | extern uint8_t *boot_splash_filedata; |
d09acb9b | 161 | extern size_t boot_splash_filedata_size; |
58b7c17e | 162 | extern bool enable_mlock; |
3d3b8303 | 163 | extern uint8_t qemu_extra_params_fw[2]; |
884f17c2 | 164 | extern QEMUClockType rtc_clock; |
e1c57ab8 PB |
165 | extern const char *mem_path; |
166 | extern 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 |
179 | typedef struct QEMUOptionRom { |
180 | const char *name; | |
181 | int32_t bootindex; | |
182 | } QEMUOptionRom; | |
183 | extern QEMUOptionRom option_rom[MAX_OPTION_ROMS]; | |
87ecb68b PB |
184 | extern int nb_option_roms; |
185 | ||
87ecb68b PB |
186 | #define MAX_PROM_ENVS 128 |
187 | extern const char *prom_envs[MAX_PROM_ENVS]; | |
188 | extern unsigned int nb_prom_envs; | |
87ecb68b | 189 | |
dd97aa8a | 190 | /* generic hotplug */ |
3e5a50d6 | 191 | void hmp_drive_add(Monitor *mon, const QDict *qdict); |
dd97aa8a | 192 | |
2ae63bda | 193 | /* pcie aer error injection */ |
04e00c92 | 194 | void 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 | ||
200 | extern CharDriverState *serial_hds[MAX_SERIAL_PORTS]; | |
201 | ||
202 | /* parallel ports */ | |
203 | ||
204 | #define MAX_PARALLEL_PORTS 3 | |
205 | ||
206 | extern CharDriverState *parallel_hds[MAX_PARALLEL_PORTS]; | |
207 | ||
3e5a50d6 MA |
208 | void hmp_usb_add(Monitor *mon, const QDict *qdict); |
209 | void hmp_usb_del(Monitor *mon, const QDict *qdict); | |
1ce6be24 | 210 | void hmp_info_usb(Monitor *mon, const QDict *qdict); |
87ecb68b | 211 | |
1ca4d09a GN |
212 | void add_boot_device_path(int32_t bootindex, DeviceState *dev, |
213 | const char *suffix); | |
30e32af7 | 214 | char *get_boot_devices_list(size_t *size, bool ignore_suffixes); |
094b287f | 215 | |
7dc5af55 | 216 | DeviceState *get_boot_device(uint32_t position); |
694fb857 | 217 | void check_boot_index(int32_t bootindex, Error **errp); |
9d27572d | 218 | void del_boot_device_path(DeviceState *dev, const char *suffix); |
12da3097 GA |
219 | void device_add_bootindex_property(Object *obj, int32_t *bootindex, |
220 | const char *name, const char *suffix, | |
221 | DeviceState *dev, Error **errp); | |
9816833d | 222 | void restore_boot_order(void *opaque); |
703008e8 | 223 | void 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 |
226 | typedef void QEMUBootSetHandler(void *opaque, const char *boot_order, |
227 | Error **errp); | |
9816833d | 228 | void qemu_register_boot_set(QEMUBootSetHandler *func, void *opaque); |
f1839938 | 229 | void qemu_boot_set(const char *boot_order, Error **errp); |
7dc5af55 | 230 | |
7f9d6e54 MA |
231 | QemuOpts *qemu_get_machine_opts(void); |
232 | ||
f8b6f8ed | 233 | bool defaults_enabled(void); |
094b287f | 234 | |
968854c8 AK |
235 | extern QemuOptsList qemu_legacy_drive_opts; |
236 | extern QemuOptsList qemu_common_drive_opts; | |
4d454574 PB |
237 | extern QemuOptsList qemu_drive_opts; |
238 | extern QemuOptsList qemu_chardev_opts; | |
239 | extern QemuOptsList qemu_device_opts; | |
240 | extern QemuOptsList qemu_netdev_opts; | |
241 | extern QemuOptsList qemu_net_opts; | |
242 | extern QemuOptsList qemu_global_opts; | |
243 | extern QemuOptsList qemu_mon_opts; | |
244 | ||
87ecb68b | 245 | #endif |