X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=src%2Fexit%2Fexit.c;h=bf7835a15cd2d3ecf9d7d7c7e8e1dc25a62d2806;hb=2fae10f887b48b809bac56e4ff8a5c3fd4525de3;hp=b391f33871a86473dc8acd3228b2c5f1a1e0a0db;hpb=ad1cd43a86645ba2d4f7c8747240452a349d6bc1;p=musl diff --git a/src/exit/exit.c b/src/exit/exit.c index b391f338..bf7835a1 100644 --- a/src/exit/exit.c +++ b/src/exit/exit.c @@ -10,17 +10,17 @@ static void dummy() * as a consequence of linking either __toread.c or __towrite.c. */ weak_alias(dummy, __funcs_on_exit); weak_alias(dummy, __stdio_exit); +weak_alias(dummy, _fini); -extern void _fini() __attribute__((weak)); -extern void (*const __fini_array_start)() __attribute__((weak)); -extern void (*const __fini_array_end)() __attribute__((weak)); +__attribute__((__weak__, __visibility__("hidden"))) +extern void (*const __fini_array_start)(void), (*const __fini_array_end)(void); static void libc_exit_fini(void) { uintptr_t a = (uintptr_t)&__fini_array_end; for (; a>(uintptr_t)&__fini_array_start; a-=sizeof(void(*)())) (*(void (**)())(a-sizeof(void(*)())))(); - if (_fini) _fini(); + _fini(); } weak_alias(libc_exit_fini, __libc_exit_fini);