* commit '261ebb63478e5d30cc3da6c3f37a1ae3e08551da': Call __cxa_thread_finalize for the main thread.
This commit is contained in:
commit
9e66105685
3 changed files with 33 additions and 3 deletions
|
@ -63,6 +63,7 @@ libc_common_src_files := \
|
|||
stdio/sprintf.c \
|
||||
stdio/stdio.c \
|
||||
stdio/stdio_ext.cpp \
|
||||
stdlib/exit.c \
|
||||
|
||||
# Fortify implementations of libc functions.
|
||||
libc_common_src_files += \
|
||||
|
@ -480,7 +481,6 @@ libc_upstream_openbsd_ndk_src_files := \
|
|||
upstream-openbsd/lib/libc/stdlib/atoi.c \
|
||||
upstream-openbsd/lib/libc/stdlib/atol.c \
|
||||
upstream-openbsd/lib/libc/stdlib/atoll.c \
|
||||
upstream-openbsd/lib/libc/stdlib/exit.c \
|
||||
upstream-openbsd/lib/libc/stdlib/getenv.c \
|
||||
upstream-openbsd/lib/libc/stdlib/insque.c \
|
||||
upstream-openbsd/lib/libc/stdlib/lsearch.c \
|
||||
|
|
|
@ -32,8 +32,6 @@
|
|||
#include <sys/mman.h>
|
||||
#include <stdlib.h>
|
||||
#include <unistd.h>
|
||||
#include "atexit.h"
|
||||
#include "thread_private.h"
|
||||
|
||||
/*
|
||||
* This variable is zero until a process has created a thread.
|
||||
|
@ -44,12 +42,21 @@
|
|||
*/
|
||||
int __isthreaded = 0;
|
||||
|
||||
/* BEGIN android-added: using __cxa_finalize and __cxa_thread_finalize */
|
||||
extern void __cxa_finalize(void* dso_handle);
|
||||
extern void __cxa_thread_finalize();
|
||||
/* END android-added */
|
||||
|
||||
/*
|
||||
* Exit, flushing stdio buffers if necessary.
|
||||
*/
|
||||
void
|
||||
exit(int status)
|
||||
{
|
||||
/* BEGIN android-added: call thread_local d-tors */
|
||||
__cxa_thread_finalize();
|
||||
/* END android-added */
|
||||
|
||||
/*
|
||||
* Call functions registered by atexit() or _cxa_atexit()
|
||||
* (including the stdio cleanup routine) and then _exit().
|
|
@ -50,6 +50,29 @@ TEST(thread_local, smoke) {
|
|||
ASSERT_EQ("dtor called.", class_with_dtor_output);
|
||||
}
|
||||
|
||||
class ClassWithDtorForMainThread {
|
||||
public:
|
||||
void set_message(const std::string& msg) {
|
||||
message = msg;
|
||||
}
|
||||
|
||||
~ClassWithDtorForMainThread() {
|
||||
fprintf(stderr, "%s", message.c_str());
|
||||
}
|
||||
private:
|
||||
std::string message;
|
||||
};
|
||||
|
||||
static void thread_atexit_main() {
|
||||
static thread_local ClassWithDtorForMainThread class_with_dtor_for_main_thread;
|
||||
class_with_dtor_for_main_thread.set_message("d-tor for main thread called.");
|
||||
exit(0);
|
||||
}
|
||||
|
||||
TEST(thread_local, dtor_for_main_thread) {
|
||||
ASSERT_EXIT(thread_atexit_main(), testing::ExitedWithCode(0), "d-tor for main thread called.");
|
||||
}
|
||||
|
||||
extern "C" int __cxa_thread_atexit_impl(void (*fn)(void*), void* arg, void* dso_handle);
|
||||
|
||||
static void thread_atexit_fn1(void* arg) {
|
||||
|
|
Loading…
Reference in a new issue