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