X-Git-Url: http://nsz.repo.hu/git/?p=musl;a=blobdiff_plain;f=src%2Finternal%2Flibc.h;h=115cd8653b78246cb5835e408a19c95f4f21ef8e;hp=60a25eff7cf0321824a550001e1d3142da7aad52;hb=407d933052c310ebc5541dae2ecd8c4bd8f55fb9;hpb=952987a0cb9b1973fdf23e05f8ddc6fe3c98fd68 diff --git a/src/internal/libc.h b/src/internal/libc.h index 60a25eff..115cd865 100644 --- a/src/internal/libc.h +++ b/src/internal/libc.h @@ -5,19 +5,14 @@ #include struct __libc { - int *(*errno_location)(void); - void (*cancelpt)(int); - void (*lock)(volatile int *); - void (*lockfile)(FILE *); - void (**tsd_keys)(void *); - void (*sigtimer)(); + void *main_thread; + int threaded; + int canceldisable; int (*atexit)(void (*)(void)); void (*fini)(void); void (*ldso_fini)(void); volatile int threads_minus_1; int ofl_lock; - int (*rsyscall)(int, long, long, long, long, long, long); - void (*fork_handler)(int); FILE *ofl_head; }; @@ -40,13 +35,14 @@ extern struct __libc *__libc_loc(void) __attribute__((const)); /* Designed to avoid any overhead in non-threaded processes */ void __lock(volatile int *); -void __lockfile(FILE *); +int __lockfile(FILE *); +void __unlockfile(FILE *); #define LOCK(x) (libc.threads_minus_1 ? (__lock(x),1) : ((void)(x),1)) -#define UNLOCK(x) (*(x)=0) -#define CANCELPT(x) (libc.cancelpt ? libc.cancelpt((x)),0 : (void)(x),0) -#define CANCELPT_BEGIN CANCELPT(1) -#define CANCELPT_TRY CANCELPT(0) -#define CANCELPT_END CANCELPT(-1) +#define UNLOCK(x) (*(volatile int *)(x)=0) + +void __synccall(void (*)(void *), void *); +void __synccall_wait(void); +int __setxid(int, int, int, int); extern char **__environ; #define environ __environ