mirror of git://sourceware.org/git/glibc.git
In C++11 18.5.12 says "Objects shall not be destroyed as a result of calling quick_exit." In C11 quick_exit is silent about thread object destruction. Therefore to make glibc C++ compliant we do not call any thread local destructors. A new regression test verifies the fix. I will note that C++11 18.5.3 makes it clear that C++ defines additional requirements for _Exit() to prevent it from executing destructors. Given that the point of _Exit() is to terminate the process immediately it makes sense the C and C++ should line up and avoid calling destructors. No failures. New regtest passes. |
||
---|---|---|
.. | ||
bits | ||
sys | ||
Implies | ||
Makefile | ||
Versions | ||
arch-fork.h | ||
atomic-machine.h | ||
c++-types.data | ||
cacheflush.c | ||
clone.S | ||
configure | ||
configure.ac | ||
getcontext.S | ||
kernel_rt_sigframe.h | ||
ld.abilist | ||
libBrokenLocale.abilist | ||
libanl.abilist | ||
libc.abilist | ||
libcrypt.abilist | ||
libdl.abilist | ||
libm.abilist | ||
libnsl.abilist | ||
libpthread.abilist | ||
libresolv.abilist | ||
librt.abilist | ||
libthread_db.abilist | ||
libutil.abilist | ||
localplt.data | ||
makecontext.c | ||
profil-counter.h | ||
setcontext.S | ||
shlib-versions | ||
sigcontextinfo.h | ||
swapcontext.S | ||
syscall.S | ||
sysdep-cancel.h | ||
sysdep.S | ||
sysdep.h | ||
ucontext_i.sym | ||
vfork.S |