1 1.100 rillig # $NetBSD: Makefile,v 1.100 2025/04/07 16:07:05 rillig Exp $ 2 1.9 thorpej # 3 1.9 thorpej 4 1.90 christos NOSANITIZER= # defined 5 1.75 matt WARNS?= 5 6 1.85 pooka LIB= pthread 7 1.24 cl 8 1.9 thorpej .include <bsd.own.mk> 9 1.9 thorpej 10 1.95 brad USE_SHLIBDIR= yes 11 1.95 brad 12 1.55 mrg .if defined(PTHREAD_MACHINE_ARCH) && !empty(PTHREAD_MACHINE_ARCH) && \ 13 1.55 mrg exists(${.CURDIR}/arch/${PTHREAD_MACHINE_ARCH}) 14 1.55 mrg ARCHSUBDIR= ${PTHREAD_MACHINE_ARCH} 15 1.84 matt .elif defined(PTHREAD_MACHINE_CPU) && !empty(PTHREAD_MACHINE_CPU) && \ 16 1.84 matt exists(${.CURDIR}/arch/${PTHREAD_MACHINE_CPU}) 17 1.84 matt ARCHSUBDIR= ${PTHREAD_MACHINE_CPU} 18 1.55 mrg .elif exists(${.CURDIR}/arch/${MACHINE_ARCH}) 19 1.9 thorpej ARCHSUBDIR= ${MACHINE_ARCH} 20 1.98 rin .elif exists(${.CURDIR}/arch/${MACHINE_CPU}) 21 1.9 thorpej ARCHSUBDIR= ${MACHINE_CPU} 22 1.9 thorpej .else 23 1.9 thorpej .BEGIN: 24 1.10 thorpej @echo "WARNING: no ARCHSUBDIR for ${MACHINE_ARCH}/${MACHINE_CPU}; skipping..." 25 1.9 thorpej .endif 26 1.9 thorpej 27 1.10 thorpej INCS= pthread.h pthread_types.h pthread_queue.h 28 1.10 thorpej INCSDIR=/usr/include 29 1.10 thorpej 30 1.9 thorpej .if defined(ARCHSUBDIR) 31 1.9 thorpej 32 1.9 thorpej ARCHDIR= ${.CURDIR}/arch/${ARCHSUBDIR} 33 1.9 thorpej .PATH: ${ARCHDIR} 34 1.9 thorpej 35 1.99 riastrad EXPSYM_SRCS+= pthread_mi.expsym 36 1.99 riastrad . if ${MACHINE_ARCH} == "alpha" || ${MACHINE_ARCH} == "hppa" 37 1.99 riastrad # PTHREAD__ASM_RASOPS 38 1.99 riastrad EXPSYM_SRCS+= pthread_md.expsym 39 1.99 riastrad . else 40 1.99 riastrad # !PTHREAD__ASM_RASOPS 41 1.99 riastrad # XXX These really shouldn't be exported. 42 1.99 riastrad EXPSYM_SRCS+= pthread_ras.expsym 43 1.99 riastrad . endif 44 1.99 riastrad 45 1.99 riastrad LIB_EXPSYM= pthread.expsym 46 1.99 riastrad pthread.expsym: ${EXPSYM_SRCS} 47 1.99 riastrad ${_MKTARGET_CREATE} 48 1.99 riastrad LC_ALL=C sort -m ${.ALLSRC} >${.TARGET}.tmp && \ 49 1.99 riastrad ${MV} ${.TARGET}.tmp ${.TARGET} 50 1.99 riastrad CLEANFILES+= pthread.expsym pthread.expsym.tmp 51 1.99 riastrad 52 1.80 christos CPPFLAGS+= -I${ARCHDIR} -I${.CURDIR} -I${.OBJDIR} -D_LIBC -D_REENTRANT 53 1.80 christos CPPFLAGS+= -I${.CURDIR}/../libc/include 54 1.80 christos CPPFLAGS+= -D__LIBPTHREAD_SOURCE__ -D__LIBC_THREAD_STUBS 55 1.9 thorpej 56 1.96 joerg # Since <pthread.h> is not used, allow declaring pthread_create and 57 1.96 joerg # friends locally. 58 1.96 joerg CWARNFLAGS.clang+= -Wno-builtin-requires-header 59 1.96 joerg 60 1.35 christos # XXX: This crappy poke at libc's internals needs to be fixed. 61 1.35 christos CPPFLAGS+=-I${NETBSDSRCDIR}/sys -I${.CURDIR}/../libc 62 1.35 christos 63 1.85 pooka # providing alternative MI implementations for creating an lwp is 64 1.85 pooka # possible by setting PTHREAD_MAKELWP. Currently, alternatives are 65 1.97 lukem # set by the rumprun software stacks (see https://github.com/rumpkernel/rumprun ) 66 1.85 pooka PTHREAD_MAKELWP?= pthread_makelwp_netbsd.c 67 1.9 thorpej 68 1.9 thorpej # 69 1.9 thorpej # NOTE: When you create a new file for libpthread, make sure that pthread.c 70 1.9 thorpej # gets a reference to a symbol in that file. Otherwise, Unix's stupid static 71 1.9 thorpej # library semantics will end up discarding potentially important objects. 72 1.9 thorpej # 73 1.98 rin SRCS= pthread.c 74 1.18 nathanw SRCS+= pthread_attr.c 75 1.9 thorpej SRCS+= pthread_barrier.c 76 1.85 pooka # used by rumprun-posix to work around symbol collisions 77 1.85 pooka .if ${PTHREAD_CANCELSTUB:Uyes} != "no" 78 1.9 thorpej SRCS+= pthread_cancelstub.c 79 1.85 pooka .endif 80 1.9 thorpej SRCS+= pthread_cond.c 81 1.86 christos SRCS+= pthread_getcpuclockid.c 82 1.98 rin SRCS+= pthread_lock.c 83 1.85 pooka SRCS+= ${PTHREAD_MAKELWP} 84 1.40 ad SRCS+= pthread_misc.c 85 1.9 thorpej SRCS+= pthread_mutex.c 86 1.74 joerg SRCS+= pthread_once.c 87 1.9 thorpej SRCS+= pthread_rwlock.c 88 1.9 thorpej SRCS+= pthread_specific.c 89 1.42 ad SRCS+= pthread_spin.c 90 1.21 nathanw SRCS+= pthread_tsd.c 91 1.26 christos SRCS+= res_state.c 92 1.91 thorpej .PATH: ${.CURDIR}/../librt 93 1.11 christos SRCS+= sem.c 94 1.9 thorpej # Architecture-dependent files 95 1.56 ad .if exists(${ARCHDIR}/pthread_md.S) 96 1.56 ad SRCS+= pthread_md.S 97 1.9 thorpej .endif 98 1.82 matt .if exists(${ARCHDIR}/Makefile.inc) 99 1.82 matt .include "${ARCHDIR}/Makefile.inc" 100 1.82 matt .endif 101 1.21 nathanw 102 1.79 apb # The PTHREAD__COMPAT flag builds a libpthread that can be dropped 103 1.79 apb # into a NetBSD 2/3/4 chroot with a NetBSD 5 or later kernel. 104 1.79 apb # This makes threading work in the chroot, no other modifications 105 1.79 apb # required. 106 1.79 apb # 107 1.53 ad .if defined(PTHREAD__COMPAT) 108 1.53 ad SRCS+= pthread_compat.c 109 1.53 ad .PATH.c: ${.CURDIR}/../../common/lib/libc/arch/${ARCHSUBDIR}/atomic 110 1.53 ad .PATH.S: ${.CURDIR}/../../common/lib/libc/arch/${ARCHSUBDIR}/atomic 111 1.53 ad .PATH.c: ${.CURDIR}/../../common/lib/libc/atomic 112 1.53 ad .PATH.c: ${.CURDIR}/../libc/misc 113 1.53 ad .include "../../common/lib/libc/arch/${ARCHSUBDIR}/atomic/Makefile.inc" 114 1.53 ad .endif 115 1.53 ad 116 1.76 joerg ALIGN_FUNCTIONS= ${${ACTIVE_CC} == "gcc":? -falign-functions=32 :} 117 1.76 joerg 118 1.21 nathanw # The TSD routines are used in the implementation of profiling, and so 119 1.21 nathanw # can't be profiled themselves. 120 1.88 chs COPTS.pthread_specific.c+= ${ALIGN_FUNCTIONS} 121 1.21 nathanw pthread_specific.po: pthread_specific.o 122 1.25 lukem ${_MKTARGET_CREATE} 123 1.21 nathanw cp pthread_specific.o pthread_specific.po 124 1.21 nathanw 125 1.72 christos COPTS.pthread.c += -Wno-stack-protector -Wno-format-nonliteral 126 1.72 christos COPTS.pthread_attr.c += -Wno-format-nonliteral 127 1.45 jnemeth 128 1.100 rillig LINTFLAGS+= -Ac11 # for _Atomic 129 1.100 rillig 130 1.52 rmind MAN+= affinity.3 pthread.3 \ 131 1.48 yamt pthread_attr.3 \ 132 1.58 jruoho pthread_attr_get_np.3 \ 133 1.60 jruoho pthread_attr_getdetachstate.3 \ 134 1.62 jruoho pthread_attr_getguardsize.3 \ 135 1.63 jruoho pthread_attr_getinheritsched.3 \ 136 1.48 yamt pthread_attr_getname_np.3 \ 137 1.64 jruoho pthread_attr_getschedparam.3 \ 138 1.59 jruoho pthread_attr_getscope.3 \ 139 1.61 jruoho pthread_attr_getstack.3 \ 140 1.48 yamt pthread_attr_setcreatesuspend_np.3 \ 141 1.66 rmind pthread_barrier.3 pthread_barrierattr.3 \ 142 1.17 nathanw pthread_cancel.3 pthread_cleanup_push.3 \ 143 1.66 rmind pthread_cond.3 pthread_condattr.3 \ 144 1.66 rmind pthread_create.3 pthread_detach.3 pthread_equal.3 \ 145 1.73 yamt pthread_curcpu_np.3 \ 146 1.48 yamt pthread_exit.3 \ 147 1.86 christos pthread_getcpuclockid.3 \ 148 1.48 yamt pthread_getname_np.3 \ 149 1.48 yamt pthread_getspecific.3 pthread_join.3 \ 150 1.69 jruoho pthread_key_create.3 pthread_kill.3 \ 151 1.66 rmind pthread_mutex.3 pthread_mutexattr.3 \ 152 1.66 rmind pthread_once.3 pthread_rwlock.3 pthread_rwlockattr.3 \ 153 1.17 nathanw pthread_schedparam.3 pthread_self.3 \ 154 1.69 jruoho pthread_sigmask.3 pthread_spin.3 \ 155 1.51 rmind pthread_suspend_np.3 pthread_testcancel.3 156 1.17 nathanw 157 1.70 christos MLINKS+= pthread_attr_get_np.3 pthread_getattr_np.3 158 1.52 rmind MLINKS+= affinity.3 pthread_setaffinity_np.3 159 1.52 rmind MLINKS+= affinity.3 pthread_getaffinity_np.3 160 1.57 jruoho 161 1.17 nathanw MLINKS+= pthread_attr.3 pthread_attr_init.3 162 1.17 nathanw MLINKS+= pthread_attr.3 pthread_attr_destroy.3 163 1.59 jruoho 164 1.60 jruoho MLINKS+= pthread_attr_getdetachstate.3 pthread_attr_setdetachstate.3 165 1.62 jruoho MLINKS+= pthread_attr_getguardsize.3 pthread_attr_setguardsize.3 166 1.63 jruoho MLINKS+= pthread_attr_getinheritsched.3 pthread_attr_setinheritsched.3 167 1.68 jruoho MLINKS+= pthread_attr_getname_np.3 pthread_attr_setname_np.3 168 1.67 jruoho 169 1.67 jruoho MLINKS+= pthread_attr_getschedparam.3 pthread_attr_setschedparam.3 \ 170 1.67 jruoho pthread_attr_getschedparam.3 pthread_attr_getschedpolicy.3 \ 171 1.67 jruoho pthread_attr_getschedparam.3 pthread_attr_setschedpolicy.3 172 1.67 jruoho 173 1.59 jruoho MLINKS+= pthread_attr_getscope.3 pthread_attr_setscope.3 174 1.67 jruoho 175 1.61 jruoho MLINKS+= pthread_attr_getstack.3 pthread_attr_setstack.3 \ 176 1.61 jruoho pthread_attr_getstack.3 pthread_attr_getstacksize.3 \ 177 1.61 jruoho pthread_attr_getstack.3 pthread_attr_setstacksize.3 \ 178 1.61 jruoho pthread_attr_getstack.3 pthread_attr_getstackaddr.3 \ 179 1.61 jruoho pthread_attr_getstack.3 pthread_attr_setstackaddr.3 180 1.57 jruoho 181 1.66 rmind MLINKS+= pthread_cleanup_push.3 pthread_cleanup_pop.3 182 1.66 rmind 183 1.66 rmind MLINKS+= pthread_barrier.3 pthread_barrier_init.3 184 1.66 rmind MLINKS+= pthread_barrier.3 pthread_barrier_destroy.3 185 1.66 rmind MLINKS+= pthread_barrier.3 pthread_barrier_wait.3 186 1.66 rmind 187 1.32 peter MLINKS+= pthread_barrierattr.3 pthread_barrierattr_init.3 188 1.32 peter MLINKS+= pthread_barrierattr.3 pthread_barrierattr_destroy.3 189 1.87 christos MLINKS+= pthread_barrierattr.3 pthread_barrierattr_getpshared.3 190 1.87 christos MLINKS+= pthread_barrierattr.3 pthread_barrierattr_setpshared.3 191 1.66 rmind 192 1.66 rmind MLINKS+= pthread_cond.3 pthread_cond_init.3 193 1.66 rmind MLINKS+= pthread_cond.3 pthread_cond_destroy.3 194 1.66 rmind MLINKS+= pthread_cond.3 pthread_cond_broadcast.3 195 1.66 rmind MLINKS+= pthread_cond.3 pthread_cond_wait.3 196 1.66 rmind MLINKS+= pthread_cond.3 pthread_cond_signal.3 197 1.66 rmind MLINKS+= pthread_cond.3 pthread_cond_timedwait.3 198 1.66 rmind 199 1.17 nathanw MLINKS+= pthread_condattr.3 pthread_condattr_init.3 200 1.17 nathanw MLINKS+= pthread_condattr.3 pthread_condattr_destroy.3 201 1.78 riastrad MLINKS+= pthread_condattr.3 pthread_condattr_setclock.3 202 1.87 christos MLINKS+= pthread_condattr.3 pthread_condattr_getclock.3 203 1.87 christos MLINKS+= pthread_condattr.3 pthread_condattr_getpshared.3 204 1.87 christos MLINKS+= pthread_condattr.3 pthread_condattr_setpshared.3 205 1.66 rmind 206 1.68 jruoho MLINKS+= pthread_getname_np.3 pthread_setname_np.3 207 1.69 jruoho MLINKS+= pthread_getspecific.3 pthread_setspecific.3 208 1.69 jruoho MLINKS+= pthread_key_create.3 pthread_key_delete.3 209 1.68 jruoho 210 1.66 rmind MLINKS+= pthread_mutex.3 pthread_mutex_init.3 211 1.66 rmind MLINKS+= pthread_mutex.3 pthread_mutex_destroy.3 212 1.66 rmind MLINKS+= pthread_mutex.3 pthread_mutex_lock.3 213 1.66 rmind MLINKS+= pthread_mutex.3 pthread_mutex_trylock.3 214 1.66 rmind MLINKS+= pthread_mutex.3 pthread_mutex_unlock.3 215 1.87 christos MLINKS+= pthread_mutex.3 pthread_mutex_timedlock.3 216 1.87 christos MLINKS+= pthread_mutex.3 pthread_mutex_getprioceiling.3 217 1.98 rin MLINKS+= pthread_mutex.3 pthread_mutex_setprioceiling.3 218 1.66 rmind 219 1.17 nathanw MLINKS+= pthread_mutexattr.3 pthread_mutexattr_init.3 220 1.17 nathanw MLINKS+= pthread_mutexattr.3 pthread_mutexattr_destroy.3 221 1.87 christos MLINKS+= pthread_mutexattr.3 pthread_mutexattr_getpshared.3 222 1.87 christos MLINKS+= pthread_mutexattr.3 pthread_mutexattr_setpshared.3 223 1.17 nathanw MLINKS+= pthread_mutexattr.3 pthread_mutexattr_settype.3 224 1.17 nathanw MLINKS+= pthread_mutexattr.3 pthread_mutexattr_gettype.3 225 1.87 christos MLINKS+= pthread_mutexattr.3 pthread_mutexattr_getprotocol.3 226 1.87 christos MLINKS+= pthread_mutexattr.3 pthread_mutexattr_setprotocol.3 227 1.87 christos MLINKS+= pthread_mutexattr.3 pthread_mutexattr_getprioceiling.3 228 1.98 rin MLINKS+= pthread_mutexattr.3 pthread_mutexattr_setprioceiling.3 229 1.66 rmind 230 1.66 rmind MLINKS+= pthread_rwlock.3 pthread_rwlock_init.3 231 1.66 rmind MLINKS+= pthread_rwlock.3 pthread_rwlock_destroy.3 232 1.66 rmind MLINKS+= pthread_rwlock.3 pthread_rwlock_rdlock.3 233 1.66 rmind MLINKS+= pthread_rwlock.3 pthread_rwlock_wrlock.3 234 1.66 rmind MLINKS+= pthread_rwlock.3 pthread_rwlock_unlock.3 235 1.66 rmind 236 1.66 rmind MLINKS+= pthread_rwlock.3 pthread_rwlock_timedrdlock.3 237 1.66 rmind MLINKS+= pthread_rwlock.3 pthread_rwlock_timedwrlock.3 238 1.66 rmind MLINKS+= pthread_rwlock.3 pthread_rwlock_tryrdlock.3 239 1.66 rmind MLINKS+= pthread_rwlock.3 pthread_rwlock_trywrlock.3 240 1.66 rmind 241 1.17 nathanw MLINKS+= pthread_rwlockattr.3 pthread_rwlockattr_init.3 242 1.17 nathanw MLINKS+= pthread_rwlockattr.3 pthread_rwlockattr_destroy.3 243 1.87 christos MLINKS+= pthread_rwlockattr.3 pthread_rwlockattr_getpshared.3 244 1.87 christos MLINKS+= pthread_rwlockattr.3 pthread_rwlockattr_setpshared.3 245 1.66 rmind 246 1.66 rmind MLINKS+= pthread_spin.3 pthread_spin_init.3 247 1.66 rmind MLINKS+= pthread_spin.3 pthread_spin_destroy.3 248 1.66 rmind MLINKS+= pthread_spin.3 pthread_spin_lock.3 249 1.66 rmind MLINKS+= pthread_spin.3 pthread_spin_trylock.3 250 1.66 rmind MLINKS+= pthread_spin.3 pthread_spin_unlock.3 251 1.66 rmind 252 1.17 nathanw MLINKS+= pthread_schedparam.3 pthread_setschedparam.3 253 1.17 nathanw MLINKS+= pthread_schedparam.3 pthread_getschedparam.3 254 1.23 christos MLINKS+= pthread_suspend_np.3 pthread_resume_np.3 255 1.17 nathanw MLINKS+= pthread_testcancel.3 pthread_setcancelstate.3 256 1.17 nathanw MLINKS+= pthread_testcancel.3 pthread_setcanceltype.3 257 1.9 thorpej 258 1.92 kamil # ISO C threads (ISO/IEC 9899:2011) 259 1.92 kamil 260 1.92 kamil SRCS+= call_once.c cnd.c mtx.c thrd.c tss.c 261 1.92 kamil MAN+= threads.3 call_once.3 cnd.3 mtx.3 thrd.3 tss.3 262 1.92 kamil 263 1.92 kamil MLINKS+= call_once.3 ONCE_FLAG_INIT.3 264 1.92 kamil MLINKS+= call_once.3 once_flag.3 265 1.92 kamil 266 1.92 kamil MLINKS+= cnd.3 cnd_broadcast.3 267 1.92 kamil MLINKS+= cnd.3 cnd_destroy.3 268 1.92 kamil MLINKS+= cnd.3 cnd_init.3 269 1.92 kamil MLINKS+= cnd.3 cnd_signal.3 270 1.92 kamil MLINKS+= cnd.3 cnd_timedwait.3 271 1.92 kamil MLINKS+= cnd.3 cnd_wait.3 272 1.92 kamil 273 1.92 kamil MLINKS+= mtx.3 mtx_destroy.3 274 1.92 kamil MLINKS+= mtx.3 mtx_init.3 275 1.92 kamil MLINKS+= mtx.3 mtx_lock.3 276 1.92 kamil MLINKS+= mtx.3 mtx_timedlock.3 277 1.92 kamil MLINKS+= mtx.3 mtx_trylock.3 278 1.92 kamil MLINKS+= mtx.3 mtx_unlock.3 279 1.92 kamil 280 1.92 kamil MLINKS+= thrd.3 thrd_create.3 281 1.92 kamil MLINKS+= thrd.3 thrd_current.3 282 1.92 kamil MLINKS+= thrd.3 thrd_detach.3 283 1.92 kamil MLINKS+= thrd.3 thrd_equal.3 284 1.92 kamil MLINKS+= thrd.3 thrd_exit.3 285 1.92 kamil MLINKS+= thrd.3 thrd_join.3 286 1.92 kamil MLINKS+= thrd.3 thrd_sleep.3 287 1.92 kamil MLINKS+= thrd.3 thrd_yield.3 288 1.92 kamil 289 1.92 kamil MLINKS+= tss.3 TSS_DTOR_ITERATIONS.3 290 1.92 kamil MLINKS+= tss.3 tss_create.3 291 1.92 kamil MLINKS+= tss.3 tss_delete.3 292 1.92 kamil MLINKS+= tss.3 tss_get.3 293 1.92 kamil MLINKS+= tss.3 tss_set.3 294 1.92 kamil 295 1.92 kamil INCS+= threads.h 296 1.92 kamil 297 1.93 maya # PR lib/54001: create libpthread.a as a single large object, with all the 298 1.93 maya # symbols in one section. ensures that if any libpthread function is used, 299 1.93 maya # you get all of them from libpthread, and not the libc stubs. 300 1.93 maya # 301 1.93 maya # This makes -lpthread equivalent to -Wl,--whole-archive -lpthread 302 1.93 maya 303 1.93 maya __archivebuild: .USE 304 1.93 maya ${_MKTARGET_BUILD} 305 1.93 maya @rm -f ${.TARGET} 306 1.93 maya ${LD} -r -o ${.TARGET}.o `NM=${NM} ${LORDER} ${.ALLSRC:M*o} | ${TSORT}` 307 1.93 maya ${AR} ${_ARFL} ${.TARGET} ${.TARGET}.o 308 1.93 maya 309 1.94 maya CLEANFILES+= ${_LIBS:=.o} 310 1.93 maya 311 1.1 proven .include <bsd.lib.mk> 312 1.1 proven 313 1.9 thorpej .else 314 1.9 thorpej 315 1.9 thorpej .include <bsd.man.mk> 316 1.10 thorpej .include <bsd.files.mk> 317 1.10 thorpej .include <bsd.inc.mk> 318 1.9 thorpej 319 1.9 thorpej .endif 320 1.9 thorpej 321 1.9 thorpej # WARNS=2 sets -Wcast-qual. This causes problems for one of 322 1.9 thorpej # pthread_setspecific() and pthread_getspecific(), since the constness 323 1.9 thorpej # of the argument to setspecific() has to be discarded *somewhere* 324 1.9 thorpej # before returning it from getspecific(). 325 1.77 matt CWARNFLAGS+= -Wno-cast-qual 326