]> git.proxmox.com Git - mirror_qemu.git/blame - sysemu.h
qdev: enable vmstate_unregister() support
[mirror_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
210f41ba
AL
61void qemu_announce_self(void);
62
87ecb68b
PB
63void main_loop_wait(int timeout);
64
c163b5ca 65int qemu_savevm_state_begin(QEMUFile *f, int blk_enable, int shared);
9366f418
AL
66int qemu_savevm_state_iterate(QEMUFile *f);
67int qemu_savevm_state_complete(QEMUFile *f);
68int qemu_savevm_state(QEMUFile *f);
69int qemu_loadvm_state(QEMUFile *f);
70
ac7531ec
GH
71void qemu_errors_to_file(FILE *fp);
72void qemu_errors_to_mon(Monitor *mon);
73void qemu_errors_to_previous(void);
74void qemu_error(const char *fmt, ...) __attribute__ ((format(printf, 1, 2)));
8204a918
LC
75void qemu_error_internal(const char *file, int linenr, const char *func,
76 const char *fmt, ...)
77 __attribute__ ((format(printf, 4, 5)));
78
79#define qemu_error_new(fmt, ...) \
80 qemu_error_internal(__FILE__, __LINE__, __func__, fmt, ## __VA_ARGS__)
ac7531ec 81
56f3a5d0 82#ifdef _WIN32
87ecb68b
PB
83/* Polling handling */
84
85/* return TRUE if no sleep should be done afterwards */
86typedef int PollingFunc(void *opaque);
87
88int qemu_add_polling_cb(PollingFunc *func, void *opaque);
89void qemu_del_polling_cb(PollingFunc *func, void *opaque);
90
87ecb68b
PB
91/* Wait objects handling */
92typedef void WaitObjectFunc(void *opaque);
93
94int qemu_add_wait_object(HANDLE handle, WaitObjectFunc *func, void *opaque);
95void qemu_del_wait_object(HANDLE handle, WaitObjectFunc *func, void *opaque);
96#endif
97
87ecb68b 98/* SLIRP */
376253ec 99void do_info_slirp(Monitor *mon);
87ecb68b 100
993fbfdb
AL
101typedef enum DisplayType
102{
103 DT_DEFAULT,
104 DT_CURSES,
105 DT_SDL,
106 DT_VNC,
107 DT_NOGRAPHIC,
108} DisplayType;
109
d399f677 110extern int autostart;
87ecb68b 111extern int bios_size;
86176759
ZA
112
113typedef enum {
114 VGA_NONE, VGA_STD, VGA_CIRRUS, VGA_VMWARE, VGA_XENFB
115} VGAInterfaceType;
116
117extern int vga_interface_type;
118#define cirrus_vga_enabled (vga_interface_type == VGA_CIRRUS)
119#define std_vga_enabled (vga_interface_type == VGA_STD)
120#define xenfb_enabled (vga_interface_type == VGA_XENFB)
121#define vmsvga_enabled (vga_interface_type == VGA_VMWARE)
122
87ecb68b
PB
123extern int graphic_width;
124extern int graphic_height;
125extern int graphic_depth;
6b35e7bf 126extern uint8_t irq0override;
993fbfdb 127extern DisplayType display_type;
87ecb68b
PB
128extern const char *keyboard_layout;
129extern int win2k_install_hack;
73822ec8 130extern int rtc_td_hack;
87ecb68b 131extern int alt_grab;
0ca9f8a4 132extern int ctrl_grab;
87ecb68b
PB
133extern int usb_enabled;
134extern int smp_cpus;
6be68d7e 135extern int max_cpus;
87ecb68b
PB
136extern int cursor_hide;
137extern int graphic_rotate;
138extern int no_quit;
139extern int semihosting_enabled;
87ecb68b 140extern int old_param;
95387491 141extern int boot_menu;
6875204c 142extern QEMUClock *rtc_clock;
87ecb68b 143
268a362c
AL
144#define MAX_NODES 64
145extern int nb_numa_nodes;
146extern uint64_t node_mem[MAX_NODES];
075cd324 147extern uint64_t node_cpumask[MAX_NODES];
268a362c 148
87ecb68b
PB
149#define MAX_OPTION_ROMS 16
150extern const char *option_rom[MAX_OPTION_ROMS];
151extern int nb_option_roms;
152
1ad2134f 153#ifdef NEED_CPU_H
95efd11c 154#if defined(TARGET_SPARC) || defined(TARGET_PPC)
87ecb68b
PB
155#define MAX_PROM_ENVS 128
156extern const char *prom_envs[MAX_PROM_ENVS];
157extern unsigned int nb_prom_envs;
158#endif
1ad2134f 159#endif
87ecb68b 160
e4bcb14c 161typedef enum {
a8659e90 162 IF_NONE,
aae9460e
PB
163 IF_IDE, IF_SCSI, IF_FLOPPY, IF_PFLASH, IF_MTD, IF_SD, IF_VIRTIO, IF_XEN,
164 IF_COUNT
e4bcb14c
TS
165} BlockInterfaceType;
166
428c5705
AL
167typedef enum {
168 BLOCK_ERR_REPORT, BLOCK_ERR_IGNORE, BLOCK_ERR_STOP_ENOSPC,
169 BLOCK_ERR_STOP_ANY
170} BlockInterfaceErrorAction;
171
bf011293 172#define BLOCK_SERIAL_STRLEN 20
173
e4bcb14c
TS
174typedef struct DriveInfo {
175 BlockDriverState *bdrv;
1dae12e6 176 char *id;
c2cc47a4 177 const char *devaddr;
f60d39bc 178 BlockInterfaceType type;
e4bcb14c
TS
179 int bus;
180 int unit;
9dfd7c7a 181 QemuOpts *opts;
428c5705 182 BlockInterfaceErrorAction onerror;
bf011293 183 char serial[BLOCK_SERIAL_STRLEN + 1];
72cf2d4f 184 QTAILQ_ENTRY(DriveInfo) next;
e4bcb14c
TS
185} DriveInfo;
186
187#define MAX_IDE_DEVS 2
188#define MAX_SCSI_DEVS 7
189#define MAX_DRIVES 32
190
72cf2d4f
BS
191extern QTAILQ_HEAD(drivelist, DriveInfo) drives;
192extern QTAILQ_HEAD(driveoptlist, DriveOpt) driveopts;
e4bcb14c 193
751c6a17 194extern DriveInfo *drive_get(BlockInterfaceType type, int bus, int unit);
2e810b36 195extern DriveInfo *drive_get_by_id(const char *id);
f60d39bc 196extern int drive_get_max_bus(BlockInterfaceType type);
56a14938 197extern void drive_uninit(DriveInfo *dinfo);
fa879c64 198extern const char *drive_get_serial(BlockDriverState *bdrv);
428c5705 199extern BlockInterfaceErrorAction drive_get_onerror(BlockDriverState *bdrv);
87ecb68b 200
aae9460e
PB
201BlockDriverState *qdev_init_bdrv(DeviceState *dev, BlockInterfaceType type);
202
9dfd7c7a
GH
203extern QemuOpts *drive_add(const char *file, const char *fmt, ...);
204extern DriveInfo *drive_init(QemuOpts *arg, void *machine, int *fatal_error);
4d73cd3b 205
6f338c34
AL
206/* device-hotplug */
207
751c6a17 208DriveInfo *add_init_drive(const char *opts);
6f338c34
AL
209
210/* pci-hotplug */
1d4daa91 211void pci_device_hot_add(Monitor *mon, const QDict *qdict);
f18c16de 212void drive_hot_add(Monitor *mon, const QDict *qdict);
376253ec 213void pci_device_hot_remove(Monitor *mon, const char *pci_addr);
6848d827
LC
214void do_pci_device_hot_remove(Monitor *mon, const QDict *qdict,
215 QObject **ret_data);
6f338c34 216
87ecb68b
PB
217/* serial ports */
218
219#define MAX_SERIAL_PORTS 4
220
221extern CharDriverState *serial_hds[MAX_SERIAL_PORTS];
222
223/* parallel ports */
224
225#define MAX_PARALLEL_PORTS 3
226
227extern CharDriverState *parallel_hds[MAX_PARALLEL_PORTS];
228
9ede2fde
AL
229/* virtio consoles */
230
231#define MAX_VIRTIO_CONSOLES 1
232
233extern CharDriverState *virtcon_hds[MAX_VIRTIO_CONSOLES];
234
0e82f34d
AL
235#define TFR(expr) do { if ((expr) != -1) break; } while (errno == EINTR)
236
87ecb68b
PB
237#ifdef HAS_AUDIO
238struct soundhw {
239 const char *name;
240 const char *descr;
241 int enabled;
242 int isa;
243 union {
22d83b14
PB
244 int (*init_isa) (qemu_irq *pic);
245 int (*init_pci) (PCIBus *bus);
87ecb68b
PB
246 } init;
247};
248
249extern struct soundhw soundhw[];
250#endif
251
d54908a5
LC
252void do_usb_add(Monitor *mon, const QDict *qdict);
253void do_usb_del(Monitor *mon, const QDict *qdict);
376253ec 254void usb_info(Monitor *mon);
87ecb68b 255
aae9460e
PB
256void register_devices(void);
257
87ecb68b 258#endif