X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=src%2Fexit%2Fexit.c;h=a6869b37594ea06585bdbffd5bb4e0e52c956234;hb=0847902ab99065a48f9bd3729b6e676288dfd69e;hp=27fb3e292d756e13d73466ed87607da4d5933f5e;hpb=c463e11eda8326aacee2ac1d516954a9574a2dcd;p=musl diff --git a/src/exit/exit.c b/src/exit/exit.c index 27fb3e29..a6869b37 100644 --- a/src/exit/exit.c +++ b/src/exit/exit.c @@ -10,26 +10,24 @@ 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); - -#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) -{ - __funcs_on_exit(); +extern weak hidden void (*const __fini_array_start)(void), (*const __fini_array_end)(void); -#ifndef SHARED +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(*)())))(); _fini(); -#endif +} - __stdio_exit(); +weak_alias(libc_exit_fini, __libc_exit_fini); +_Noreturn void exit(int code) +{ + __funcs_on_exit(); + __libc_exit_fini(); + __stdio_exit(); _Exit(code); - for(;;); }