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