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