t_tls_extern.c revision 1.4 1 1.4 riastrad /* $NetBSD: t_tls_extern.c,v 1.4 2023/06/01 20:50:18 riastradh Exp $ */
2 1.1 riastrad
3 1.1 riastrad /*-
4 1.1 riastrad * Copyright (c) 2023 The NetBSD Foundation, Inc.
5 1.1 riastrad * All rights reserved.
6 1.1 riastrad *
7 1.1 riastrad * Redistribution and use in source and binary forms, with or without
8 1.1 riastrad * modification, are permitted provided that the following conditions
9 1.1 riastrad * are met:
10 1.1 riastrad * 1. Redistributions of source code must retain the above copyright
11 1.1 riastrad * notice, this list of conditions and the following disclaimer.
12 1.1 riastrad * 2. Redistributions in binary form must reproduce the above copyright
13 1.1 riastrad * notice, this list of conditions and the following disclaimer in the
14 1.1 riastrad * documentation and/or other materials provided with the distribution.
15 1.1 riastrad *
16 1.1 riastrad * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
17 1.1 riastrad * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
18 1.1 riastrad * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
19 1.1 riastrad * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
20 1.1 riastrad * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
21 1.1 riastrad * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
22 1.1 riastrad * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
23 1.1 riastrad * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
24 1.1 riastrad * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
25 1.1 riastrad * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
26 1.1 riastrad * POSSIBILITY OF SUCH DAMAGE.
27 1.1 riastrad */
28 1.1 riastrad
29 1.1 riastrad #include <sys/types.h>
30 1.1 riastrad
31 1.1 riastrad #include <atf-c.h>
32 1.1 riastrad #include <dlfcn.h>
33 1.1 riastrad
34 1.2 riastrad #define ATF_REQUIRE_DL(x) ATF_REQUIRE_MSG(x, "%s: %s", #x, dlerror())
35 1.1 riastrad
36 1.4 riastrad ATF_TC(tls_extern_dynamic_defuse);
37 1.4 riastrad ATF_TC_HEAD(tls_extern_dynamic_defuse, tc)
38 1.4 riastrad {
39 1.4 riastrad atf_tc_set_md_var(tc, "descr", "extern __thread for dynamic TLS works,"
40 1.4 riastrad " loading def then use");
41 1.4 riastrad }
42 1.4 riastrad ATF_TC_BODY(tls_extern_dynamic_defuse, tc)
43 1.4 riastrad {
44 1.4 riastrad void *def, *use;
45 1.4 riastrad int *(*fdef)(void), *(*fuse)(void);
46 1.4 riastrad int *pdef, *puse;
47 1.4 riastrad
48 1.4 riastrad (void)dlerror();
49 1.4 riastrad
50 1.4 riastrad ATF_REQUIRE_DL(def = dlopen("libh_def_dynamic.so", 0));
51 1.4 riastrad ATF_REQUIRE_DL(use = dlopen("libh_use_dynamic.so", 0));
52 1.4 riastrad
53 1.4 riastrad ATF_REQUIRE_DL(fdef = dlsym(def, "fdef"));
54 1.4 riastrad ATF_REQUIRE_DL(fuse = dlsym(use, "fuse"));
55 1.4 riastrad
56 1.4 riastrad pdef = (*fdef)();
57 1.4 riastrad puse = (*fuse)();
58 1.4 riastrad ATF_CHECK_EQ_MSG(pdef, puse,
59 1.4 riastrad "%p in defining library != %p in using library",
60 1.4 riastrad pdef, puse);
61 1.4 riastrad }
62 1.4 riastrad
63 1.4 riastrad ATF_TC(tls_extern_dynamic_usedef);
64 1.4 riastrad ATF_TC_HEAD(tls_extern_dynamic_usedef, tc)
65 1.4 riastrad {
66 1.4 riastrad atf_tc_set_md_var(tc, "descr", "extern __thread for dynamic TLS works,"
67 1.4 riastrad " loading use then def");
68 1.4 riastrad }
69 1.4 riastrad ATF_TC_BODY(tls_extern_dynamic_usedef, tc)
70 1.4 riastrad {
71 1.4 riastrad void *def, *use;
72 1.4 riastrad int *(*fdef)(void), *(*fuse)(void);
73 1.4 riastrad int *pdef, *puse;
74 1.4 riastrad
75 1.4 riastrad (void)dlerror();
76 1.4 riastrad
77 1.4 riastrad ATF_REQUIRE_DL(use = dlopen("libh_use_dynamic.so", 0));
78 1.4 riastrad ATF_REQUIRE_DL(def = dlopen("libh_def_dynamic.so", 0));
79 1.4 riastrad
80 1.4 riastrad ATF_REQUIRE_DL(fdef = dlsym(def, "fdef"));
81 1.4 riastrad ATF_REQUIRE_DL(fuse = dlsym(use, "fuse"));
82 1.4 riastrad
83 1.4 riastrad pdef = (*fdef)();
84 1.4 riastrad puse = (*fuse)();
85 1.4 riastrad ATF_CHECK_EQ_MSG(pdef, puse,
86 1.4 riastrad "%p in defining library != %p in using library",
87 1.4 riastrad pdef, puse);
88 1.4 riastrad }
89 1.4 riastrad
90 1.4 riastrad ATF_TC(tls_extern_dynamic_usedefnoload);
91 1.4 riastrad ATF_TC_HEAD(tls_extern_dynamic_usedefnoload, tc)
92 1.4 riastrad {
93 1.4 riastrad atf_tc_set_md_var(tc, "descr", "extern __thread for dynamic TLS works,"
94 1.4 riastrad " loading use then def with RTLD_NOLOAD");
95 1.4 riastrad }
96 1.4 riastrad ATF_TC_BODY(tls_extern_dynamic_usedefnoload, tc)
97 1.4 riastrad {
98 1.4 riastrad void *def, *use;
99 1.4 riastrad int *(*fdef)(void), *(*fuse)(void);
100 1.4 riastrad int *pdef, *puse;
101 1.4 riastrad
102 1.4 riastrad (void)dlerror();
103 1.4 riastrad
104 1.4 riastrad ATF_REQUIRE_DL(use = dlopen("libh_use_dynamic.so", 0));
105 1.4 riastrad ATF_REQUIRE_DL(def = dlopen("libh_def_dynamic.so", RTLD_NOLOAD));
106 1.4 riastrad
107 1.4 riastrad ATF_REQUIRE_DL(fdef = dlsym(def, "fdef"));
108 1.4 riastrad ATF_REQUIRE_DL(fuse = dlsym(use, "fuse"));
109 1.4 riastrad
110 1.4 riastrad pdef = (*fdef)();
111 1.4 riastrad puse = (*fuse)();
112 1.4 riastrad ATF_CHECK_EQ_MSG(pdef, puse,
113 1.4 riastrad "%p in defining library != %p in using library",
114 1.4 riastrad pdef, puse);
115 1.4 riastrad }
116 1.4 riastrad
117 1.3 riastrad ATF_TC(tls_extern_static_defuse);
118 1.3 riastrad ATF_TC_HEAD(tls_extern_static_defuse, tc)
119 1.1 riastrad {
120 1.3 riastrad atf_tc_set_md_var(tc, "descr", "extern __thread for static TLS works,"
121 1.3 riastrad " loading def then use");
122 1.1 riastrad }
123 1.3 riastrad ATF_TC_BODY(tls_extern_static_defuse, tc)
124 1.1 riastrad {
125 1.1 riastrad void *def, *use;
126 1.1 riastrad int *(*fdef)(void), *(*fuse)(void);
127 1.1 riastrad int *pdef, *puse;
128 1.1 riastrad
129 1.1 riastrad (void)dlerror();
130 1.3 riastrad
131 1.3 riastrad ATF_REQUIRE_DL(def = dlopen("libh_def_static.so", 0));
132 1.3 riastrad ATF_REQUIRE_DL(use = dlopen("libh_use_static.so", 0));
133 1.3 riastrad
134 1.3 riastrad ATF_REQUIRE_DL(fdef = dlsym(def, "fdef"));
135 1.3 riastrad ATF_REQUIRE_DL(fuse = dlsym(use, "fuse"));
136 1.3 riastrad
137 1.3 riastrad pdef = (*fdef)();
138 1.3 riastrad puse = (*fuse)();
139 1.3 riastrad ATF_CHECK_EQ_MSG(pdef, puse,
140 1.3 riastrad "%p in defining library != %p in using library",
141 1.3 riastrad pdef, puse);
142 1.3 riastrad }
143 1.3 riastrad
144 1.3 riastrad ATF_TC(tls_extern_static_usedef);
145 1.3 riastrad ATF_TC_HEAD(tls_extern_static_usedef, tc)
146 1.3 riastrad {
147 1.3 riastrad atf_tc_set_md_var(tc, "descr", "extern __thread for static TLS works,"
148 1.3 riastrad " loading use then def");
149 1.3 riastrad }
150 1.3 riastrad ATF_TC_BODY(tls_extern_static_usedef, tc)
151 1.3 riastrad {
152 1.3 riastrad void *def, *use;
153 1.3 riastrad int *(*fdef)(void), *(*fuse)(void);
154 1.3 riastrad int *pdef, *puse;
155 1.3 riastrad
156 1.3 riastrad (void)dlerror();
157 1.3 riastrad
158 1.3 riastrad ATF_REQUIRE_DL(use = dlopen("libh_use_static.so", 0));
159 1.3 riastrad ATF_REQUIRE_DL(def = dlopen("libh_def_static.so", 0));
160 1.3 riastrad
161 1.3 riastrad ATF_REQUIRE_DL(fdef = dlsym(def, "fdef"));
162 1.3 riastrad ATF_REQUIRE_DL(fuse = dlsym(use, "fuse"));
163 1.3 riastrad
164 1.3 riastrad pdef = (*fdef)();
165 1.3 riastrad puse = (*fuse)();
166 1.3 riastrad atf_tc_expect_fail("PR toolchain/50277:"
167 1.3 riastrad " rtld relocation bug with thread local storage");
168 1.3 riastrad ATF_CHECK_EQ_MSG(pdef, puse,
169 1.3 riastrad "%p in defining library != %p in using library",
170 1.3 riastrad pdef, puse);
171 1.3 riastrad }
172 1.3 riastrad
173 1.3 riastrad ATF_TC(tls_extern_static_usedefnoload);
174 1.3 riastrad ATF_TC_HEAD(tls_extern_static_usedefnoload, tc)
175 1.3 riastrad {
176 1.3 riastrad atf_tc_set_md_var(tc, "descr", "extern __thread for static TLS works,"
177 1.3 riastrad " loading use then def with RTLD_NOLOAD");
178 1.3 riastrad }
179 1.3 riastrad ATF_TC_BODY(tls_extern_static_usedefnoload, tc)
180 1.3 riastrad {
181 1.3 riastrad void *def, *use;
182 1.3 riastrad int *(*fdef)(void), *(*fuse)(void);
183 1.3 riastrad int *pdef, *puse;
184 1.3 riastrad
185 1.3 riastrad (void)dlerror();
186 1.3 riastrad
187 1.2 riastrad ATF_REQUIRE_DL(use = dlopen("libh_use_static.so", 0));
188 1.2 riastrad ATF_REQUIRE_DL(def = dlopen("libh_def_static.so", RTLD_NOLOAD));
189 1.3 riastrad
190 1.2 riastrad ATF_REQUIRE_DL(fdef = dlsym(def, "fdef"));
191 1.2 riastrad ATF_REQUIRE_DL(fuse = dlsym(use, "fuse"));
192 1.1 riastrad
193 1.1 riastrad pdef = (*fdef)();
194 1.1 riastrad puse = (*fuse)();
195 1.1 riastrad atf_tc_expect_fail("PR toolchain/50277:"
196 1.1 riastrad " rtld relocation bug with thread local storage");
197 1.1 riastrad ATF_CHECK_EQ_MSG(pdef, puse,
198 1.1 riastrad "%p in defining library != %p in using library",
199 1.1 riastrad pdef, puse);
200 1.1 riastrad }
201 1.1 riastrad
202 1.1 riastrad ATF_TP_ADD_TCS(tp)
203 1.1 riastrad {
204 1.3 riastrad
205 1.4 riastrad ATF_TP_ADD_TC(tp, tls_extern_dynamic_defuse);
206 1.4 riastrad ATF_TP_ADD_TC(tp, tls_extern_dynamic_usedef);
207 1.4 riastrad ATF_TP_ADD_TC(tp, tls_extern_dynamic_usedefnoload);
208 1.3 riastrad ATF_TP_ADD_TC(tp, tls_extern_static_defuse);
209 1.3 riastrad ATF_TP_ADD_TC(tp, tls_extern_static_usedef);
210 1.3 riastrad ATF_TP_ADD_TC(tp, tls_extern_static_usedefnoload);
211 1.1 riastrad return atf_no_error();
212 1.1 riastrad }
213