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;
__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;
+#ifndef SHARED
__init_libc(envp, argv[0]);
-
- libc.ldso_fini = ldso_fini;
- libc.fini = fini;
-
- /* Execute constructors (static) linked into the application */
- if (init) init(argc, argv, envp);
-
-#ifdef SHARED
- __init_ldso_ctors();
+ _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 */
weak_alias(dummy, __flush_on_exit);
weak_alias(dummy, __seek_on_exit);
+#ifndef SHARED
+weak_alias(dummy, _fini);
+extern void (*const __fini_array_start)() __attribute__((weak));
+extern void (*const __fini_array_end)() __attribute__((weak));
+#endif
+
_Noreturn void exit(int code)
{
static int lock;
while (a_swap(&lock, 1)) __syscall(SYS_pause);
__funcs_on_exit();
- if (libc.fini) libc.fini();
- if (libc.ldso_fini) libc.ldso_fini();
+
+#ifndef SHARED
+ uintptr_t a = (uintptr_t)&__fini_array_end;
+ for (; a>(uintptr_t)&__fini_array_start; a-=sizeof(void(*)()))
+ (*(void (**)())(a-sizeof(void(*)())))();
+ _fini();
+#endif
+
__flush_on_exit();
__seek_on_exit();
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;
void __init_ssp(size_t *);
void *__install_initial_tls(void *);
+void __init_libc(char **, char *);
static struct dso *head, *tail, *ldso, *fini_head;
static char *env_path, *sys_path, *r_path;
char *env_preload=0;
size_t vdso_base;
size_t *auxv;
+ char **envp = argv+argc+1;
/* Find aux vector just past environ[] */
for (i=argc+1; argv[i]; i++)
tls_align = MAXP2(tls_align, app->tls_align);
}
app->global = 1;
- app->constructed = 1;
decode_dyn(app);
/* Attach to vdso, if provided by the kernel */
_dl_debug_state();
if (ssp_used) __init_ssp((void *)aux[AT_RANDOM]);
-
- errno = 0;
- return (void *)aux[AT_ENTRY];
-}
-
-void __init_ldso_ctors(void)
-{
+ __init_libc(envp, argv[0]);
atexit(do_fini);
+ errno = 0;
do_init_fini(tail);
+
+ return (void *)aux[AT_ENTRY];
}
void *dlopen(const char *file, int mode)