X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=src%2Finternal%2Flibc.h;h=508911480645e32b769ad01059419230f97d31f5;hb=5652d70054daf3c2c9b6d475fdf9d24a940e51aa;hp=06ba73e7fb685bb0fffcd6398e87d06c1d5a6765;hpb=9080cc153cc2b09881c3245becbd68534db18d7c;p=musl diff --git a/src/internal/libc.h b/src/internal/libc.h index 06ba73e7..50891148 100644 --- a/src/internal/libc.h +++ b/src/internal/libc.h @@ -5,30 +5,40 @@ #include struct __libc { - int *(*errno_location)(void); - void (*testcancel)(void); + void *main_thread; int threaded; - int canceldisable; - void (*fork_handler)(int); + int secure; + size_t *auxv; int (*atexit)(void (*)(void)); void (*fini)(void); void (*ldso_fini)(void); volatile int threads_minus_1; - int ofl_lock; + int canceldisable; FILE *ofl_head; + int ofl_lock[2]; + size_t tls_size; }; +extern size_t __hwcap; -#if 100*__GNUC__+__GNUC_MINOR__ >= 303 || defined(__PCC__) || defined(__TINYC__) -extern struct __libc __libc __attribute__((visibility("hidden"))); -#define libc __libc +#if !defined(__PIC__) || (100*__GNUC__+__GNUC_MINOR__ >= 303 && !defined(__PCC__)) + +#ifdef __PIC__ +#if __GNUC__ < 4 +#define BROKEN_VISIBILITY 1 +#endif +#define ATTR_LIBC_VISIBILITY __attribute__((visibility("hidden"))) +#else +#define ATTR_LIBC_VISIBILITY +#endif -#elif !defined(__PIC__) -extern struct __libc __libc; +extern struct __libc __libc ATTR_LIBC_VISIBILITY; #define libc __libc #else + #define USE_LIBC_ACCESSOR +#define ATTR_LIBC_VISIBILITY extern struct __libc *__libc_loc(void) __attribute__((const)); #define libc (*__libc_loc()) @@ -36,12 +46,15 @@ extern struct __libc *__libc_loc(void) __attribute__((const)); /* Designed to avoid any overhead in non-threaded processes */ -void __lock(volatile int *); -void __lockfile(FILE *); +void __lock(volatile int *) ATTR_LIBC_VISIBILITY; +void __unlock(volatile int *) ATTR_LIBC_VISIBILITY; +int __lockfile(FILE *) ATTR_LIBC_VISIBILITY; +void __unlockfile(FILE *) ATTR_LIBC_VISIBILITY; #define LOCK(x) (libc.threads_minus_1 ? (__lock(x),1) : ((void)(x),1)) -#define UNLOCK(x) (*(volatile int *)(x)=0) +#define UNLOCK(x) (libc.threads_minus_1 ? (__unlock(x),1) : ((void)(x),1)) -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 @@ -51,8 +64,7 @@ extern char **__environ; extern __typeof(old) new __attribute__((weak, alias(#old))) #undef LFS64_2 -//#define LFS64_2(x, y) weak_alias(x, y) -#define LFS64_2(x, y) extern __typeof(x) y +#define LFS64_2(x, y) weak_alias(x, y) #undef LFS64 #define LFS64(x) LFS64_2(x, x##64)