]> git.proxmox.com Git - qemu.git/blame - qemu-common.h
Make struct iovec universally available
[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
5/* we put basic includes here to avoid repeating them in device drivers */
6#include <stdlib.h>
7#include <stdio.h>
8#include <stdarg.h>
9#include <string.h>
c8906845 10#include <strings.h>
faf07963
PB
11#include <inttypes.h>
12#include <limits.h>
13#include <time.h>
14#include <ctype.h>
15#include <errno.h>
16#include <unistd.h>
17#include <fcntl.h>
18#include <sys/stat.h>
bf9298b9 19#include "config-host.h"
faf07963
PB
20
21#ifndef O_LARGEFILE
22#define O_LARGEFILE 0
23#endif
24#ifndef O_BINARY
25#define O_BINARY 0
26#endif
27
28#ifndef ENOMEDIUM
29#define ENOMEDIUM ENODEV
30#endif
31
bf9298b9
AL
32#ifndef HAVE_IOVEC
33#define HAVE_IOVEC
34struct iovec {
35 void *iov_base;
36 size_t iov_len;
37};
38#endif
39
faf07963 40#ifdef _WIN32
4fddf62a 41#define WIN32_LEAN_AND_MEAN
d247d25f 42#define WINVER 0x0501 /* needed for ipv6 bits */
faf07963
PB
43#include <windows.h>
44#define fsync _commit
45#define lseek _lseeki64
46#define ENOTSUP 4096
47extern int qemu_ftruncate64(int, int64_t);
48#define ftruncate qemu_ftruncate64
49
50
51static inline char *realpath(const char *path, char *resolved_path)
52{
53 _fullpath(resolved_path, path, _MAX_PATH);
54 return resolved_path;
55}
56
57#define PRId64 "I64d"
58#define PRIx64 "I64x"
59#define PRIu64 "I64u"
60#define PRIo64 "I64o"
61#endif
62
63/* FIXME: Remove NEED_CPU_H. */
64#ifndef NEED_CPU_H
65
faf07963
PB
66#include <setjmp.h>
67#include "osdep.h"
68#include "bswap.h"
69
70#else
71
72#include "cpu.h"
73
74#endif /* !defined(NEED_CPU_H) */
75
76/* bottom halves */
77typedef struct QEMUBH QEMUBH;
78
79typedef void QEMUBHFunc(void *opaque);
80
81QEMUBH *qemu_bh_new(QEMUBHFunc *cb, void *opaque);
82void qemu_bh_schedule(QEMUBH *bh);
80d3580b
AL
83/* Bottom halfs that are scheduled from a bottom half handler are instantly
84 * invoked. This can create an infinite loop if a bottom half handler
85 * schedules itself. qemu_bh_schedule_idle() avoids this infinite loop by
86 * ensuring that the bottom half isn't executed until the next main loop
87 * iteration.
88 */
1b435b10 89void qemu_bh_schedule_idle(QEMUBH *bh);
faf07963
PB
90void qemu_bh_cancel(QEMUBH *bh);
91void qemu_bh_delete(QEMUBH *bh);
92int qemu_bh_poll(void);
93
87ecb68b
PB
94uint64_t muldiv64(uint64_t a, uint32_t b, uint32_t c);
95
f6503059
AZ
96void qemu_get_timedate(struct tm *tm, int offset);
97int qemu_timedate_diff(struct tm *tm);
98
faf07963
PB
99/* cutils.c */
100void pstrcpy(char *buf, int buf_size, const char *str);
101char *pstrcat(char *buf, int buf_size, const char *s);
102int strstart(const char *str, const char *val, const char **ptr);
103int stristart(const char *str, const char *val, const char **ptr);
104time_t mktimegm(struct tm *tm);
b39ade83 105int fls(int i);
faf07963 106
cd390083
BS
107#define qemu_isalnum(c) isalnum((unsigned char)(c))
108#define qemu_isalpha(c) isalpha((unsigned char)(c))
109#define qemu_iscntrl(c) iscntrl((unsigned char)(c))
110#define qemu_isdigit(c) isdigit((unsigned char)(c))
111#define qemu_isgraph(c) isgraph((unsigned char)(c))
112#define qemu_islower(c) islower((unsigned char)(c))
113#define qemu_isprint(c) isprint((unsigned char)(c))
114#define qemu_ispunct(c) ispunct((unsigned char)(c))
115#define qemu_isspace(c) isspace((unsigned char)(c))
116#define qemu_isupper(c) isupper((unsigned char)(c))
117#define qemu_isxdigit(c) isxdigit((unsigned char)(c))
118#define qemu_tolower(c) tolower((unsigned char)(c))
119#define qemu_toupper(c) toupper((unsigned char)(c))
120#define qemu_isascii(c) isascii((unsigned char)(c))
121#define qemu_toascii(c) toascii((unsigned char)(c))
122
ca10f867 123void *qemu_malloc(size_t size);
2137b4cc 124void *qemu_realloc(void *ptr, size_t size);
ca10f867
AJ
125void *qemu_mallocz(size_t size);
126void qemu_free(void *ptr);
127char *qemu_strdup(const char *str);
ac4b0d0c 128char *qemu_strndup(const char *str, size_t size);
ca10f867
AJ
129
130void *get_mmap_addr(unsigned long size);
131
132
87ecb68b
PB
133/* Error handling. */
134
135void hw_error(const char *fmt, ...)
136 __attribute__ ((__format__ (__printf__, 1, 2)))
137 __attribute__ ((__noreturn__));
138
139/* IO callbacks. */
140typedef void IOReadHandler(void *opaque, const uint8_t *buf, int size);
141typedef int IOCanRWHandler(void *opaque);
142typedef void IOHandler(void *opaque);
143
144struct ParallelIOArg {
145 void *buffer;
146 int count;
147};
148
149typedef int (*DMA_transfer_handler) (void *opaque, int nchan, int pos, int size);
150
151/* A load of opaque types so that device init declarations don't have to
152 pull in all the real definitions. */
153typedef struct NICInfo NICInfo;
1ae26a18 154typedef struct HCIInfo HCIInfo;
87ecb68b
PB
155typedef struct AudioState AudioState;
156typedef struct BlockDriverState BlockDriverState;
157typedef struct DisplayState DisplayState;
158typedef struct TextConsole TextConsole;
c60e08d9 159typedef TextConsole QEMUConsole;
87ecb68b
PB
160typedef struct CharDriverState CharDriverState;
161typedef struct VLANState VLANState;
162typedef struct QEMUFile QEMUFile;
163typedef struct i2c_bus i2c_bus;
164typedef struct i2c_slave i2c_slave;
165typedef struct SMBusDevice SMBusDevice;
166typedef struct QEMUTimer QEMUTimer;
167typedef struct PCIBus PCIBus;
168typedef struct PCIDevice PCIDevice;
169typedef struct SerialState SerialState;
170typedef struct IRQState *qemu_irq;
171struct pcmcia_card_s;
172
b3c7724c
PB
173/* CPU save/load. */
174void cpu_save(QEMUFile *f, void *opaque);
175int cpu_load(QEMUFile *f, void *opaque, int version_id);
176
9e472e10
AL
177/* Force QEMU to stop what it's doing and service IO */
178void qemu_service_io(void);
179
faf07963 180#endif