Makefile revision 1.44
1# $NetBSD: Makefile,v 1.44 2007/10/04 21:08:35 ad Exp $ 2# 3 4WARNS= 4 5 6.include <bsd.own.mk> 7 8.if exists(${.CURDIR}/arch/${MACHINE_ARCH}) 9ARCHSUBDIR= ${MACHINE_ARCH} 10.elif exists(${.CURDIR}/arch/${MACHINE_CPU}) 11ARCHSUBDIR= ${MACHINE_CPU} 12.else 13.BEGIN: 14 @echo "WARNING: no ARCHSUBDIR for ${MACHINE_ARCH}/${MACHINE_CPU}; skipping..." 15.endif 16 17INCS= pthread.h pthread_types.h pthread_queue.h 18INCSDIR=/usr/include 19 20.if defined(ARCHSUBDIR) 21 22ARCHDIR= ${.CURDIR}/arch/${ARCHSUBDIR} 23.PATH: ${ARCHDIR} 24 25CPPFLAGS+= -I${ARCHDIR} -I${.CURDIR} -I${.OBJDIR} -D_LIBC 26CPPFLAGS+= -D__LIBPTHREAD_SOURCE__ 27 28# XXX: This crappy poke at libc's internals needs to be fixed. 29# We need to put this *after our own includes, so that our "assym.h" 30# gets picked, instead of the libc one 31CPPFLAGS+=-I${NETBSDSRCDIR}/sys -I${.CURDIR}/../libc 32 33DPSRCS+= assym.h 34CLEANFILES+= assym.h 35 36assym.h: ${ARCHDIR}/genassym.cf pthread.h pthread_int.h pthread_md.h 37 ${_MKTARGET_CREATE} 38 ${TOOL_GENASSYM} -- ${CC} ${CFLAGS} ${CPPFLAGS} ${PROF} \ 39 < ${ARCHDIR}/genassym.cf > assym.h.tmp && \ 40 mv -f assym.h.tmp assym.h 41 42LIB= pthread 43 44# 45# NOTE: When you create a new file for libpthread, make sure that pthread.c 46# gets a reference to a symbol in that file. Otherwise, Unix's stupid static 47# library semantics will end up discarding potentially important objects. 48# 49SRCS= pthread.c 50SRCS+= pthread_attr.c 51SRCS+= pthread_barrier.c 52SRCS+= pthread_cancelstub.c 53SRCS+= pthread_cond.c 54SRCS+= pthread_lock.c 55SRCS+= pthread_misc.c 56SRCS+= pthread_mutex.c 57SRCS+= pthread_mutex2.c 58SRCS+= pthread_rwlock.c 59SRCS+= pthread_rwlock2.c 60SRCS+= pthread_specific.c 61SRCS+= pthread_spin.c 62SRCS+= pthread_tsd.c 63SRCS+= pthread_debug.c 64SRCS+= res_state.c 65SRCS+= sched.c 66SRCS+= sem.c 67# Architecture-dependent files 68SRCS+= _context_u.S 69.if exists(${ARCHDIR}/pthread_md.c) 70SRCS+= pthread_md.c 71.endif 72 73# The TSD routines are used in the implementation of profiling, and so 74# can't be profiled themselves. 75COPTS.pthread_specific.c+= -fomit-frame-pointer -falign-functions=32 76pthread_specific.po: pthread_specific.o 77 ${_MKTARGET_CREATE} 78 cp pthread_specific.o pthread_specific.po 79 80# Internal spinlock routines are performance critical. Don't profile them, 81# it's incompatibile with -fomit-frame-pointer. 82COPTS.pthread_lock.c+= -fomit-frame-pointer -falign-functions=32 83pthread_lock.po: pthread_lock.o 84 ${_MKTARGET_CREATE} 85 cp pthread_lock.o pthread_lock.po 86 87_context_u.po: _context_u.o 88 ${_MKTARGET_CREATE} 89 cp _context_u.o _context_u.po 90 91MAN+= pthread.3 \ 92 pthread_attr.3 pthread_attr_setcreatesuspend_np.3 \ 93 pthread_barrier_destroy.3 pthread_barrier_init.3 \ 94 pthread_barrier_wait.3 pthread_barrierattr.3 \ 95 pthread_cancel.3 pthread_cleanup_push.3 \ 96 pthread_cond_broadcast.3 pthread_cond_destroy.3 pthread_cond_init.3 \ 97 pthread_cond_wait.3 \ 98 pthread_condattr.3 pthread_create.3 pthread_detach.3 pthread_equal.3 \ 99 pthread_exit.3 pthread_getspecific.3 pthread_join.3 \ 100 pthread_key_create.3 pthread_key_delete.3 pthread_kill.3 \ 101 pthread_mutex_destroy.3 pthread_mutex_init.3 pthread_mutex_lock.3 \ 102 pthread_mutex_unlock.3 pthread_mutexattr.3 \ 103 pthread_once.3 pthread_rwlock_destroy.3 pthread_rwlock_init.3 \ 104 pthread_rwlock_rdlock.3 pthread_rwlock_unlock.3 \ 105 pthread_rwlock_wrlock.3 pthread_rwlockattr.3 \ 106 pthread_schedparam.3 pthread_self.3 \ 107 pthread_setspecific.3 pthread_sigmask.3 pthread_spin_destroy.3 \ 108 pthread_spin_init.3 pthread_spin_lock.3 pthread_spin_unlock.3 \ 109 pthread_suspend_np.3 pthread_testcancel.3 \ 110 sched_yield.3 111 112MLINKS+= pthread_attr.3 pthread_attr_init.3 113MLINKS+= pthread_attr.3 pthread_attr_destroy.3 114MLINKS+= pthread_attr.3 pthread_attr_setdetachstate.3 115MLINKS+= pthread_attr.3 pthread_attr_getdetachstate.3 116MLINKS+= pthread_attr.3 pthread_attr_setschedparam.3 117MLINKS+= pthread_attr.3 pthread_attr_getschedparam.3 118MLINKS+= pthread_barrierattr.3 pthread_barrierattr_init.3 119MLINKS+= pthread_barrierattr.3 pthread_barrierattr_destroy.3 120MLINKS+= pthread_cleanup_push.3 pthread_cleanup_pop.3 121MLINKS+= pthread_cond_broadcast.3 pthread_cond_signal.3 122MLINKS+= pthread_cond_wait.3 pthread_cond_timedwait.3 123MLINKS+= pthread_condattr.3 pthread_condattr_init.3 124MLINKS+= pthread_condattr.3 pthread_condattr_destroy.3 125MLINKS+= pthread_mutex_lock.3 pthread_mutex_trylock.3 126MLINKS+= pthread_mutexattr.3 pthread_mutexattr_init.3 127MLINKS+= pthread_mutexattr.3 pthread_mutexattr_destroy.3 128MLINKS+= pthread_mutexattr.3 pthread_mutexattr_settype.3 129MLINKS+= pthread_mutexattr.3 pthread_mutexattr_gettype.3 130MLINKS+= pthread_rwlock_rdlock.3 pthread_rwlock_timedrdlock.3 131MLINKS+= pthread_rwlock_rdlock.3 pthread_rwlock_tryrdlock.3 132MLINKS+= pthread_rwlock_wrlock.3 pthread_rwlock_timedwrlock.3 133MLINKS+= pthread_rwlock_wrlock.3 pthread_rwlock_trywrlock.3 134MLINKS+= pthread_rwlockattr.3 pthread_rwlockattr_init.3 135MLINKS+= pthread_rwlockattr.3 pthread_rwlockattr_destroy.3 136MLINKS+= pthread_schedparam.3 pthread_setschedparam.3 137MLINKS+= pthread_schedparam.3 pthread_getschedparam.3 138MLINKS+= pthread_spin_lock.3 pthread_spin_trylock.3 139MLINKS+= pthread_suspend_np.3 pthread_resume_np.3 140MLINKS+= pthread_testcancel.3 pthread_setcancelstate.3 141MLINKS+= pthread_testcancel.3 pthread_setcanceltype.3 142 143pthread_switch.S _context_u.S: assym.h 144 145debuglog: debuglog.o 146 $(CC) -o debuglog debuglog.o -lpthread 147 148.include <bsd.lib.mk> 149 150.else 151 152.include <bsd.man.mk> 153.include <bsd.files.mk> 154.include <bsd.inc.mk> 155 156.endif 157 158# WARNS=2 sets -Wcast-qual. This causes problems for one of 159# pthread_setspecific() and pthread_getspecific(), since the constness 160# of the argument to setspecific() has to be discarded *somewhere* 161# before returning it from getspecific(). 162CFLAGS+= -Wno-cast-qual 163