X-Git-Url: http://nsz.repo.hu/git/?p=musl;a=blobdiff_plain;f=src%2Finternal%2Flibc.h;h=638ea5270e38f5a449011edac0df9762b3a05865;hp=e81ef7609f466d4dc2fa1b068acbc7cb87d9eaa6;hb=870cc679771f776333953b2a990a107393d9d0fd;hpb=41d518360fd2da0f19d6a2f8d8c5f226b201c1e9 diff --git a/src/internal/libc.h b/src/internal/libc.h index e81ef760..638ea527 100644 --- a/src/internal/libc.h +++ b/src/internal/libc.h @@ -5,16 +5,18 @@ #include struct __libc { - void (*lock)(volatile int *); - void (*cancelpt)(int); + int *(*errno_location)(void); + void (*testcancel)(void); + int threaded; + int canceldisable; + void (*fork_handler)(int); int (*atexit)(void (*)(void)); void (*fini)(void); void (*ldso_fini)(void); - int *(*errno_location)(void); volatile int threads_minus_1; - int (*rsyscall)(int, long, long, long, long, long, long); - void (**tsd_keys)(void *); - void (*fork_handler)(int); + int ofl_lock; + FILE *ofl_head; + void *main_thread; }; @@ -36,11 +38,11 @@ extern struct __libc *__libc_loc(void) __attribute__((const)); /* Designed to avoid any overhead in non-threaded processes */ void __lock(volatile int *); +void __lockfile(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_END CANCELPT(0) +#define UNLOCK(x) (*(volatile int *)(x)=0) + +int __rsyscall(int, long, long, long, long, long, long); extern char **__environ; #define environ __environ