X-Git-Url: http://vcs.maemo.org/git/?a=blobdiff_plain;f=osdep.h;h=f818ce03a8bf20bd2ba458f286917e5775f1d490;hb=4aa4253115255d79fe510ba15a68dad8f4ba4499;hp=1c14de4c5ee15a68a9427c693a14dffc63f458b5;hpb=0fb48229a73b39be02a78350547fa524c0d72c57;p=qemu diff --git a/osdep.h b/osdep.h index 1c14de4..f818ce0 100644 --- a/osdep.h +++ b/osdep.h @@ -10,6 +10,10 @@ void qemu_printf(const char *fmt, ...); void *qemu_malloc(size_t size); void *qemu_mallocz(size_t size); void qemu_free(void *ptr); +char *qemu_strdup(const char *str); + +void *qemu_vmalloc(size_t size); +void qemu_vfree(void *ptr); void *get_mmap_addr(unsigned long size); @@ -21,6 +25,29 @@ void *get_mmap_addr(unsigned long size); extern void __longjmp(jmp_buf env, int val); #define longjmp __longjmp +#include + +/* NOTE: it works only because the glibc sigset_t is >= kernel sigset_t */ +struct qemu_sigaction { + union { + void (*_sa_handler)(int); + void (*_sa_sigaction)(int, struct siginfo *, void *); + } _u; + unsigned long sa_flags; + void (*sa_restorer)(void); + sigset_t sa_mask; /* mask last for extensibility */ +}; + +int qemu_sigaction(int signum, const struct qemu_sigaction *act, + struct qemu_sigaction *oldact); + +#undef sigaction +#undef sa_handler +#undef sa_sigaction +#define sigaction qemu_sigaction +#define sa_handler _u._sa_handler +#define sa_sigaction _u._sa_sigaction + #endif #endif