summaryrefslogtreecommitdiff
path: root/libc/misc/internals
diff options
context:
space:
mode:
Diffstat (limited to 'libc/misc/internals')
-rw-r--r--libc/misc/internals/__uClibc_main.c13
1 files changed, 10 insertions, 3 deletions
diff --git a/libc/misc/internals/__uClibc_main.c b/libc/misc/internals/__uClibc_main.c
index 81cc57d94..e9af10dcd 100644
--- a/libc/misc/internals/__uClibc_main.c
+++ b/libc/misc/internals/__uClibc_main.c
@@ -21,6 +21,7 @@
*/
extern int main(int argc, char **argv, char **envp);
extern void weak_function _init(void);
+extern void weak_function __pthread_initialize_minimal(void);
extern void weak_function _fini(void);
extern void weak_function _stdio_init(void);
extern int *weak_const_function __errno_location(void);
@@ -56,6 +57,11 @@ __uClibc_main(int argc, char **argv, char **envp)
__environ = envp;
}
+#ifdef _LIBC_REENTRANT
+ if (likely(__pthread_initialize_minimal!=NULL))
+ __pthread_initialize_minimal();
+#endif
+
#if 0
/* Some security at this point. Prevent starting a SUID binary
* where the standard file descriptors are not opened. We have
@@ -67,7 +73,8 @@ __uClibc_main(int argc, char **argv, char **envp)
#ifdef __UCLIBC_HAS_LOCALE__
/* Initialize the global locale structure. */
- if (likely(_locale_init!=NULL)) _locale_init();
+ if (likely(_locale_init!=NULL))
+ _locale_init();
#endif
/*
@@ -78,12 +85,12 @@ __uClibc_main(int argc, char **argv, char **envp)
_stdio_init();
/* Arrange for dtors to run at exit. */
- if (unlikely(_fini!=NULL && atexit)) {
+ if (likely(_fini!=NULL && atexit)) {
atexit (&_fini);
}
/* Run all ctors now. */
- if (unlikely(_init!=NULL))
+ if (likely(_init!=NULL))
_init();
/*