X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=src%2Finternal%2Flibc.h;h=929ff97ae4257d8493d6c6c0e7c32c6ce58c5445;hb=dba68bf98fc708cea4c478278c889fc7ad802b00;hp=d6df93d0a40cf9a79fe35c0a11f1db97ece05fb3;hpb=ebf82447be4b30bedc19ad868c3a0662b1ba596d;p=musl diff --git a/src/internal/libc.h b/src/internal/libc.h index d6df93d0..929ff97a 100644 --- a/src/internal/libc.h +++ b/src/internal/libc.h @@ -7,8 +7,8 @@ struct __libc { int *(*errno_location)(void); void (*testcancel)(void); - void (*lock)(volatile int *); - void (*lockfile)(FILE *); + int threaded; + int canceldisable; void (*fork_handler)(int); int (*atexit)(void (*)(void)); void (*fini)(void); @@ -16,7 +16,7 @@ struct __libc { volatile int threads_minus_1; int ofl_lock; FILE *ofl_head; - int canceldisable; + void *main_thread; }; @@ -38,11 +38,13 @@ 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 UNLOCK(x) (*(volatile int *)(x)=0) -int __rsyscall(int, long, long, long, long, long, long); +void __synccall(void (*)(void *), void *); +int __setxid(int, int, int, int); extern char **__environ; #define environ __environ