1 # $NetBSD: Makefile,v 1.83 2013/10/09 22:33:41 matt Exp $ 2 # 3 4 WARNS?= 5 5 6 .include <bsd.own.mk> 7 8 .if defined(PTHREAD_MACHINE_ARCH) && !empty(PTHREAD_MACHINE_ARCH) && \ 9 exists(${.CURDIR}/arch/${PTHREAD_MACHINE_ARCH}) 10 ARCHSUBDIR= ${PTHREAD_MACHINE_ARCH} 11 .elif exists(${.CURDIR}/arch/${MACHINE_ARCH}) 12 ARCHSUBDIR= ${MACHINE_ARCH} 13 .elif exists(${.CURDIR}/arch/${MACHINE_CPU}) 14 ARCHSUBDIR= ${MACHINE_CPU} 15 .else 16 .BEGIN: 17 @echo "WARNING: no ARCHSUBDIR for ${MACHINE_ARCH}/${MACHINE_CPU}; skipping..." 18 .endif 19 20 INCS= pthread.h pthread_types.h pthread_queue.h 21 INCSDIR=/usr/include 22 23 .if defined(ARCHSUBDIR) 24 25 ARCHDIR= ${.CURDIR}/arch/${ARCHSUBDIR} 26 .PATH: ${ARCHDIR} 27 28 CPPFLAGS+= -I${ARCHDIR} -I${.CURDIR} -I${.OBJDIR} -D_LIBC -D_REENTRANT 29 CPPFLAGS+= -I${.CURDIR}/../libc/include 30 CPPFLAGS+= -D__LIBPTHREAD_SOURCE__ -D__LIBC_THREAD_STUBS 31 32 # XXX: This crappy poke at libc's internals needs to be fixed. 33 CPPFLAGS+=-I${NETBSDSRCDIR}/sys -I${.CURDIR}/../libc 34 35 LIB= pthread 36 37 # 38 # NOTE: When you create a new file for libpthread, make sure that pthread.c 39 # gets a reference to a symbol in that file. Otherwise, Unix's stupid static 40 # library semantics will end up discarding potentially important objects. 41 # 42 SRCS= pthread.c 43 SRCS+= pthread_attr.c 44 SRCS+= pthread_barrier.c 45 SRCS+= pthread_cancelstub.c 46 SRCS+= pthread_cond.c 47 SRCS+= pthread_lock.c 48 SRCS+= pthread_misc.c 49 SRCS+= pthread_mutex.c 50 SRCS+= pthread_once.c 51 SRCS+= pthread_rwlock.c 52 SRCS+= pthread_specific.c 53 SRCS+= pthread_spin.c 54 SRCS+= pthread_tsd.c 55 SRCS+= res_state.c 56 SRCS+= sem.c 57 # Architecture-dependent files 58 .if exists(${ARCHDIR}/pthread_md.S) 59 SRCS+= pthread_md.S 60 .endif 61 .if exists(${ARCHDIR}/Makefile.inc) 62 .include "${ARCHDIR}/Makefile.inc" 63 .endif 64 65 # The PTHREAD__COMPAT flag builds a libpthread that can be dropped 66 # into a NetBSD 2/3/4 chroot with a NetBSD 5 or later kernel. 67 # This makes threading work in the chroot, no other modifications 68 # required. 69 # 70 .if defined(PTHREAD__COMPAT) 71 SRCS+= pthread_compat.c 72 .PATH.c: ${.CURDIR}/../../common/lib/libc/arch/${ARCHSUBDIR}/atomic 73 .PATH.S: ${.CURDIR}/../../common/lib/libc/arch/${ARCHSUBDIR}/atomic 74 .PATH.c: ${.CURDIR}/../../common/lib/libc/atomic 75 .PATH.c: ${.CURDIR}/../libc/misc 76 .include "../../common/lib/libc/arch/${ARCHSUBDIR}/atomic/Makefile.inc" 77 .endif 78 79 ALIGN_FUNCTIONS= ${${ACTIVE_CC} == "gcc":? -falign-functions=32 :} 80 81 .if ${MACHINE_CPU} != "m68k" && ${MACHINE_CPU} != "sh3" && ${MACHINE_ARCH} != "vax" 82 OMIT_FRAME_POINTER= -fomit-frame-pointer 83 .else 84 OMIT_FRAME_POINTER= 85 .endif 86 87 # The TSD routines are used in the implementation of profiling, and so 88 # can't be profiled themselves. 89 COPTS.pthread_specific.c+= ${OMIT_FRAME_POINTER} ${ALIGN_FUNCTIONS} 90 pthread_specific.po: pthread_specific.o 91 ${_MKTARGET_CREATE} 92 cp pthread_specific.o pthread_specific.po 93 94 # Internal spinlock routines are performance critical. Don't profile them, 95 # it's incompatibile with -fomit-frame-pointer. 96 COPTS.pthread_lock.c+= ${OMIT_FRAME_POINTER} ${ALIGN_FUNCTIONS} 97 pthread_lock.po: pthread_lock.o 98 ${_MKTARGET_CREATE} 99 cp pthread_lock.o pthread_lock.po 100 101 COPTS.pthread_mutex.c+= ${OMIT_FRAME_POINTER} ${ALIGN_FUNCTIONS} 102 pthread_mutex.po: pthread_mutex.o 103 ${_MKTARGET_CREATE} 104 cp pthread_mutex.o pthread_mutex.po 105 106 COPTS.pthread.c += -Wno-stack-protector -Wno-format-nonliteral 107 COPTS.pthread_attr.c += -Wno-format-nonliteral 108 109 MAN+= affinity.3 pthread.3 \ 110 pthread_attr.3 \ 111 pthread_attr_get_np.3 \ 112 pthread_attr_getdetachstate.3 \ 113 pthread_attr_getguardsize.3 \ 114 pthread_attr_getinheritsched.3 \ 115 pthread_attr_getname_np.3 \ 116 pthread_attr_getschedparam.3 \ 117 pthread_attr_getscope.3 \ 118 pthread_attr_getstack.3 \ 119 pthread_attr_setcreatesuspend_np.3 \ 120 pthread_barrier.3 pthread_barrierattr.3 \ 121 pthread_cancel.3 pthread_cleanup_push.3 \ 122 pthread_cond.3 pthread_condattr.3 \ 123 pthread_create.3 pthread_detach.3 pthread_equal.3 \ 124 pthread_curcpu_np.3 \ 125 pthread_exit.3 \ 126 pthread_getname_np.3 \ 127 pthread_getspecific.3 pthread_join.3 \ 128 pthread_key_create.3 pthread_kill.3 \ 129 pthread_mutex.3 pthread_mutexattr.3 \ 130 pthread_once.3 pthread_rwlock.3 pthread_rwlockattr.3 \ 131 pthread_schedparam.3 pthread_self.3 \ 132 pthread_sigmask.3 pthread_spin.3 \ 133 pthread_suspend_np.3 pthread_testcancel.3 134 135 MLINKS+= pthread_attr_get_np.3 pthread_getattr_np.3 136 MLINKS+= affinity.3 pthread_setaffinity_np.3 137 MLINKS+= affinity.3 pthread_getaffinity_np.3 138 139 MLINKS+= pthread_attr.3 pthread_attr_init.3 140 MLINKS+= pthread_attr.3 pthread_attr_destroy.3 141 142 MLINKS+= pthread_attr_getdetachstate.3 pthread_attr_setdetachstate.3 143 MLINKS+= pthread_attr_getguardsize.3 pthread_attr_setguardsize.3 144 MLINKS+= pthread_attr_getinheritsched.3 pthread_attr_setinheritsched.3 145 MLINKS+= pthread_attr_getname_np.3 pthread_attr_setname_np.3 146 147 MLINKS+= pthread_attr_getschedparam.3 pthread_attr_setschedparam.3 \ 148 pthread_attr_getschedparam.3 pthread_attr_getschedpolicy.3 \ 149 pthread_attr_getschedparam.3 pthread_attr_setschedpolicy.3 150 151 MLINKS+= pthread_attr_getscope.3 pthread_attr_setscope.3 152 153 MLINKS+= pthread_attr_getstack.3 pthread_attr_setstack.3 \ 154 pthread_attr_getstack.3 pthread_attr_getstacksize.3 \ 155 pthread_attr_getstack.3 pthread_attr_setstacksize.3 \ 156 pthread_attr_getstack.3 pthread_attr_getstackaddr.3 \ 157 pthread_attr_getstack.3 pthread_attr_setstackaddr.3 158 159 MLINKS+= pthread_cleanup_push.3 pthread_cleanup_pop.3 160 161 MLINKS+= pthread_barrier.3 pthread_barrier_init.3 162 MLINKS+= pthread_barrier.3 pthread_barrier_destroy.3 163 MLINKS+= pthread_barrier.3 pthread_barrier_wait.3 164 165 MLINKS+= pthread_barrierattr.3 pthread_barrierattr_init.3 166 MLINKS+= pthread_barrierattr.3 pthread_barrierattr_destroy.3 167 168 MLINKS+= pthread_cond.3 pthread_cond_init.3 169 MLINKS+= pthread_cond.3 pthread_cond_destroy.3 170 MLINKS+= pthread_cond.3 pthread_cond_broadcast.3 171 MLINKS+= pthread_cond.3 pthread_cond_wait.3 172 MLINKS+= pthread_cond.3 pthread_cond_signal.3 173 MLINKS+= pthread_cond.3 pthread_cond_timedwait.3 174 175 MLINKS+= pthread_condattr.3 pthread_condattr_init.3 176 MLINKS+= pthread_condattr.3 pthread_condattr_destroy.3 177 MLINKS+= pthread_condattr.3 pthread_condattr_setclock.3 178 179 MLINKS+= pthread_getname_np.3 pthread_setname_np.3 180 MLINKS+= pthread_getspecific.3 pthread_setspecific.3 181 MLINKS+= pthread_key_create.3 pthread_key_delete.3 182 183 MLINKS+= pthread_mutex.3 pthread_mutex_init.3 184 MLINKS+= pthread_mutex.3 pthread_mutex_destroy.3 185 MLINKS+= pthread_mutex.3 pthread_mutex_lock.3 186 MLINKS+= pthread_mutex.3 pthread_mutex_trylock.3 187 MLINKS+= pthread_mutex.3 pthread_mutex_unlock.3 188 189 MLINKS+= pthread_mutexattr.3 pthread_mutexattr_init.3 190 MLINKS+= pthread_mutexattr.3 pthread_mutexattr_destroy.3 191 MLINKS+= pthread_mutexattr.3 pthread_mutexattr_settype.3 192 MLINKS+= pthread_mutexattr.3 pthread_mutexattr_gettype.3 193 194 MLINKS+= pthread_rwlock.3 pthread_rwlock_init.3 195 MLINKS+= pthread_rwlock.3 pthread_rwlock_destroy.3 196 MLINKS+= pthread_rwlock.3 pthread_rwlock_rdlock.3 197 MLINKS+= pthread_rwlock.3 pthread_rwlock_wrlock.3 198 MLINKS+= pthread_rwlock.3 pthread_rwlock_unlock.3 199 200 MLINKS+= pthread_rwlock.3 pthread_rwlock_timedrdlock.3 201 MLINKS+= pthread_rwlock.3 pthread_rwlock_timedwrlock.3 202 MLINKS+= pthread_rwlock.3 pthread_rwlock_tryrdlock.3 203 MLINKS+= pthread_rwlock.3 pthread_rwlock_trywrlock.3 204 205 MLINKS+= pthread_rwlockattr.3 pthread_rwlockattr_init.3 206 MLINKS+= pthread_rwlockattr.3 pthread_rwlockattr_destroy.3 207 208 MLINKS+= pthread_spin.3 pthread_spin_init.3 209 MLINKS+= pthread_spin.3 pthread_spin_destroy.3 210 MLINKS+= pthread_spin.3 pthread_spin_lock.3 211 MLINKS+= pthread_spin.3 pthread_spin_trylock.3 212 MLINKS+= pthread_spin.3 pthread_spin_unlock.3 213 214 MLINKS+= pthread_schedparam.3 pthread_setschedparam.3 215 MLINKS+= pthread_schedparam.3 pthread_getschedparam.3 216 MLINKS+= pthread_suspend_np.3 pthread_resume_np.3 217 MLINKS+= pthread_testcancel.3 pthread_setcancelstate.3 218 MLINKS+= pthread_testcancel.3 pthread_setcanceltype.3 219 220 .include <bsd.lib.mk> 221 222 .else 223 224 .include <bsd.man.mk> 225 .include <bsd.files.mk> 226 .include <bsd.inc.mk> 227 228 .endif 229 230 # WARNS=2 sets -Wcast-qual. This causes problems for one of 231 # pthread_setspecific() and pthread_getspecific(), since the constness 232 # of the argument to setspecific() has to be discarded *somewhere* 233 # before returning it from getspecific(). 234 CWARNFLAGS+= -Wno-cast-qual 235