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. |
||
---|---|---|
.. | ||
970 | ||
a2 | ||
cell | ||
fpu | ||
Implies | ||
Versions | ||
____longjmp_chk.S | ||
brk.S | ||
c++-types.data | ||
clone.S | ||
configure | ||
configure.ac | ||
dl-cache.h | ||
fcntl.c | ||
getcontext.S | ||
kernel_stat.h | ||
ld-le.abilist | ||
ld.abilist | ||
ldsodefs.h | ||
libBrokenLocale-le.abilist | ||
libBrokenLocale.abilist | ||
libanl-le.abilist | ||
libanl.abilist | ||
libc-le.abilist | ||
libc.abilist | ||
libcrypt-le.abilist | ||
libcrypt.abilist | ||
libdl-le.abilist | ||
libdl.abilist | ||
libm-le.abilist | ||
libm.abilist | ||
libnsl-le.abilist | ||
libnsl.abilist | ||
libpthread-le.abilist | ||
libpthread.abilist | ||
libresolv-le.abilist | ||
libresolv.abilist | ||
librt-le.abilist | ||
librt.abilist | ||
libthread_db-le.abilist | ||
libthread_db.abilist | ||
libutil-le.abilist | ||
libutil.abilist | ||
localplt.data | ||
makecontext.S | ||
setcontext.S | ||
shlib-versions | ||
swapcontext.S | ||
sync_file_range.c | ||
syscalls.list | ||
sysdep-cancel.h | ||
sysdep.h | ||
timer_create.c | ||
timer_delete.c | ||
timer_getoverr.c | ||
timer_gettime.c | ||
timer_settime.c | ||
ucontext_i.sym | ||
umount.c | ||
vfork.S |