X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=src%2Fexit%2Fexit.c;h=a6869b37594ea06585bdbffd5bb4e0e52c956234;hb=8ef9d46f4d0ff4f0073da6bee7ed0cb5f9035ead;hp=b391f33871a86473dc8acd3228b2c5f1a1e0a0db;hpb=ad1cd43a86645ba2d4f7c8747240452a349d6bc1;p=musl diff --git a/src/exit/exit.c b/src/exit/exit.c index b391f338..a6869b37 100644 --- a/src/exit/exit.c +++ b/src/exit/exit.c @@ -10,17 +10,16 @@ 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)); +extern weak hidden 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);