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