X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=src%2Fenv%2F__libc_start_main.c;h=aef9f9ec72c6032f273309e111bc7c2b307310cd;hb=6d861ac87491a207e4599c44b61d142f0a601c2d;hp=ee10b0ded6753686c08c2ff72a4fe1b1cd714435;hpb=12e9b4faf68a1a02ebf5ad69c03ac10f170f14cb;p=musl diff --git a/src/env/__libc_start_main.c b/src/env/__libc_start_main.c index ee10b0de..aef9f9ec 100644 --- a/src/env/__libc_start_main.c +++ b/src/env/__libc_start_main.c @@ -3,12 +3,14 @@ void __init_tls(size_t *); void __init_security(size_t *); +void __init_ldso_ctors(void); #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,6 +20,11 @@ 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); } @@ -29,7 +36,7 @@ int __libc_start_main( { char **envp = argv+argc+1; - __init_libc(envp); + __init_libc(envp, argv[0]); libc.ldso_fini = ldso_fini; libc.fini = fini; @@ -37,6 +44,10 @@ int __libc_start_main( /* Execute constructors (static) linked into the application */ if (init) init(argc, argv, envp); +#ifdef SHARED + __init_ldso_ctors(); +#endif + /* Pass control to to application */ exit(main(argc, argv, envp)); return 0;