Make atexit.dlclose work for glibc
* build libtest_atexit.so * remove atexit(NULL) - glibc segfaults on it Bug: 15350494 Change-Id: I27d79130c32c5691b0e8790a57d92f9710f5bf4a
This commit is contained in:
parent
66b5e6b609
commit
214e64135e
@ -312,8 +312,10 @@ libtest_atexit_src_files := \
|
||||
atexit_testlib.cpp
|
||||
|
||||
module := libtest_atexit
|
||||
build_type := target
|
||||
build_target := SHARED_LIBRARY
|
||||
build_type := target
|
||||
include $(LOCAL_PATH)/Android.build.mk
|
||||
build_type := host
|
||||
include $(LOCAL_PATH)/Android.build.mk
|
||||
|
||||
# -----------------------------------------------------------------------------
|
||||
|
@ -25,7 +25,6 @@
|
||||
#include <string>
|
||||
|
||||
TEST(atexit, dlclose) {
|
||||
#if defined(__BIONIC__)
|
||||
std::string atexit_call_sequence;
|
||||
bool valid_this_in_static_dtor = false;
|
||||
void* handle = dlopen("libtest_atexit.so", RTLD_NOW);
|
||||
@ -39,9 +38,6 @@ TEST(atexit, dlclose) {
|
||||
// this test verifies atexit call from atexit handler. as well as the order of calls
|
||||
ASSERT_EQ("Humpty Dumpty sat on a wall", atexit_call_sequence);
|
||||
ASSERT_TRUE(valid_this_in_static_dtor);
|
||||
#else // __BIONIC__
|
||||
GTEST_LOG_(INFO) << "This test does nothing.";
|
||||
#endif // __BIONIC__
|
||||
}
|
||||
|
||||
class TestMainStaticDtorClass {
|
||||
|
@ -71,6 +71,5 @@ extern "C" void register_atexit(std::string* sequence, bool* valid_this_in_stati
|
||||
atexit_valid_this_in_static_dtor = valid_this_in_static_dtor;
|
||||
atexit(atexit_handler_regular);
|
||||
atexit(atexit_handler_with_atexit);
|
||||
atexit(NULL);
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user