1 /* Copyright (C) 2009-2022 Free Software Foundation, Inc.
2    This file is part of the GNU C Library.
3 
4    The GNU C Library is free software; you can redistribute it and/or
5    modify it under the terms of the GNU Lesser General Public
6    License as published by the Free Software Foundation; either
7    version 2.1 of the License, or (at your option) any later version.
8 
9    The GNU C Library is distributed in the hope that it will be useful,
10    but WITHOUT ANY WARRANTY; without even the implied warranty of
11    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
12    Lesser General Public License for more details.
13 
14    You should have received a copy of the GNU Lesser General Public
15    License along with the GNU C Library; if not, see
16    <https://www.gnu.org/licenses/>.  */
17 
18 #include <stdio.h>
19 #include <stdlib.h>
20 #include <unistd.h>
21 #include <sysdep.h>
22 #include <signal.h>
23 #include <errno.h>
24 #include <shlib-compat.h>
25 #include "exit.h"
26 
27 void
__new_quick_exit(int status)28 __new_quick_exit (int status)
29 {
30   /* The new quick_exit, following C++11 18.5.12, does not run object
31      destructors.   While C11 says nothing about object destructors,
32      since it has none, the intent is to run the registered
33      at_quick_exit handlers and then run _Exit immediately without
34      disturbing the state of the process and threads.  */
35   __run_exit_handlers (status, &__quick_exit_funcs, false, false);
36 }
37 versioned_symbol (libc, __new_quick_exit, quick_exit, GLIBC_2_24);
38 
39 #if SHLIB_COMPAT(libc, GLIBC_2_10, GLIBC_2_24)
40 void
41 attribute_compat_text_section
__old_quick_exit(int status)42 __old_quick_exit (int status)
43 {
44   /* The old quick_exit runs thread_local destructors.  */
45   __run_exit_handlers (status, &__quick_exit_funcs, false, true);
46 }
47 compat_symbol (libc, __old_quick_exit, quick_exit, GLIBC_2_10);
48 #endif
49