blob: 661e6e86ac0012760e578304b4183be5e0dc754d [file] [log] [blame]
bellardea888122004-02-16 22:12:40 +00001#ifndef QEMU_OSDEP_H
2#define QEMU_OSDEP_H
3
4#include <stdarg.h>
5
bellardd62ca2b2006-08-01 15:50:14 +00006#define qemu_printf printf
bellardea888122004-02-16 22:12:40 +00007
8void *qemu_malloc(size_t size);
bellard0fb48222004-03-14 21:48:47 +00009void *qemu_mallocz(size_t size);
bellardea888122004-02-16 22:12:40 +000010void qemu_free(void *ptr);
bellard25719292004-07-14 17:21:57 +000011char *qemu_strdup(const char *str);
bellardea888122004-02-16 22:12:40 +000012
bellard49b470e2005-02-10 21:59:25 +000013void *qemu_vmalloc(size_t size);
14void qemu_vfree(void *ptr);
15
bellardea888122004-02-16 22:12:40 +000016void *get_mmap_addr(unsigned long size);
17
18/* specific kludges for OS compatibility (should be moved elsewhere) */
19#if defined(__i386__) && !defined(CONFIG_SOFTMMU) && !defined(CONFIG_USER_ONLY)
20
21/* disabled pthread version of longjmp which prevent us from using an
22 alternative signal stack */
23extern void __longjmp(jmp_buf env, int val);
24#define longjmp __longjmp
25
bellardd2bfb392004-08-03 22:09:30 +000026#include <signal.h>
27
bellard755d1372006-06-25 18:02:02 +000028struct siginfo;
29
bellardd2bfb392004-08-03 22:09:30 +000030/* NOTE: it works only because the glibc sigset_t is >= kernel sigset_t */
31struct qemu_sigaction {
32 union {
33 void (*_sa_handler)(int);
34 void (*_sa_sigaction)(int, struct siginfo *, void *);
35 } _u;
36 unsigned long sa_flags;
37 void (*sa_restorer)(void);
38 sigset_t sa_mask; /* mask last for extensibility */
39};
40
41int qemu_sigaction(int signum, const struct qemu_sigaction *act,
42 struct qemu_sigaction *oldact);
43
44#undef sigaction
45#undef sa_handler
46#undef sa_sigaction
47#define sigaction qemu_sigaction
48#define sa_handler _u._sa_handler
49#define sa_sigaction _u._sa_sigaction
50
bellardea888122004-02-16 22:12:40 +000051#endif
52
53#endif