]> git.proxmox.com Git - qemu.git/blame - qemu-common.h
We only support eventfd under POSIX, move qemu_eventfd() to os-posix.c
[qemu.git] / qemu-common.h
CommitLineData
faf07963
PB
1/* Common header file that is included by all of qemu. */
2#ifndef QEMU_COMMON_H
3#define QEMU_COMMON_H
4
beb6f0de
KW
5#include "config-host.h"
6
a5e50b26 7#define QEMU_NORETURN __attribute__ ((__noreturn__))
747bbdf7
BS
8#ifdef CONFIG_GCC_ATTRIBUTE_WARN_UNUSED_RESULT
9#define QEMU_WARN_UNUSED_RESULT __attribute__((warn_unused_result))
10#else
11#define QEMU_WARN_UNUSED_RESULT
12#endif
7d99a001 13
24ebf5f3
PB
14#define QEMU_BUILD_BUG_ON(x) typedef char __build_bug_on__##__LINE__[(x)?-1:1];
15
29e922b6
BS
16typedef struct QEMUTimer QEMUTimer;
17typedef struct QEMUFile QEMUFile;
18typedef struct QEMUBH QEMUBH;
92a16d7a 19typedef struct DeviceState DeviceState;
29e922b6 20
faf07963
PB
21/* we put basic includes here to avoid repeating them in device drivers */
22#include <stdlib.h>
23#include <stdio.h>
24#include <stdarg.h>
11165820 25#include <stdbool.h>
faf07963 26#include <string.h>
c8906845 27#include <strings.h>
faf07963
PB
28#include <inttypes.h>
29#include <limits.h>
30#include <time.h>
31#include <ctype.h>
32#include <errno.h>
33#include <unistd.h>
34#include <fcntl.h>
35#include <sys/stat.h>
55616505 36#include <assert.h>
faf07963
PB
37
38#ifndef O_LARGEFILE
39#define O_LARGEFILE 0
40#endif
41#ifndef O_BINARY
42#define O_BINARY 0
43#endif
0e74e66b
JQ
44#ifndef MAP_ANONYMOUS
45#define MAP_ANONYMOUS MAP_ANON
46#endif
faf07963
PB
47#ifndef ENOMEDIUM
48#define ENOMEDIUM ENODEV
49#endif
4c955388 50#if !defined(ENOTSUP)
2880bc32
JQ
51#define ENOTSUP 4096
52#endif
faf07963 53
6114fdb0
JQ
54#ifndef CONFIG_IOVEC
55#define CONFIG_IOVEC
bf9298b9
AL
56struct iovec {
57 void *iov_base;
58 size_t iov_len;
59};
e2a305fb
CH
60/*
61 * Use the same value as Linux for now.
62 */
63#define IOV_MAX 1024
331dadde
BS
64#else
65#include <sys/uio.h>
bf9298b9
AL
66#endif
67
9c9e7d51
SW
68#if defined __GNUC__
69# if (__GNUC__ < 4) || \
70 defined(__GNUC_MINOR__) && (__GNUC__ == 4) && (__GNUC_MINOR__ < 4)
71 /* gcc versions before 4.4.x don't support gnu_printf, so use printf. */
72# define GCC_ATTR __attribute__((__unused__, format(printf, 1, 2)))
73# define GCC_FMT_ATTR(n, m) __attribute__((format(printf, n, m)))
74# else
75 /* Use gnu_printf when supported (qemu uses standard format strings). */
76# define GCC_ATTR __attribute__((__unused__, format(gnu_printf, 1, 2)))
77# define GCC_FMT_ATTR(n, m) __attribute__((format(gnu_printf, n, m)))
78# endif
79#else
80#define GCC_ATTR /**/
81#define GCC_FMT_ATTR(n, m)
82#endif
83
f868445a
SW
84typedef int (*fprintf_function)(FILE *f, const char *fmt, ...)
85 GCC_FMT_ATTR(2, 3);
86
faf07963 87#ifdef _WIN32
faf07963
PB
88#define fsync _commit
89#define lseek _lseeki64
faf07963
PB
90extern int qemu_ftruncate64(int, int64_t);
91#define ftruncate qemu_ftruncate64
92
faf07963
PB
93static inline char *realpath(const char *path, char *resolved_path)
94{
95 _fullpath(resolved_path, path, _MAX_PATH);
96 return resolved_path;
97}
98
99#define PRId64 "I64d"
100#define PRIx64 "I64x"
101#define PRIu64 "I64u"
102#define PRIo64 "I64o"
103#endif
104
105/* FIXME: Remove NEED_CPU_H. */
106#ifndef NEED_CPU_H
107
faf07963
PB
108#include <setjmp.h>
109#include "osdep.h"
110#include "bswap.h"
111
112#else
113
114#include "cpu.h"
115
116#endif /* !defined(NEED_CPU_H) */
117
118/* bottom halves */
faf07963
PB
119typedef void QEMUBHFunc(void *opaque);
120
9a1e9481
KW
121void async_context_push(void);
122void async_context_pop(void);
123int get_async_context_id(void);
124
faf07963
PB
125QEMUBH *qemu_bh_new(QEMUBHFunc *cb, void *opaque);
126void qemu_bh_schedule(QEMUBH *bh);
80d3580b
AL
127/* Bottom halfs that are scheduled from a bottom half handler are instantly
128 * invoked. This can create an infinite loop if a bottom half handler
129 * schedules itself. qemu_bh_schedule_idle() avoids this infinite loop by
130 * ensuring that the bottom half isn't executed until the next main loop
131 * iteration.
132 */
1b435b10 133void qemu_bh_schedule_idle(QEMUBH *bh);
faf07963
PB
134void qemu_bh_cancel(QEMUBH *bh);
135void qemu_bh_delete(QEMUBH *bh);
136int qemu_bh_poll(void);
4f999d05 137void qemu_bh_update_timeout(int *timeout);
faf07963 138
f6503059
AZ
139void qemu_get_timedate(struct tm *tm, int offset);
140int qemu_timedate_diff(struct tm *tm);
141
faf07963
PB
142/* cutils.c */
143void pstrcpy(char *buf, int buf_size, const char *str);
144char *pstrcat(char *buf, int buf_size, const char *s);
145int strstart(const char *str, const char *val, const char **ptr);
146int stristart(const char *str, const char *val, const char **ptr);
d43277c5 147int qemu_strnlen(const char *s, int max_len);
faf07963 148time_t mktimegm(struct tm *tm);
ad46db9a 149int qemu_fls(int i);
6f1953c4 150int qemu_fdatasync(int fd);
db1a4972 151int fcntl_setfl(int fd, int flag);
faf07963 152
37022086
BS
153/* path.c */
154void init_paths(const char *prefix);
155const char *path(const char *pathname);
156
cd390083
BS
157#define qemu_isalnum(c) isalnum((unsigned char)(c))
158#define qemu_isalpha(c) isalpha((unsigned char)(c))
159#define qemu_iscntrl(c) iscntrl((unsigned char)(c))
160#define qemu_isdigit(c) isdigit((unsigned char)(c))
161#define qemu_isgraph(c) isgraph((unsigned char)(c))
162#define qemu_islower(c) islower((unsigned char)(c))
163#define qemu_isprint(c) isprint((unsigned char)(c))
164#define qemu_ispunct(c) ispunct((unsigned char)(c))
165#define qemu_isspace(c) isspace((unsigned char)(c))
166#define qemu_isupper(c) isupper((unsigned char)(c))
167#define qemu_isxdigit(c) isxdigit((unsigned char)(c))
168#define qemu_tolower(c) tolower((unsigned char)(c))
169#define qemu_toupper(c) toupper((unsigned char)(c))
170#define qemu_isascii(c) isascii((unsigned char)(c))
171#define qemu_toascii(c) toascii((unsigned char)(c))
172
ca10f867 173void *qemu_malloc(size_t size);
2137b4cc 174void *qemu_realloc(void *ptr, size_t size);
ca10f867
AJ
175void *qemu_mallocz(size_t size);
176void qemu_free(void *ptr);
177char *qemu_strdup(const char *str);
ac4b0d0c 178char *qemu_strndup(const char *str, size_t size);
ca10f867 179
d549db5a
GC
180void qemu_mutex_lock_iothread(void);
181void qemu_mutex_unlock_iothread(void);
182
40ff6d7e 183int qemu_open(const char *name, int flags, ...);
7c7c0629
JQ
184ssize_t qemu_write_full(int fd, const void *buf, size_t count)
185 QEMU_WARN_UNUSED_RESULT;
40ff6d7e
KW
186void qemu_set_cloexec(int fd);
187
188#ifndef _WIN32
f3dfda61 189int qemu_eventfd(int pipefd[2]);
40ff6d7e
KW
190int qemu_pipe(int pipefd[2]);
191#endif
192
87ecb68b
PB
193/* Error handling. */
194
e5924d89 195void QEMU_NORETURN hw_error(const char *fmt, ...) GCC_FMT_ATTR(1, 2);
87ecb68b
PB
196
197/* IO callbacks. */
198typedef void IOReadHandler(void *opaque, const uint8_t *buf, int size);
7b27a769 199typedef int IOCanReadHandler(void *opaque);
87ecb68b
PB
200typedef void IOHandler(void *opaque);
201
202struct ParallelIOArg {
203 void *buffer;
204 int count;
205};
206
207typedef int (*DMA_transfer_handler) (void *opaque, int nchan, int pos, int size);
208
209/* A load of opaque types so that device init declarations don't have to
210 pull in all the real definitions. */
211typedef struct NICInfo NICInfo;
1ae26a18 212typedef struct HCIInfo HCIInfo;
87ecb68b
PB
213typedef struct AudioState AudioState;
214typedef struct BlockDriverState BlockDriverState;
2446333c 215typedef struct DriveInfo DriveInfo;
87ecb68b 216typedef struct DisplayState DisplayState;
7d957bd8
AL
217typedef struct DisplayChangeListener DisplayChangeListener;
218typedef struct DisplaySurface DisplaySurface;
7b5d76da 219typedef struct DisplayAllocator DisplayAllocator;
7d957bd8 220typedef struct PixelFormat PixelFormat;
87ecb68b 221typedef struct TextConsole TextConsole;
c60e08d9 222typedef TextConsole QEMUConsole;
87ecb68b 223typedef struct CharDriverState CharDriverState;
76d32cba 224typedef struct MACAddr MACAddr;
87ecb68b 225typedef struct VLANState VLANState;
f7105843 226typedef struct VLANClientState VLANClientState;
87ecb68b
PB
227typedef struct i2c_bus i2c_bus;
228typedef struct i2c_slave i2c_slave;
229typedef struct SMBusDevice SMBusDevice;
fb47a2e9
IY
230typedef struct PCIHostState PCIHostState;
231typedef struct PCIExpressHost PCIExpressHost;
87ecb68b
PB
232typedef struct PCIBus PCIBus;
233typedef struct PCIDevice PCIDevice;
234typedef struct SerialState SerialState;
235typedef struct IRQState *qemu_irq;
bc24a225
PB
236typedef struct PCMCIACardState PCMCIACardState;
237typedef struct MouseTransformInfo MouseTransformInfo;
238typedef struct uWireSlave uWireSlave;
239typedef struct I2SCodec I2SCodec;
90d37239 240typedef struct SSIBus SSIBus;
2292b339 241typedef struct EventNotifier EventNotifier;
2be24aaa 242typedef struct VirtIODevice VirtIODevice;
87ecb68b 243
186993ee
MT
244typedef uint64_t pcibus_t;
245
2446333c
BS
246typedef enum {
247 IF_NONE,
248 IF_IDE, IF_SCSI, IF_FLOPPY, IF_PFLASH, IF_MTD, IF_SD, IF_VIRTIO, IF_XEN,
249 IF_COUNT
250} BlockInterfaceType;
251
d2053c3c
BS
252void cpu_exec_init_all(unsigned long tb_size);
253
b3c7724c
PB
254/* CPU save/load. */
255void cpu_save(QEMUFile *f, void *opaque);
256int cpu_load(QEMUFile *f, void *opaque, int version_id);
257
9e472e10
AL
258/* Force QEMU to stop what it's doing and service IO */
259void qemu_service_io(void);
260
d9f75a4e
AL
261/* Force QEMU to process pending events */
262void qemu_notify_event(void);
263
8edac960
AL
264/* Unblock cpu */
265void qemu_cpu_kick(void *env);
266int qemu_cpu_self(void *env);
267
e82bcec2
MT
268/* work queue */
269struct qemu_work_item {
270 struct qemu_work_item *next;
271 void (*func)(void *data);
272 void *data;
273 int done;
274};
275
0bf46a40
AL
276#ifdef CONFIG_USER_ONLY
277#define qemu_init_vcpu(env) do { } while (0)
278#else
279void qemu_init_vcpu(void *env);
280#endif
281
44e3ee8a
AL
282typedef struct QEMUIOVector {
283 struct iovec *iov;
284 int niov;
285 int nalloc;
249aa745 286 size_t size;
44e3ee8a
AL
287} QEMUIOVector;
288
289void qemu_iovec_init(QEMUIOVector *qiov, int alloc_hint);
522584a5 290void qemu_iovec_init_external(QEMUIOVector *qiov, struct iovec *iov, int niov);
44e3ee8a 291void qemu_iovec_add(QEMUIOVector *qiov, void *base, size_t len);
b8a83a4f
KW
292void qemu_iovec_copy(QEMUIOVector *dst, QEMUIOVector *src, uint64_t skip,
293 size_t size);
40b4f539 294void qemu_iovec_concat(QEMUIOVector *dst, QEMUIOVector *src, size_t size);
44e3ee8a 295void qemu_iovec_destroy(QEMUIOVector *qiov);
be959463 296void qemu_iovec_reset(QEMUIOVector *qiov);
44e3ee8a 297void qemu_iovec_to_buffer(QEMUIOVector *qiov, void *buf);
249aa745 298void qemu_iovec_from_buffer(QEMUIOVector *qiov, const void *buf, size_t count);
b8a83a4f 299void qemu_iovec_memset(QEMUIOVector *qiov, int c, size_t count);
44e3ee8a 300
376253ec
AL
301struct Monitor;
302typedef struct Monitor Monitor;
303
abd0c6bd
PB
304/* Convert a byte between binary and BCD. */
305static inline uint8_t to_bcd(uint8_t val)
306{
307 return ((val / 10) << 4) | (val % 10);
308}
309
310static inline uint8_t from_bcd(uint8_t val)
311{
312 return ((val >> 4) * 10) + (val & 0x0f);
313}
314
338b922e 315/* compute with 96 bit intermediate result: (a*b)/c */
316static inline uint64_t muldiv64(uint64_t a, uint32_t b, uint32_t c)
317{
318 union {
319 uint64_t ll;
320 struct {
321#ifdef HOST_WORDS_BIGENDIAN
322 uint32_t high, low;
323#else
324 uint32_t low, high;
325#endif
326 } l;
327 } u, res;
328 uint64_t rl, rh;
329
330 u.ll = a;
331 rl = (uint64_t)u.l.low * (uint64_t)b;
332 rh = (uint64_t)u.l.high * (uint64_t)b;
333 rh += (rl >> 32);
334 res.l.high = rh / c;
335 res.l.low = (((rh % c) << 32) + (rl & 0xffffffff)) / c;
336 return res.ll;
337}
338
0bfe3ca5
AL
339#include "module.h"
340
faf07963 341#endif