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