1*b585cd3eSKonstantin Belousov /*-
2*b585cd3eSKonstantin Belousov * Copyright (c) 2016 Mahdi Mokhtari <mokhi64@gmail.com>
3*b585cd3eSKonstantin Belousov * Copyright (c) 2016 The FreeBSD Foundation
4*b585cd3eSKonstantin Belousov * All rights reserved.
5*b585cd3eSKonstantin Belousov *
6*b585cd3eSKonstantin Belousov * Redistribution and use in source and binary forms, with or without
7*b585cd3eSKonstantin Belousov * modification, are permitted provided that the following conditions
8*b585cd3eSKonstantin Belousov * are met:
9*b585cd3eSKonstantin Belousov * 1. Redistributions of source code must retain the above copyright
10*b585cd3eSKonstantin Belousov * notice, this list of conditions and the following disclaimer.
11*b585cd3eSKonstantin Belousov * 2. Redistributions in binary form must reproduce the above copyright
12*b585cd3eSKonstantin Belousov * notice, this list of conditions and the following disclaimer in the
13*b585cd3eSKonstantin Belousov * documentation and/or other materials provided with the distribution.
14*b585cd3eSKonstantin Belousov *
15*b585cd3eSKonstantin Belousov * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
16*b585cd3eSKonstantin Belousov * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
17*b585cd3eSKonstantin Belousov * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
18*b585cd3eSKonstantin Belousov * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
19*b585cd3eSKonstantin Belousov * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
20*b585cd3eSKonstantin Belousov * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
21*b585cd3eSKonstantin Belousov * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
22*b585cd3eSKonstantin Belousov * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
23*b585cd3eSKonstantin Belousov * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
24*b585cd3eSKonstantin Belousov * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
25*b585cd3eSKonstantin Belousov * SUCH DAMAGE.
26*b585cd3eSKonstantin Belousov */
27*b585cd3eSKonstantin Belousov
28*b585cd3eSKonstantin Belousov #include <dlfcn.h>
29*b585cd3eSKonstantin Belousov #include <atf-c++.hpp>
30*b585cd3eSKonstantin Belousov #include <cstdio>
31*b585cd3eSKonstantin Belousov #include <cstdlib>
32*b585cd3eSKonstantin Belousov
33*b585cd3eSKonstantin Belousov static FILE *output = NULL;
34*b585cd3eSKonstantin Belousov
35*b585cd3eSKonstantin Belousov struct Foo {
FooFoo36*b585cd3eSKonstantin Belousov Foo() { ATF_REQUIRE(fprintf(output, "Created\n") > 0); }
~FooFoo37*b585cd3eSKonstantin Belousov ~Foo() { ATF_REQUIRE(fprintf(output, "Destroyed\n") > 0); }
useFoo38*b585cd3eSKonstantin Belousov void use() { ATF_REQUIRE(fprintf(output, "Used\n") > 0); }
39*b585cd3eSKonstantin Belousov };
40*b585cd3eSKonstantin Belousov
41*b585cd3eSKonstantin Belousov static thread_local Foo f;
42*b585cd3eSKonstantin Belousov
43*b585cd3eSKonstantin Belousov /*
44*b585cd3eSKonstantin Belousov * This test must not be linked to libpthread.
45*b585cd3eSKonstantin Belousov */
46*b585cd3eSKonstantin Belousov ATF_TEST_CASE_WITHOUT_HEAD(cxx__nothr);
ATF_TEST_CASE_BODY(cxx__nothr)47*b585cd3eSKonstantin Belousov ATF_TEST_CASE_BODY(cxx__nothr)
48*b585cd3eSKonstantin Belousov {
49*b585cd3eSKonstantin Belousov void *libthr_handle;
50*b585cd3eSKonstantin Belousov
51*b585cd3eSKonstantin Belousov /* Avoid coredump during f construction. */
52*b585cd3eSKonstantin Belousov output = stderr;
53*b585cd3eSKonstantin Belousov
54*b585cd3eSKonstantin Belousov libthr_handle = dlopen("libthr.so.3", RTLD_LAZY | RTLD_GLOBAL |
55*b585cd3eSKonstantin Belousov RTLD_NOLOAD);
56*b585cd3eSKonstantin Belousov ATF_REQUIRE(libthr_handle == NULL);
57*b585cd3eSKonstantin Belousov }
58*b585cd3eSKonstantin Belousov
59*b585cd3eSKonstantin Belousov static void
check_local_main(void)60*b585cd3eSKonstantin Belousov check_local_main(void)
61*b585cd3eSKonstantin Belousov {
62*b585cd3eSKonstantin Belousov static const char out_log[] = "Created\nUsed\nDestroyed\n";
63*b585cd3eSKonstantin Belousov
64*b585cd3eSKonstantin Belousov fflush(output);
65*b585cd3eSKonstantin Belousov ATF_REQUIRE(atf::utils::compare_file("test_main.txt", out_log));
66*b585cd3eSKonstantin Belousov }
67*b585cd3eSKonstantin Belousov
68*b585cd3eSKonstantin Belousov ATF_TEST_CASE_WITHOUT_HEAD(cxx__thread_local_main);
ATF_TEST_CASE_BODY(cxx__thread_local_main)69*b585cd3eSKonstantin Belousov ATF_TEST_CASE_BODY(cxx__thread_local_main)
70*b585cd3eSKonstantin Belousov {
71*b585cd3eSKonstantin Belousov
72*b585cd3eSKonstantin Belousov ATF_REQUIRE((output = fopen("test_main.txt", "w")) != NULL);
73*b585cd3eSKonstantin Belousov f.use();
74*b585cd3eSKonstantin Belousov atexit(check_local_main);
75*b585cd3eSKonstantin Belousov }
76*b585cd3eSKonstantin Belousov
77*b585cd3eSKonstantin Belousov extern "C" int __cxa_thread_atexit(void (*)(void *), void *, void *);
78*b585cd3eSKonstantin Belousov
79*b585cd3eSKonstantin Belousov static void
again(void * arg)80*b585cd3eSKonstantin Belousov again(void *arg)
81*b585cd3eSKonstantin Belousov {
82*b585cd3eSKonstantin Belousov
83*b585cd3eSKonstantin Belousov __cxa_thread_atexit(again, arg, &output);
84*b585cd3eSKonstantin Belousov }
85*b585cd3eSKonstantin Belousov
86*b585cd3eSKonstantin Belousov ATF_TEST_CASE_WITHOUT_HEAD(cxx__thread_inf_dtors);
ATF_TEST_CASE_BODY(cxx__thread_inf_dtors)87*b585cd3eSKonstantin Belousov ATF_TEST_CASE_BODY(cxx__thread_inf_dtors)
88*b585cd3eSKonstantin Belousov {
89*b585cd3eSKonstantin Belousov
90*b585cd3eSKonstantin Belousov again(NULL);
91*b585cd3eSKonstantin Belousov }
92*b585cd3eSKonstantin Belousov
ATF_INIT_TEST_CASES(tcs)93*b585cd3eSKonstantin Belousov ATF_INIT_TEST_CASES(tcs)
94*b585cd3eSKonstantin Belousov {
95*b585cd3eSKonstantin Belousov
96*b585cd3eSKonstantin Belousov ATF_ADD_TEST_CASE(tcs, cxx__nothr);
97*b585cd3eSKonstantin Belousov ATF_ADD_TEST_CASE(tcs, cxx__thread_local_main);
98*b585cd3eSKonstantin Belousov ATF_ADD_TEST_CASE(tcs, cxx__thread_inf_dtors);
99*b585cd3eSKonstantin Belousov }
100