X-Git-Url: https://git.saurik.com/apple/libc.git/blobdiff_plain/1f2f436a38f7ae2d39a943ad2898d8fed4ed2e58..e07eda1a0324f771bb1ed20ef94f3229005ee46c:/stdlib/FreeBSD/exit.c?ds=sidebyside diff --git a/stdlib/FreeBSD/exit.c b/stdlib/FreeBSD/exit.c index 8449600..ba66bc6 100644 --- a/stdlib/FreeBSD/exit.c +++ b/stdlib/FreeBSD/exit.c @@ -41,31 +41,25 @@ __FBSDID("$FreeBSD: src/lib/libc/stdlib/exit.c,v 1.9 2007/01/09 00:28:09 imp Exp #include "atexit.h" #include "libc_private.h" -void (*__cleanup)(void); +#include -/* - * This variable is zero until a process has created a thread. - * It is used to avoid calling locking functions in libc when they - * are not required. By default, libc is intended to be(come) - * thread-safe, but without a (significant) penalty to non-threaded - * processes. - */ -int __isthreaded = 0; +void (*__cleanup)(void); +extern void __exit(int) __attribute__((noreturn)); +#if !TARGET_IPHONE_SIMULATOR && (__i386__ || __x86_64__) +extern void _tlv_exit(); +#endif /* * Exit, flushing stdio buffers if necessary. */ void -exit(status) - int status; +exit(int status) { - /* Ensure that the auto-initialization routine is linked in: */ - extern int _thread_autoinit_dummy_decl; - - _thread_autoinit_dummy_decl = 1; - +#if !TARGET_IPHONE_SIMULATOR && (__i386__ || __x86_64__) + _tlv_exit(); // C++11 requires thread_local objects to be destroyed before global objects +#endif __cxa_finalize(NULL); if (__cleanup) (*__cleanup)(); - _exit(status); + __exit(status); }