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