123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140 |
- /*
- * Manuel Novoa III Feb 2001
- * Erik Andersen Mar 2002
- *
- * __uClibc_main is the routine to be called by all the arch-specific
- * versions of crt0.S in uClibc.
- *
- * It is meant to handle any special initialization needed by the library
- * such as setting the global variable(s) __environ (environ) and
- * initializing the stdio package. Using weak symbols, the latter is
- * avoided in the static library case.
- */
- #define _ERRNO_H
- #include <unistd.h>
- #if !defined HAVE_ELF
- /* This is a theoretical attempt to support old a.out compilers.
- * Dunno if this will work properly and I really don't much
- * care... Elf is the One True Path(tm). You will be assimilated */
- # define __USE_WEAK_ALIASES
- #endif
- /*
- * Prototypes.
- */
- extern int main(int argc, char **argv, char **envp);
- #ifndef __USE_WEAK_ALIASES
- #include <stdlib.h>
- extern int weak_function atexit(void (*function)(void));
- extern void weak_function _init(void);
- extern void weak_function _fini(void);
- extern void weak_function _stdio_init(void);
- extern void weak_function _stdio_term(void);
- extern int *weak_const_function __errno_location(void);
- extern int *weak_const_function __h_errno_location(void);
- #ifdef __UCLIBC_HAS_LOCALE__
- extern void weak_function _locale_init(void);
- #endif
- #else
- /*
- * Define an empty function and use it as a weak alias for the stdio
- * initialization routine. That way we don't pull in all the stdio
- * code unless we need to. Similarly, do the same for _stdio_term
- * so as not to include atexit unnecessarily.
- *
- * NOTE!!! This is only true for the _static_ case!!!
- */
- weak_alias(__environ, environ);
- void __uClibc_empty_func(void)
- {
- }
- extern void exit (int status) __attribute__ ((__noreturn__));
- extern void _init(void);
- extern void _fini(void);
- extern void _stdio_init(void);
- weak_alias(__uClibc_empty_func, _init);
- weak_alias(__uClibc_empty_func, _fini);
- //weak_alias(__uClibc_empty_func, _stdio_init);
- //weak_alias(__uClibc_empty_func, _stdio_term);
- //weak_alias(__uClibc_empty_func, atexit);
- extern int atexit(void (*function)(void));
- //weak_alias(__uClibc_empty_func, __errno_location);
- extern int *__errno_location(void);
- //weak_alias(__uClibc_empty_func, __h_errno_location);
- extern int *__h_errno_location(void);
- #ifdef __UCLIBC_HAS_LOCALE__
- extern void _locale_init(void);
- #endif
- #endif
- /*
- * Declare the __environ global variable and create a weak alias environ.
- * Note: Apparently we must initialize __environ for the weak environ
- * symbol to be included.
- */
- char **__environ = 0;
- weak_alias(__environ, environ);
- /*
- * Now for our main routine.
- */
- void __attribute__ ((__noreturn__))
- __uClibc_main(int argc, char **argv, char **envp)
- {
- /*
- * Initialize the global variable __environ.
- */
- __environ = envp;
- #if 0
- /* Some security at this point. Prevent starting a SUID binary
- * where the standard file descriptors are not opened. We have
- * to do this only for statically linked applications since
- * otherwise the dynamic loader did the work already. */
- if (unlikely (__libc_enable_secure!=NULL))
- __libc_check_standard_fds ();
- #endif
- #ifdef __UCLIBC_HAS_LOCALE__
- /* Initialize the global locale structure. */
- if (likely(_locale_init!=NULL)) _locale_init();
- #endif
- /*
- * Initialize stdio here. In the static library case, this will
- * be bypassed if not needed because of the weak alias above.
- */
- if (likely(_stdio_init != NULL))
- _stdio_init();
- /* Arrange for dtors to run at exit. */
- if (unlikely(_fini!=NULL && atexit)) {
- atexit (&_fini);
- }
- /* Run all ctors now. */
- if (unlikely(_init!=NULL))
- _init();
- /*
- * Note: It is possible that any initialization done above could
- * have resulted in errno being set nonzero, so set it to 0 before
- * we call main.
- */
- if (likely(__errno_location!=NULL))
- *(__errno_location()) = 0;
- /* Set h_errno to 0 as well */
- if (likely(__h_errno_location!=NULL))
- *(__h_errno_location()) = 0;
- /*
- * Finally, invoke application's main and then exit.
- */
- exit(main(argc, argv, envp));
- }
|