]> git.proxmox.com Git - qemu.git/blame - sysemu.h
Fix sys-queue.h conflict for good
[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"
d54908a5 8#include "qdict.h"
376253ec 9
49dc768d
AL
10#ifdef _WIN32
11#include <windows.h>
12#endif
13
87ecb68b
PB
14/* vl.c */
15extern const char *bios_name;
5cea8590
PB
16
17#define QEMU_FILE_TYPE_BIOS 0
18#define QEMU_FILE_TYPE_KEYMAP 1
19char *qemu_find_file(int type, const char *name);
87ecb68b
PB
20
21extern int vm_running;
22extern const char *qemu_name;
8fcb1b90 23extern uint8_t qemu_uuid[];
c4be29ff 24int qemu_uuid_parse(const char *str, uint8_t *uuid);
8fcb1b90 25#define UUID_FMT "%02hhx%02hhx%02hhx%02hhx-%02hhx%02hhx-%02hhx%02hhx-%02hhx%02hhx-%02hhx%02hhx%02hhx%02hhx%02hhx%02hhx"
87ecb68b
PB
26
27typedef struct vm_change_state_entry VMChangeStateEntry;
9781e040 28typedef void VMChangeStateHandler(void *opaque, int running, int reason);
87ecb68b
PB
29
30VMChangeStateEntry *qemu_add_vm_change_state_handler(VMChangeStateHandler *cb,
31 void *opaque);
32void qemu_del_vm_change_state_handler(VMChangeStateEntry *e);
33
87ecb68b
PB
34void vm_start(void);
35void vm_stop(int reason);
36
9f9e28cd
GC
37uint64_t ram_bytes_remaining(void);
38uint64_t ram_bytes_transferred(void);
39uint64_t ram_bytes_total(void);
40
87ecb68b
PB
41int64_t cpu_get_ticks(void);
42void cpu_enable_ticks(void);
43void cpu_disable_ticks(void);
44
45void qemu_system_reset_request(void);
46void qemu_system_shutdown_request(void);
47void qemu_system_powerdown_request(void);
cf7a2fe2
AJ
48int qemu_shutdown_requested(void);
49int qemu_reset_requested(void);
50int qemu_powerdown_requested(void);
d9c32310 51extern qemu_irq qemu_system_powerdown;
cf7a2fe2 52void qemu_system_reset(void);
87ecb68b 53
d54908a5 54void do_savevm(Monitor *mon, const QDict *qdict);
05f2401e 55int load_vmstate(Monitor *mon, const char *name);
d54908a5 56void do_delvm(Monitor *mon, const QDict *qdict);
376253ec 57void do_info_snapshots(Monitor *mon);
87ecb68b 58
210f41ba
AL
59void qemu_announce_self(void);
60
87ecb68b
PB
61void main_loop_wait(int timeout);
62
9366f418
AL
63int qemu_savevm_state_begin(QEMUFile *f);
64int qemu_savevm_state_iterate(QEMUFile *f);
65int qemu_savevm_state_complete(QEMUFile *f);
66int qemu_savevm_state(QEMUFile *f);
67int qemu_loadvm_state(QEMUFile *f);
68
ac7531ec
GH
69void qemu_errors_to_file(FILE *fp);
70void qemu_errors_to_mon(Monitor *mon);
71void qemu_errors_to_previous(void);
72void qemu_error(const char *fmt, ...) __attribute__ ((format(printf, 1, 2)));
73
56f3a5d0 74#ifdef _WIN32
87ecb68b
PB
75/* Polling handling */
76
77/* return TRUE if no sleep should be done afterwards */
78typedef int PollingFunc(void *opaque);
79
80int qemu_add_polling_cb(PollingFunc *func, void *opaque);
81void qemu_del_polling_cb(PollingFunc *func, void *opaque);
82
87ecb68b
PB
83/* Wait objects handling */
84typedef void WaitObjectFunc(void *opaque);
85
86int qemu_add_wait_object(HANDLE handle, WaitObjectFunc *func, void *opaque);
87void qemu_del_wait_object(HANDLE handle, WaitObjectFunc *func, void *opaque);
88#endif
89
90/* TAP win32 */
7a9f6e4a
AL
91int tap_win32_init(VLANState *vlan, const char *model,
92 const char *name, const char *ifname);
87ecb68b
PB
93
94/* SLIRP */
376253ec 95void do_info_slirp(Monitor *mon);
87ecb68b 96
993fbfdb
AL
97typedef enum DisplayType
98{
99 DT_DEFAULT,
100 DT_CURSES,
101 DT_SDL,
102 DT_VNC,
103 DT_NOGRAPHIC,
104} DisplayType;
105
d399f677 106extern int autostart;
87ecb68b 107extern int bios_size;
86176759
ZA
108
109typedef enum {
110 VGA_NONE, VGA_STD, VGA_CIRRUS, VGA_VMWARE, VGA_XENFB
111} VGAInterfaceType;
112
113extern int vga_interface_type;
114#define cirrus_vga_enabled (vga_interface_type == VGA_CIRRUS)
115#define std_vga_enabled (vga_interface_type == VGA_STD)
116#define xenfb_enabled (vga_interface_type == VGA_XENFB)
117#define vmsvga_enabled (vga_interface_type == VGA_VMWARE)
118
87ecb68b
PB
119extern int graphic_width;
120extern int graphic_height;
121extern int graphic_depth;
6b35e7bf 122extern uint8_t irq0override;
993fbfdb 123extern DisplayType display_type;
87ecb68b
PB
124extern const char *keyboard_layout;
125extern int win2k_install_hack;
73822ec8 126extern int rtc_td_hack;
87ecb68b
PB
127extern int alt_grab;
128extern int usb_enabled;
129extern int smp_cpus;
6be68d7e 130extern int max_cpus;
87ecb68b
PB
131extern int cursor_hide;
132extern int graphic_rotate;
133extern int no_quit;
134extern int semihosting_enabled;
87ecb68b 135extern int old_param;
95387491 136extern int boot_menu;
87ecb68b 137
268a362c
AL
138#define MAX_NODES 64
139extern int nb_numa_nodes;
140extern uint64_t node_mem[MAX_NODES];
141
87ecb68b
PB
142#define MAX_OPTION_ROMS 16
143extern const char *option_rom[MAX_OPTION_ROMS];
144extern int nb_option_roms;
145
1ad2134f 146#ifdef NEED_CPU_H
95efd11c 147#if defined(TARGET_SPARC) || defined(TARGET_PPC)
87ecb68b
PB
148#define MAX_PROM_ENVS 128
149extern const char *prom_envs[MAX_PROM_ENVS];
150extern unsigned int nb_prom_envs;
151#endif
1ad2134f 152#endif
87ecb68b 153
e4bcb14c 154typedef enum {
a8659e90 155 IF_NONE,
aae9460e
PB
156 IF_IDE, IF_SCSI, IF_FLOPPY, IF_PFLASH, IF_MTD, IF_SD, IF_VIRTIO, IF_XEN,
157 IF_COUNT
e4bcb14c
TS
158} BlockInterfaceType;
159
428c5705
AL
160typedef enum {
161 BLOCK_ERR_REPORT, BLOCK_ERR_IGNORE, BLOCK_ERR_STOP_ENOSPC,
162 BLOCK_ERR_STOP_ANY
163} BlockInterfaceErrorAction;
164
bf011293 165#define BLOCK_SERIAL_STRLEN 20
166
e4bcb14c
TS
167typedef struct DriveInfo {
168 BlockDriverState *bdrv;
1dae12e6 169 char *id;
c2cc47a4 170 const char *devaddr;
f60d39bc 171 BlockInterfaceType type;
e4bcb14c
TS
172 int bus;
173 int unit;
9dfd7c7a 174 QemuOpts *opts;
428c5705 175 BlockInterfaceErrorAction onerror;
bf011293 176 char serial[BLOCK_SERIAL_STRLEN + 1];
72cf2d4f 177 QTAILQ_ENTRY(DriveInfo) next;
e4bcb14c
TS
178} DriveInfo;
179
180#define MAX_IDE_DEVS 2
181#define MAX_SCSI_DEVS 7
182#define MAX_DRIVES 32
183
72cf2d4f
BS
184extern QTAILQ_HEAD(drivelist, DriveInfo) drives;
185extern QTAILQ_HEAD(driveoptlist, DriveOpt) driveopts;
e4bcb14c 186
751c6a17 187extern DriveInfo *drive_get(BlockInterfaceType type, int bus, int unit);
2e810b36 188extern DriveInfo *drive_get_by_id(const char *id);
f60d39bc 189extern int drive_get_max_bus(BlockInterfaceType type);
b01b1111 190extern void drive_uninit(BlockDriverState *bdrv);
fa879c64 191extern const char *drive_get_serial(BlockDriverState *bdrv);
428c5705 192extern BlockInterfaceErrorAction drive_get_onerror(BlockDriverState *bdrv);
87ecb68b 193
aae9460e
PB
194BlockDriverState *qdev_init_bdrv(DeviceState *dev, BlockInterfaceType type);
195
9dfd7c7a
GH
196extern QemuOpts *drive_add(const char *file, const char *fmt, ...);
197extern DriveInfo *drive_init(QemuOpts *arg, void *machine, int *fatal_error);
4d73cd3b 198
5e3cb534 199/* acpi */
9d5e77a2
IY
200typedef void (*qemu_system_device_hot_add_t)(int pcibus, int slot, int state);
201void qemu_system_device_hot_add_register(qemu_system_device_hot_add_t callback);
ca2c72be 202void qemu_system_device_hot_add(int pcibus, int slot, int state);
5e3cb534 203
6f338c34
AL
204/* device-hotplug */
205
206typedef int (dev_match_fn)(void *dev_private, void *arg);
207
751c6a17 208DriveInfo *add_init_drive(const char *opts);
6f338c34
AL
209void destroy_nic(dev_match_fn *match_fn, void *arg);
210void destroy_bdrvs(dev_match_fn *match_fn, void *arg);
211
212/* pci-hotplug */
1d4daa91 213void pci_device_hot_add(Monitor *mon, const QDict *qdict);
f18c16de 214void drive_hot_add(Monitor *mon, const QDict *qdict);
376253ec 215void pci_device_hot_remove(Monitor *mon, const char *pci_addr);
d54908a5 216void do_pci_device_hot_remove(Monitor *mon, const QDict *qdict);
6f338c34
AL
217void pci_device_hot_remove_success(int pcibus, int slot);
218
87ecb68b
PB
219/* serial ports */
220
221#define MAX_SERIAL_PORTS 4
222
223extern CharDriverState *serial_hds[MAX_SERIAL_PORTS];
224
225/* parallel ports */
226
227#define MAX_PARALLEL_PORTS 3
228
229extern CharDriverState *parallel_hds[MAX_PARALLEL_PORTS];
230
9ede2fde
AL
231/* virtio consoles */
232
233#define MAX_VIRTIO_CONSOLES 1
234
235extern CharDriverState *virtcon_hds[MAX_VIRTIO_CONSOLES];
236
0e82f34d
AL
237#define TFR(expr) do { if ((expr) != -1) break; } while (errno == EINTR)
238
87ecb68b
PB
239#ifdef NEED_CPU_H
240/* loader.c */
241int get_image_size(const char *filename);
293f78bc
BS
242int load_image(const char *filename, uint8_t *addr); /* deprecated */
243int load_image_targphys(const char *filename, target_phys_addr_t, int max_sz);
83c1f87c 244int load_elf(const char *filename, int64_t address_offset,
87ecb68b 245 uint64_t *pentry, uint64_t *lowaddr, uint64_t *highaddr);
293f78bc 246int load_aout(const char *filename, target_phys_addr_t addr, int max_sz);
5a9154e0
AL
247int load_uimage(const char *filename, target_ulong *ep, target_ulong *loadaddr,
248 int *is_linux);
293f78bc
BS
249
250int fread_targphys(target_phys_addr_t dst_addr, size_t nbytes, FILE *f);
251int fread_targphys_ok(target_phys_addr_t dst_addr, size_t nbytes, FILE *f);
252int read_targphys(int fd, target_phys_addr_t dst_addr, size_t nbytes);
253void pstrcpy_targphys(target_phys_addr_t dest, int buf_size,
254 const char *source);
87ecb68b
PB
255#endif
256
257#ifdef HAS_AUDIO
258struct soundhw {
259 const char *name;
260 const char *descr;
261 int enabled;
262 int isa;
263 union {
22d83b14
PB
264 int (*init_isa) (qemu_irq *pic);
265 int (*init_pci) (PCIBus *bus);
87ecb68b
PB
266 } init;
267};
268
269extern struct soundhw soundhw[];
270#endif
271
d54908a5
LC
272void do_usb_add(Monitor *mon, const QDict *qdict);
273void do_usb_del(Monitor *mon, const QDict *qdict);
376253ec 274void usb_info(Monitor *mon);
87ecb68b 275
aae9460e
PB
276void register_devices(void);
277
87ecb68b 278#endif