X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=src%2Finternal%2Flibc.h;h=619bba8613e8d20cc00c69eec83dd054348b5005;hb=8d81ba8c0bc6fe31136cb15c9c82ef4c24965040;hp=ca06f3199340d04e92b8c5f69fa0b74a864236f5;hpb=8431d7972fd9be0fdcaff8516316d748e81724bb;p=musl diff --git a/src/internal/libc.h b/src/internal/libc.h index ca06f319..619bba86 100644 --- a/src/internal/libc.h +++ b/src/internal/libc.h @@ -3,70 +3,56 @@ #include #include +#include -struct __libc { - void *main_thread; - int threaded; - int secure; - size_t *auxv; - int (*atexit)(void (*)(void)); - void (*fini)(void); - void (*ldso_fini)(void); - volatile int threads_minus_1; - int canceldisable; - FILE *ofl_head; - int ofl_lock[2]; - volatile size_t tls_size, tls_cnt; +struct __locale_map; + +struct __locale_struct { + const struct __locale_map *cat[6]; }; -extern size_t __hwcap; +struct tls_module { + struct tls_module *next; + void *image; + size_t len, size, align, offset; +}; -#if !defined(__PIC__) || 100*__GNUC__+__GNUC_MINOR__ >= 303 || defined(__PCC__) || defined(__TINYC__) +struct __libc { + char can_do_threads; + char threaded; + char secure; + volatile signed char need_locks; + int threads_minus_1; + size_t *auxv; + struct tls_module *tls_head; + size_t tls_size, tls_align, tls_cnt; + size_t page_size; + struct __locale_struct global_locale; +}; -#ifdef __PIC__ -#if __GNUC__ < 4 -#define BROKEN_VISIBILITY 1 -#endif -#define ATTR_LIBC_VISIBILITY __attribute__((visibility("hidden"))) -#else -#define ATTR_LIBC_VISIBILITY +#ifndef PAGE_SIZE +#define PAGE_SIZE libc.page_size #endif -extern struct __libc __libc ATTR_LIBC_VISIBILITY; +extern hidden struct __libc __libc; #define libc __libc -#else - -#define USE_LIBC_ACCESSOR -#define ATTR_LIBC_VISIBILITY -extern struct __libc *__libc_loc(void) __attribute__((const)); -#define libc (*__libc_loc()) - -#endif - - -/* Designed to avoid any overhead in non-threaded processes */ -void __lock(volatile int *); -void __unlock(volatile int *); -int __lockfile(FILE *); -void __unlockfile(FILE *); -#define LOCK(x) (libc.threads_minus_1 ? (__lock(x),1) : ((void)(x),1)) -#define UNLOCK(x) (libc.threads_minus_1 ? (__unlock(x),1) : ((void)(x),1)) - -void __synccall(void (*)(void *), void *); -int __setxid(int, int, int, int); - -extern char **__environ; -#define environ __environ +hidden void __init_libc(char **, char *); +hidden void __init_tls(size_t *); +hidden void __init_ssp(void *); +hidden void __libc_start_init(void); +hidden void __funcs_on_exit(void); +hidden void __funcs_on_quick_exit(void); +hidden void __libc_exit_fini(void); +hidden void __fork_handler(int); -#undef weak_alias -#define weak_alias(old, new) \ - extern __typeof(old) new __attribute__((weak, alias(#old))) +extern hidden size_t __hwcap; +extern hidden size_t __sysinfo; +extern char *__progname, *__progname_full; -#undef LFS64_2 -#define LFS64_2(x, y) weak_alias(x, y) +extern hidden const char __libc_version[]; -#undef LFS64 -#define LFS64(x) LFS64_2(x, x##64) +hidden void __synccall(void (*)(void *), void *); +hidden int __setxid(int, int, int, int); #endif