1 // SPDX-License-Identifier: GPL-2.0-or-later
2 /*
3 * Copyright (c) 2016 Oracle and/or its affiliates. All Rights Reserved.
4 */
5
6 #include <pthread.h>
7 #include <stdio.h>
8
9 #define TST_NO_DEFAULT_MAIN
10 #include "tst_test.h"
11
safe_pthread_create(const char * file,const int lineno,pthread_t * thread_id,const pthread_attr_t * attr,void * (* thread_fn)(void *),void * arg)12 int safe_pthread_create(const char *file, const int lineno,
13 pthread_t *thread_id, const pthread_attr_t *attr,
14 void *(*thread_fn)(void *), void *arg)
15 {
16 int rval;
17
18 rval = pthread_create(thread_id, attr, thread_fn, arg);
19
20 if (rval) {
21 tst_brk_(file, lineno, TBROK,
22 "pthread_create(%p,%p,%p,%p) failed: %s", thread_id,
23 attr, thread_fn, arg, tst_strerrno(rval));
24 }
25
26 return rval;
27 }
28
safe_pthread_join(const char * file,const int lineno,pthread_t thread_id,void ** retval)29 int safe_pthread_join(const char *file, const int lineno,
30 pthread_t thread_id, void **retval)
31 {
32 int rval;
33
34 rval = pthread_join(thread_id, retval);
35
36 if (rval) {
37 tst_brk_(file, lineno, TBROK,
38 "pthread_join(..., %p) failed: %s",
39 retval, tst_strerrno(rval));
40 }
41
42 return rval;
43 }
44
safe_pthread_barrier_wait(const char * file,const int lineno,pthread_barrier_t * barrier)45 int safe_pthread_barrier_wait(const char *file, const int lineno,
46 pthread_barrier_t *barrier)
47 {
48 int rval;
49
50 rval = pthread_barrier_wait(barrier);
51
52 if (rval && rval != PTHREAD_BARRIER_SERIAL_THREAD) {
53 tst_brk_(file, lineno, TBROK,
54 "pthread_barrier_wait(%p) failed: %s",
55 barrier, tst_strerrno(rval));
56 }
57
58 return rval;
59 }
60
safe_pthread_barrier_destroy(const char * file,const int lineno,pthread_barrier_t * barrier)61 int safe_pthread_barrier_destroy(const char *file, const int lineno,
62 pthread_barrier_t *barrier)
63 {
64 int rval;
65
66 rval = pthread_barrier_destroy(barrier);
67
68 if (rval) {
69 tst_brk_(file, lineno, TBROK,
70 "pthread_barrier_destroy(%p) failed: %s",
71 barrier, tst_strerrno(rval));
72 }
73
74 return rval;
75 }
76
safe_pthread_cancel(const char * file,const int lineno,pthread_t thread_id)77 int safe_pthread_cancel(const char *file, const int lineno,
78 pthread_t thread_id)
79 {
80 int rval;
81
82 rval = pthread_cancel(thread_id);
83
84 if (rval) {
85 tst_brk_(file, lineno, TBROK,
86 "pthread_cancel(...) failed: %s", tst_strerrno(rval));
87 }
88
89 return rval;
90 }
91
safe_pthread_barrier_init(const char * file,const int lineno,pthread_barrier_t * barrier,const pthread_barrierattr_t * attr,unsigned count)92 int safe_pthread_barrier_init(const char *file, const int lineno,
93 pthread_barrier_t *barrier,
94 const pthread_barrierattr_t *attr,
95 unsigned count)
96 {
97 int rval;
98
99 rval = pthread_barrier_init(barrier, attr, count);
100
101 if (rval) {
102 tst_brk_(file, lineno, TBROK,
103 "pthread_barrier_init(%p, %p, %u)failed: %s",
104 barrier, attr, count, tst_strerrno(rval));
105 }
106
107 return rval;
108 }
109
safe_pthread_mutexattr_init(const char * file,const int lineno,pthread_mutexattr_t * attr)110 int safe_pthread_mutexattr_init(const char *file, const int lineno,
111 pthread_mutexattr_t *attr)
112 {
113 int ret;
114
115 ret = pthread_mutexattr_init(attr);
116
117 if (ret) {
118 tst_brk_(file, lineno, TBROK,
119 "pthread_mutexattr_init(%p) failed: %s",
120 attr, tst_strerrno(ret));
121 }
122
123 return ret;
124 }
125
safe_pthread_mutexattr_destroy(const char * file,const int lineno,pthread_mutexattr_t * attr)126 int safe_pthread_mutexattr_destroy(const char *file, const int lineno,
127 pthread_mutexattr_t *attr)
128 {
129 int ret;
130
131 ret = pthread_mutexattr_destroy(attr);
132
133 if (ret) {
134 tst_brk_(file, lineno, TBROK,
135 "pthread_mutexattr_destroy(%p) failed: %s",
136 attr, tst_strerrno(ret));
137 }
138
139 return ret;
140 }
141
safe_pthread_mutexattr_settype(const char * file,const int lineno,pthread_mutexattr_t * attr,int type)142 int safe_pthread_mutexattr_settype(const char *file, const int lineno,
143 pthread_mutexattr_t *attr, int type)
144 {
145 int ret;
146
147 ret = pthread_mutexattr_settype(attr, type);
148
149 if (ret) {
150 tst_brk_(file, lineno, TBROK,
151 "pthread_mutexattr_settype(%p, %d) failed: %s",
152 attr, type, tst_strerrno(ret));
153 }
154
155 return ret;
156 }
157
safe_pthread_mutex_init(const char * file,const int lineno,pthread_mutex_t * mutex,const pthread_mutexattr_t * attr)158 int safe_pthread_mutex_init(const char *file, const int lineno,
159 pthread_mutex_t *mutex, const pthread_mutexattr_t *attr)
160 {
161 int ret;
162
163 ret = pthread_mutex_init(mutex, attr);
164
165 if (ret) {
166 tst_brk_(file, lineno, TBROK,
167 "pthread_mutex_init(%p, %p) failed: %s",
168 mutex, attr, tst_strerrno(ret));
169 }
170
171 return ret;
172 }
173
safe_pthread_mutex_destroy(const char * file,const int lineno,pthread_mutex_t * mutex)174 int safe_pthread_mutex_destroy(const char *file, const int lineno,
175 pthread_mutex_t *mutex)
176 {
177 int ret;
178
179 ret = pthread_mutex_destroy(mutex);
180
181 if (ret) {
182 tst_brk_(file, lineno, TBROK,
183 "pthread_mutex_destroy(%p) failed: %s",
184 mutex, tst_strerrno(ret));
185 }
186
187 return ret;
188 }
189
safe_pthread_mutex_lock(const char * file,const int lineno,pthread_mutex_t * mutex)190 int safe_pthread_mutex_lock(const char *file, const int lineno,
191 pthread_mutex_t *mutex)
192 {
193 int ret;
194
195 ret = pthread_mutex_lock(mutex);
196
197 if (ret) {
198 tst_brk_(file, lineno, TBROK,
199 "pthread_mutex_lock(%p) failed: %s",
200 mutex, tst_strerrno(ret));
201 }
202
203 return ret;
204 }
205
safe_pthread_mutex_trylock(const char * file,const int lineno,pthread_mutex_t * mutex)206 int safe_pthread_mutex_trylock(const char *file, const int lineno,
207 pthread_mutex_t *mutex)
208 {
209 int ret;
210
211 ret = pthread_mutex_trylock(mutex);
212
213 if (ret && ret != EBUSY) {
214 tst_brk_(file, lineno, TBROK,
215 "pthread_mutex_trylock(%p) failed: %s",
216 mutex, tst_strerrno(ret));
217 }
218
219 return ret;
220 }
221
safe_pthread_mutex_timedlock(const char * file,const int lineno,pthread_mutex_t * mutex,const struct timespec * abstime)222 int safe_pthread_mutex_timedlock(const char *file, const int lineno,
223 pthread_mutex_t *mutex, const struct timespec *abstime)
224 {
225 int ret;
226
227 ret = pthread_mutex_timedlock(mutex, abstime);
228
229 if (ret && ret != ETIMEDOUT) {
230 tst_brk_(file, lineno, TBROK,
231 "pthread_mutex_timedlock(%p, {%lld, %ld}) failed: %s",
232 mutex, (long long)abstime->tv_sec, abstime->tv_nsec,
233 tst_strerrno(ret));
234 }
235
236 return ret;
237 }
238
safe_pthread_mutex_unlock(const char * file,const int lineno,pthread_mutex_t * mutex)239 int safe_pthread_mutex_unlock(const char *file, const int lineno,
240 pthread_mutex_t *mutex)
241 {
242 int ret;
243
244 ret = pthread_mutex_unlock(mutex);
245
246 if (ret) {
247 tst_brk_(file, lineno, TBROK,
248 "pthread_mutex_unlock(%p) failed: %s",
249 mutex, tst_strerrno(ret));
250 }
251
252 return ret;
253 }
254
safe_pthread_kill(const char * file,const int lineno,pthread_t thread,int sig)255 int safe_pthread_kill(const char *file, const int lineno,
256 pthread_t thread, int sig)
257 {
258 int ret;
259
260 ret = pthread_kill(thread, sig);
261
262 if (ret) {
263 tst_brk_(file, lineno, TBROK,
264 "pthread_kill(..., %d) failed: %s",
265 sig, tst_strerrno(ret));
266 }
267
268 return ret;
269 }
270