X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=src%2Fenv%2F__libc_start_main.c;h=2a8698bb19439809a7acc469caa6e2656c90a58c;hb=b5e409df70ff83f45b0e6f460b07e791c8d51c76;hp=ee10b0ded6753686c08c2ff72a4fe1b1cd714435;hpb=12e9b4faf68a1a02ebf5ad69c03ac10f170f14cb;p=musl diff --git a/src/env/__libc_start_main.c b/src/env/__libc_start_main.c index ee10b0de..2a8698bb 100644 --- a/src/env/__libc_start_main.c +++ b/src/env/__libc_start_main.c @@ -3,12 +3,21 @@ void __init_tls(size_t *); void __init_security(size_t *); +void __init_ldso_ctors(void); + +#ifndef SHARED +static void dummy() {} +weak_alias(dummy, _init); +extern void (*const __init_array_start)() __attribute__((weak)); +extern void (*const __init_array_end)() __attribute__((weak)); +#endif #define AUX_CNT 38 extern size_t __hwcap, __sysinfo; +extern char *__progname, *__progname_full; -void __init_libc(char **envp) +void __init_libc(char **envp, char *pn) { size_t i, *auxv, aux[AUX_CNT] = { 0 }; __environ = envp; @@ -18,24 +27,26 @@ void __init_libc(char **envp) __hwcap = aux[AT_HWCAP]; __sysinfo = aux[AT_SYSINFO]; + if (pn) { + __progname = __progname_full = pn; + for (i=0; pn[i]; i++) if (pn[i]=='/') __progname = pn+i+1; + } + __init_tls(aux); __init_security(aux); } -int __libc_start_main( - int (*main)(int, char **, char **), int argc, char **argv, - int (*init)(int, char **, char **), void (*fini)(void), - void (*ldso_fini)(void)) +int __libc_start_main(int (*main)(int,char **,char **), int argc, char **argv) { char **envp = argv+argc+1; - __init_libc(envp); - - libc.ldso_fini = ldso_fini; - libc.fini = fini; - - /* Execute constructors (static) linked into the application */ - if (init) init(argc, argv, envp); +#ifndef SHARED + __init_libc(envp, argv[0]); + _init(); + uintptr_t a = (uintptr_t)&__init_array_start; + for (; a<(uintptr_t)&__init_array_end; a+=sizeof(void(*)())) + (*(void (**)())a)(); +#endif /* Pass control to to application */ exit(main(argc, argv, envp));