]> git.proxmox.com Git - qemu.git/blame - sysemu.h
KVM: Rework VCPU state writeback API
[qemu.git] / sysemu.h
CommitLineData
87ecb68b
PB
1#ifndef SYSEMU_H
2#define SYSEMU_H
3/* Misc. things related to the system emulator. */
4
376253ec 5#include "qemu-common.h"
62c5802e 6#include "qemu-option.h"
72cf2d4f 7#include "qemu-queue.h"
6875204c 8#include "qemu-timer.h"
d54908a5 9#include "qdict.h"
8204a918 10#include "qerror.h"
376253ec 11
49dc768d
AL
12#ifdef _WIN32
13#include <windows.h>
14#endif
15
87ecb68b
PB
16/* vl.c */
17extern const char *bios_name;
5cea8590
PB
18
19#define QEMU_FILE_TYPE_BIOS 0
20#define QEMU_FILE_TYPE_KEYMAP 1
21char *qemu_find_file(int type, const char *name);
87ecb68b
PB
22
23extern int vm_running;
24extern const char *qemu_name;
8fcb1b90 25extern uint8_t qemu_uuid[];
c4be29ff 26int qemu_uuid_parse(const char *str, uint8_t *uuid);
8fcb1b90 27#define UUID_FMT "%02hhx%02hhx%02hhx%02hhx-%02hhx%02hhx-%02hhx%02hhx-%02hhx%02hhx-%02hhx%02hhx%02hhx%02hhx%02hhx%02hhx"
87ecb68b
PB
28
29typedef struct vm_change_state_entry VMChangeStateEntry;
9781e040 30typedef void VMChangeStateHandler(void *opaque, int running, int reason);
87ecb68b
PB
31
32VMChangeStateEntry *qemu_add_vm_change_state_handler(VMChangeStateHandler *cb,
33 void *opaque);
34void qemu_del_vm_change_state_handler(VMChangeStateEntry *e);
35
87ecb68b
PB
36void vm_start(void);
37void vm_stop(int reason);
38
9f9e28cd
GC
39uint64_t ram_bytes_remaining(void);
40uint64_t ram_bytes_transferred(void);
41uint64_t ram_bytes_total(void);
42
87ecb68b
PB
43int64_t cpu_get_ticks(void);
44void cpu_enable_ticks(void);
45void cpu_disable_ticks(void);
46
47void qemu_system_reset_request(void);
48void qemu_system_shutdown_request(void);
49void qemu_system_powerdown_request(void);
cf7a2fe2
AJ
50int qemu_shutdown_requested(void);
51int qemu_reset_requested(void);
52int qemu_powerdown_requested(void);
d9c32310 53extern qemu_irq qemu_system_powerdown;
cf7a2fe2 54void qemu_system_reset(void);
87ecb68b 55
d54908a5 56void do_savevm(Monitor *mon, const QDict *qdict);
05f2401e 57int load_vmstate(Monitor *mon, const char *name);
d54908a5 58void do_delvm(Monitor *mon, const QDict *qdict);
376253ec 59void do_info_snapshots(Monitor *mon);
87ecb68b 60
ea375f9a
JK
61void cpu_synchronize_all_states(void);
62void cpu_synchronize_all_post_reset(void);
63void cpu_synchronize_all_post_init(void);
64
210f41ba
AL
65void qemu_announce_self(void);
66
87ecb68b
PB
67void main_loop_wait(int timeout);
68
f327aa0c
JK
69int qemu_savevm_state_begin(Monitor *mon, QEMUFile *f, int blk_enable,
70 int shared);
71int qemu_savevm_state_iterate(Monitor *mon, QEMUFile *f);
72int qemu_savevm_state_complete(Monitor *mon, QEMUFile *f);
73void qemu_savevm_state_cancel(Monitor *mon, QEMUFile *f);
9366f418
AL
74int qemu_loadvm_state(QEMUFile *f);
75
ac7531ec
GH
76void qemu_errors_to_file(FILE *fp);
77void qemu_errors_to_mon(Monitor *mon);
78void qemu_errors_to_previous(void);
79void qemu_error(const char *fmt, ...) __attribute__ ((format(printf, 1, 2)));
8204a918
LC
80void qemu_error_internal(const char *file, int linenr, const char *func,
81 const char *fmt, ...)
82 __attribute__ ((format(printf, 4, 5)));
83
84#define qemu_error_new(fmt, ...) \
85 qemu_error_internal(__FILE__, __LINE__, __func__, fmt, ## __VA_ARGS__)
ac7531ec 86
56f3a5d0 87#ifdef _WIN32
87ecb68b
PB
88/* Polling handling */
89
90/* return TRUE if no sleep should be done afterwards */
91typedef int PollingFunc(void *opaque);
92
93int qemu_add_polling_cb(PollingFunc *func, void *opaque);
94void qemu_del_polling_cb(PollingFunc *func, void *opaque);
95
87ecb68b
PB
96/* Wait objects handling */
97typedef void WaitObjectFunc(void *opaque);
98
99int qemu_add_wait_object(HANDLE handle, WaitObjectFunc *func, void *opaque);
100void qemu_del_wait_object(HANDLE handle, WaitObjectFunc *func, void *opaque);
101#endif
102
87ecb68b 103/* SLIRP */
376253ec 104void do_info_slirp(Monitor *mon);
87ecb68b 105
993fbfdb
AL
106typedef enum DisplayType
107{
108 DT_DEFAULT,
109 DT_CURSES,
110 DT_SDL,
111 DT_VNC,
112 DT_NOGRAPHIC,
113} DisplayType;
114
d399f677 115extern int autostart;
87ecb68b 116extern int bios_size;
86176759
ZA
117
118typedef enum {
119 VGA_NONE, VGA_STD, VGA_CIRRUS, VGA_VMWARE, VGA_XENFB
120} VGAInterfaceType;
121
122extern int vga_interface_type;
123#define cirrus_vga_enabled (vga_interface_type == VGA_CIRRUS)
124#define std_vga_enabled (vga_interface_type == VGA_STD)
125#define xenfb_enabled (vga_interface_type == VGA_XENFB)
126#define vmsvga_enabled (vga_interface_type == VGA_VMWARE)
127
87ecb68b
PB
128extern int graphic_width;
129extern int graphic_height;
130extern int graphic_depth;
6b35e7bf 131extern uint8_t irq0override;
993fbfdb 132extern DisplayType display_type;
87ecb68b
PB
133extern const char *keyboard_layout;
134extern int win2k_install_hack;
73822ec8 135extern int rtc_td_hack;
87ecb68b 136extern int alt_grab;
0ca9f8a4 137extern int ctrl_grab;
87ecb68b
PB
138extern int usb_enabled;
139extern int smp_cpus;
6be68d7e 140extern int max_cpus;
87ecb68b
PB
141extern int cursor_hide;
142extern int graphic_rotate;
143extern int no_quit;
144extern int semihosting_enabled;
87ecb68b 145extern int old_param;
95387491 146extern int boot_menu;
6875204c 147extern QEMUClock *rtc_clock;
87ecb68b 148
268a362c
AL
149#define MAX_NODES 64
150extern int nb_numa_nodes;
151extern uint64_t node_mem[MAX_NODES];
075cd324 152extern uint64_t node_cpumask[MAX_NODES];
268a362c 153
87ecb68b
PB
154#define MAX_OPTION_ROMS 16
155extern const char *option_rom[MAX_OPTION_ROMS];
156extern int nb_option_roms;
157
1ad2134f 158#ifdef NEED_CPU_H
95efd11c 159#if defined(TARGET_SPARC) || defined(TARGET_PPC)
87ecb68b
PB
160#define MAX_PROM_ENVS 128
161extern const char *prom_envs[MAX_PROM_ENVS];
162extern unsigned int nb_prom_envs;
163#endif
1ad2134f 164#endif
87ecb68b 165
e4bcb14c 166typedef enum {
a8659e90 167 IF_NONE,
aae9460e
PB
168 IF_IDE, IF_SCSI, IF_FLOPPY, IF_PFLASH, IF_MTD, IF_SD, IF_VIRTIO, IF_XEN,
169 IF_COUNT
e4bcb14c
TS
170} BlockInterfaceType;
171
428c5705
AL
172typedef enum {
173 BLOCK_ERR_REPORT, BLOCK_ERR_IGNORE, BLOCK_ERR_STOP_ENOSPC,
174 BLOCK_ERR_STOP_ANY
175} BlockInterfaceErrorAction;
176
bf011293 177#define BLOCK_SERIAL_STRLEN 20
178
e4bcb14c
TS
179typedef struct DriveInfo {
180 BlockDriverState *bdrv;
1dae12e6 181 char *id;
c2cc47a4 182 const char *devaddr;
f60d39bc 183 BlockInterfaceType type;
e4bcb14c
TS
184 int bus;
185 int unit;
9dfd7c7a 186 QemuOpts *opts;
e9b2e818 187 BlockInterfaceErrorAction on_read_error;
f7850099 188 BlockInterfaceErrorAction on_write_error;
bf011293 189 char serial[BLOCK_SERIAL_STRLEN + 1];
72cf2d4f 190 QTAILQ_ENTRY(DriveInfo) next;
e4bcb14c
TS
191} DriveInfo;
192
193#define MAX_IDE_DEVS 2
194#define MAX_SCSI_DEVS 7
195#define MAX_DRIVES 32
196
72cf2d4f
BS
197extern QTAILQ_HEAD(drivelist, DriveInfo) drives;
198extern QTAILQ_HEAD(driveoptlist, DriveOpt) driveopts;
e4bcb14c 199
751c6a17 200extern DriveInfo *drive_get(BlockInterfaceType type, int bus, int unit);
2e810b36 201extern DriveInfo *drive_get_by_id(const char *id);
f60d39bc 202extern int drive_get_max_bus(BlockInterfaceType type);
56a14938 203extern void drive_uninit(DriveInfo *dinfo);
fa879c64 204extern const char *drive_get_serial(BlockDriverState *bdrv);
f7850099
KW
205
206extern BlockInterfaceErrorAction drive_get_on_error(
207 BlockDriverState *bdrv, int is_read);
87ecb68b 208
aae9460e
PB
209BlockDriverState *qdev_init_bdrv(DeviceState *dev, BlockInterfaceType type);
210
9dfd7c7a
GH
211extern QemuOpts *drive_add(const char *file, const char *fmt, ...);
212extern DriveInfo *drive_init(QemuOpts *arg, void *machine, int *fatal_error);
4d73cd3b 213
6f338c34
AL
214/* device-hotplug */
215
751c6a17 216DriveInfo *add_init_drive(const char *opts);
6f338c34
AL
217
218/* pci-hotplug */
7a344f7a 219void pci_device_hot_add_print(Monitor *mon, const QObject *data);
395560c8 220int pci_device_hot_add(Monitor *mon, const QDict *qdict, QObject **ret_data);
f18c16de 221void drive_hot_add(Monitor *mon, const QDict *qdict);
053801bc
LC
222int pci_device_hot_remove(Monitor *mon, const char *pci_addr);
223int do_pci_device_hot_remove(Monitor *mon, const QDict *qdict,
224 QObject **ret_data);
6f338c34 225
87ecb68b
PB
226/* serial ports */
227
228#define MAX_SERIAL_PORTS 4
229
230extern CharDriverState *serial_hds[MAX_SERIAL_PORTS];
231
232/* parallel ports */
233
234#define MAX_PARALLEL_PORTS 3
235
236extern CharDriverState *parallel_hds[MAX_PARALLEL_PORTS];
237
0e82f34d
AL
238#define TFR(expr) do { if ((expr) != -1) break; } while (errno == EINTR)
239
87ecb68b
PB
240#ifdef HAS_AUDIO
241struct soundhw {
242 const char *name;
243 const char *descr;
244 int enabled;
245 int isa;
246 union {
22d83b14
PB
247 int (*init_isa) (qemu_irq *pic);
248 int (*init_pci) (PCIBus *bus);
87ecb68b
PB
249 } init;
250};
251
252extern struct soundhw soundhw[];
253#endif
254
d54908a5
LC
255void do_usb_add(Monitor *mon, const QDict *qdict);
256void do_usb_del(Monitor *mon, const QDict *qdict);
376253ec 257void usb_info(Monitor *mon);
87ecb68b 258
aae9460e
PB
259void register_devices(void);
260
87ecb68b 261#endif