Makefile revision 1.75
11.75Smatt# $NetBSD: Makefile,v 1.75 2012/03/21 05:37:43 matt Exp $ 21.9Sthorpej# 31.9Sthorpej 41.75SmattWARNS?= 5 51.24Scl 61.9Sthorpej.include <bsd.own.mk> 71.9Sthorpej 81.55Smrg.if defined(PTHREAD_MACHINE_ARCH) && !empty(PTHREAD_MACHINE_ARCH) && \ 91.55Smrg exists(${.CURDIR}/arch/${PTHREAD_MACHINE_ARCH}) 101.55SmrgARCHSUBDIR= ${PTHREAD_MACHINE_ARCH} 111.55Smrg.elif exists(${.CURDIR}/arch/${MACHINE_ARCH}) 121.9SthorpejARCHSUBDIR= ${MACHINE_ARCH} 131.9Sthorpej.elif exists(${.CURDIR}/arch/${MACHINE_CPU}) 141.9SthorpejARCHSUBDIR= ${MACHINE_CPU} 151.9Sthorpej.else 161.9Sthorpej.BEGIN: 171.10Sthorpej @echo "WARNING: no ARCHSUBDIR for ${MACHINE_ARCH}/${MACHINE_CPU}; skipping..." 181.9Sthorpej.endif 191.9Sthorpej 201.10SthorpejINCS= pthread.h pthread_types.h pthread_queue.h 211.10SthorpejINCSDIR=/usr/include 221.10Sthorpej 231.9Sthorpej.if defined(ARCHSUBDIR) 241.9Sthorpej 251.9SthorpejARCHDIR= ${.CURDIR}/arch/${ARCHSUBDIR} 261.9Sthorpej.PATH: ${ARCHDIR} 271.9Sthorpej 281.11SchristosCPPFLAGS+= -I${ARCHDIR} -I${.CURDIR} -I${.OBJDIR} -D_LIBC 291.37SadCPPFLAGS+= -D__LIBPTHREAD_SOURCE__ 301.9Sthorpej 311.35Schristos# XXX: This crappy poke at libc's internals needs to be fixed. 321.35SchristosCPPFLAGS+=-I${NETBSDSRCDIR}/sys -I${.CURDIR}/../libc 331.35Schristos 341.9SthorpejLIB= pthread 351.9Sthorpej 361.71SskrllLDFLAGS+= -Wl,-znodlopen 371.71Sskrll 381.9Sthorpej# 391.9Sthorpej# NOTE: When you create a new file for libpthread, make sure that pthread.c 401.9Sthorpej# gets a reference to a symbol in that file. Otherwise, Unix's stupid static 411.9Sthorpej# library semantics will end up discarding potentially important objects. 421.9Sthorpej# 431.9SthorpejSRCS= pthread.c 441.18SnathanwSRCS+= pthread_attr.c 451.9SthorpejSRCS+= pthread_barrier.c 461.9SthorpejSRCS+= pthread_cancelstub.c 471.9SthorpejSRCS+= pthread_cond.c 481.9SthorpejSRCS+= pthread_lock.c 491.40SadSRCS+= pthread_misc.c 501.9SthorpejSRCS+= pthread_mutex.c 511.74SjoergSRCS+= pthread_once.c 521.9SthorpejSRCS+= pthread_rwlock.c 531.9SthorpejSRCS+= pthread_specific.c 541.42SadSRCS+= pthread_spin.c 551.21SnathanwSRCS+= pthread_tsd.c 561.26SchristosSRCS+= res_state.c 571.11SchristosSRCS+= sem.c 581.9Sthorpej# Architecture-dependent files 591.56Sad.if exists(${ARCHDIR}/pthread_md.S) 601.56SadSRCS+= pthread_md.S 611.9Sthorpej.endif 621.21Snathanw 631.53Sad.if defined(PTHREAD__COMPAT) 641.53SadSRCS+= pthread_compat.c 651.53Sad.PATH.c: ${.CURDIR}/../../common/lib/libc/arch/${ARCHSUBDIR}/atomic 661.53Sad.PATH.S: ${.CURDIR}/../../common/lib/libc/arch/${ARCHSUBDIR}/atomic 671.53Sad.PATH.c: ${.CURDIR}/../../common/lib/libc/atomic 681.53Sad.PATH.c: ${.CURDIR}/../libc/misc 691.53Sad.include "../../common/lib/libc/arch/${ARCHSUBDIR}/atomic/Makefile.inc" 701.53Sad.endif 711.53Sad 721.21Snathanw# The TSD routines are used in the implementation of profiling, and so 731.21Snathanw# can't be profiled themselves. 741.44SadCOPTS.pthread_specific.c+= -fomit-frame-pointer -falign-functions=32 751.21Snathanwpthread_specific.po: pthread_specific.o 761.25Slukem ${_MKTARGET_CREATE} 771.21Snathanw cp pthread_specific.o pthread_specific.po 781.21Snathanw 791.42Sad# Internal spinlock routines are performance critical. Don't profile them, 801.42Sad# it's incompatibile with -fomit-frame-pointer. 811.42SadCOPTS.pthread_lock.c+= -fomit-frame-pointer -falign-functions=32 821.42Sadpthread_lock.po: pthread_lock.o 831.42Sad ${_MKTARGET_CREATE} 841.42Sad cp pthread_lock.o pthread_lock.po 851.42Sad 861.50SadCOPTS.pthread_mutex.c+= -fomit-frame-pointer -falign-functions=32 871.50Sadpthread_mutex.po: pthread_mutex.o 881.46Sad ${_MKTARGET_CREATE} 891.50Sad cp pthread_mutex.o pthread_mutex.po 901.46Sad 911.72SchristosCOPTS.pthread.c += -Wno-stack-protector -Wno-format-nonliteral 921.72SchristosCOPTS.pthread_attr.c += -Wno-format-nonliteral 931.45Sjnemeth 941.52SrmindMAN+= affinity.3 pthread.3 \ 951.48Syamt pthread_attr.3 \ 961.58Sjruoho pthread_attr_get_np.3 \ 971.60Sjruoho pthread_attr_getdetachstate.3 \ 981.62Sjruoho pthread_attr_getguardsize.3 \ 991.63Sjruoho pthread_attr_getinheritsched.3 \ 1001.48Syamt pthread_attr_getname_np.3 \ 1011.64Sjruoho pthread_attr_getschedparam.3 \ 1021.59Sjruoho pthread_attr_getscope.3 \ 1031.61Sjruoho pthread_attr_getstack.3 \ 1041.48Syamt pthread_attr_setcreatesuspend_np.3 \ 1051.66Srmind pthread_barrier.3 pthread_barrierattr.3 \ 1061.17Snathanw pthread_cancel.3 pthread_cleanup_push.3 \ 1071.66Srmind pthread_cond.3 pthread_condattr.3 \ 1081.66Srmind pthread_create.3 pthread_detach.3 pthread_equal.3 \ 1091.73Syamt pthread_curcpu_np.3 \ 1101.48Syamt pthread_exit.3 \ 1111.48Syamt pthread_getname_np.3 \ 1121.48Syamt pthread_getspecific.3 pthread_join.3 \ 1131.69Sjruoho pthread_key_create.3 pthread_kill.3 \ 1141.66Srmind pthread_mutex.3 pthread_mutexattr.3 \ 1151.66Srmind pthread_once.3 pthread_rwlock.3 pthread_rwlockattr.3 \ 1161.17Snathanw pthread_schedparam.3 pthread_self.3 \ 1171.69Sjruoho pthread_sigmask.3 pthread_spin.3 \ 1181.51Srmind pthread_suspend_np.3 pthread_testcancel.3 1191.17Snathanw 1201.70SchristosMLINKS+= pthread_attr_get_np.3 pthread_getattr_np.3 1211.52SrmindMLINKS+= affinity.3 pthread_setaffinity_np.3 1221.52SrmindMLINKS+= affinity.3 pthread_getaffinity_np.3 1231.57Sjruoho 1241.17SnathanwMLINKS+= pthread_attr.3 pthread_attr_init.3 1251.17SnathanwMLINKS+= pthread_attr.3 pthread_attr_destroy.3 1261.59Sjruoho 1271.60SjruohoMLINKS+= pthread_attr_getdetachstate.3 pthread_attr_setdetachstate.3 1281.62SjruohoMLINKS+= pthread_attr_getguardsize.3 pthread_attr_setguardsize.3 1291.63SjruohoMLINKS+= pthread_attr_getinheritsched.3 pthread_attr_setinheritsched.3 1301.68SjruohoMLINKS+= pthread_attr_getname_np.3 pthread_attr_setname_np.3 1311.67Sjruoho 1321.67SjruohoMLINKS+= pthread_attr_getschedparam.3 pthread_attr_setschedparam.3 \ 1331.67Sjruoho pthread_attr_getschedparam.3 pthread_attr_getschedpolicy.3 \ 1341.67Sjruoho pthread_attr_getschedparam.3 pthread_attr_setschedpolicy.3 1351.67Sjruoho 1361.59SjruohoMLINKS+= pthread_attr_getscope.3 pthread_attr_setscope.3 1371.67Sjruoho 1381.61SjruohoMLINKS+= pthread_attr_getstack.3 pthread_attr_setstack.3 \ 1391.61Sjruoho pthread_attr_getstack.3 pthread_attr_getstacksize.3 \ 1401.61Sjruoho pthread_attr_getstack.3 pthread_attr_setstacksize.3 \ 1411.61Sjruoho pthread_attr_getstack.3 pthread_attr_getstackaddr.3 \ 1421.61Sjruoho pthread_attr_getstack.3 pthread_attr_setstackaddr.3 1431.57Sjruoho 1441.66SrmindMLINKS+= pthread_cleanup_push.3 pthread_cleanup_pop.3 1451.66Srmind 1461.66SrmindMLINKS+= pthread_barrier.3 pthread_barrier_init.3 1471.66SrmindMLINKS+= pthread_barrier.3 pthread_barrier_destroy.3 1481.66SrmindMLINKS+= pthread_barrier.3 pthread_barrier_wait.3 1491.66Srmind 1501.32SpeterMLINKS+= pthread_barrierattr.3 pthread_barrierattr_init.3 1511.32SpeterMLINKS+= pthread_barrierattr.3 pthread_barrierattr_destroy.3 1521.66Srmind 1531.66SrmindMLINKS+= pthread_cond.3 pthread_cond_init.3 1541.66SrmindMLINKS+= pthread_cond.3 pthread_cond_destroy.3 1551.66SrmindMLINKS+= pthread_cond.3 pthread_cond_broadcast.3 1561.66SrmindMLINKS+= pthread_cond.3 pthread_cond_wait.3 1571.66SrmindMLINKS+= pthread_cond.3 pthread_cond_signal.3 1581.66SrmindMLINKS+= pthread_cond.3 pthread_cond_timedwait.3 1591.66Srmind 1601.17SnathanwMLINKS+= pthread_condattr.3 pthread_condattr_init.3 1611.17SnathanwMLINKS+= pthread_condattr.3 pthread_condattr_destroy.3 1621.66Srmind 1631.68SjruohoMLINKS+= pthread_getname_np.3 pthread_setname_np.3 1641.69SjruohoMLINKS+= pthread_getspecific.3 pthread_setspecific.3 1651.69SjruohoMLINKS+= pthread_key_create.3 pthread_key_delete.3 1661.68Sjruoho 1671.66SrmindMLINKS+= pthread_mutex.3 pthread_mutex_init.3 1681.66SrmindMLINKS+= pthread_mutex.3 pthread_mutex_destroy.3 1691.66SrmindMLINKS+= pthread_mutex.3 pthread_mutex_lock.3 1701.66SrmindMLINKS+= pthread_mutex.3 pthread_mutex_trylock.3 1711.66SrmindMLINKS+= pthread_mutex.3 pthread_mutex_unlock.3 1721.66Srmind 1731.17SnathanwMLINKS+= pthread_mutexattr.3 pthread_mutexattr_init.3 1741.17SnathanwMLINKS+= pthread_mutexattr.3 pthread_mutexattr_destroy.3 1751.17SnathanwMLINKS+= pthread_mutexattr.3 pthread_mutexattr_settype.3 1761.17SnathanwMLINKS+= pthread_mutexattr.3 pthread_mutexattr_gettype.3 1771.66Srmind 1781.66SrmindMLINKS+= pthread_rwlock.3 pthread_rwlock_init.3 1791.66SrmindMLINKS+= pthread_rwlock.3 pthread_rwlock_destroy.3 1801.66SrmindMLINKS+= pthread_rwlock.3 pthread_rwlock_rdlock.3 1811.66SrmindMLINKS+= pthread_rwlock.3 pthread_rwlock_wrlock.3 1821.66SrmindMLINKS+= pthread_rwlock.3 pthread_rwlock_unlock.3 1831.66Srmind 1841.66SrmindMLINKS+= pthread_rwlock.3 pthread_rwlock_timedrdlock.3 1851.66SrmindMLINKS+= pthread_rwlock.3 pthread_rwlock_timedwrlock.3 1861.66SrmindMLINKS+= pthread_rwlock.3 pthread_rwlock_tryrdlock.3 1871.66SrmindMLINKS+= pthread_rwlock.3 pthread_rwlock_trywrlock.3 1881.66Srmind 1891.17SnathanwMLINKS+= pthread_rwlockattr.3 pthread_rwlockattr_init.3 1901.17SnathanwMLINKS+= pthread_rwlockattr.3 pthread_rwlockattr_destroy.3 1911.66Srmind 1921.66SrmindMLINKS+= pthread_spin.3 pthread_spin_init.3 1931.66SrmindMLINKS+= pthread_spin.3 pthread_spin_destroy.3 1941.66SrmindMLINKS+= pthread_spin.3 pthread_spin_lock.3 1951.66SrmindMLINKS+= pthread_spin.3 pthread_spin_trylock.3 1961.66SrmindMLINKS+= pthread_spin.3 pthread_spin_unlock.3 1971.66Srmind 1981.17SnathanwMLINKS+= pthread_schedparam.3 pthread_setschedparam.3 1991.17SnathanwMLINKS+= pthread_schedparam.3 pthread_getschedparam.3 2001.23SchristosMLINKS+= pthread_suspend_np.3 pthread_resume_np.3 2011.17SnathanwMLINKS+= pthread_testcancel.3 pthread_setcancelstate.3 2021.17SnathanwMLINKS+= pthread_testcancel.3 pthread_setcanceltype.3 2031.9Sthorpej 2041.1Sproven.include <bsd.lib.mk> 2051.1Sproven 2061.9Sthorpej.else 2071.9Sthorpej 2081.9Sthorpej.include <bsd.man.mk> 2091.10Sthorpej.include <bsd.files.mk> 2101.10Sthorpej.include <bsd.inc.mk> 2111.9Sthorpej 2121.9Sthorpej.endif 2131.9Sthorpej 2141.9Sthorpej# WARNS=2 sets -Wcast-qual. This causes problems for one of 2151.9Sthorpej# pthread_setspecific() and pthread_getspecific(), since the constness 2161.9Sthorpej# of the argument to setspecific() has to be discarded *somewhere* 2171.9Sthorpej# before returning it from getspecific(). 2181.9SthorpejCFLAGS+= -Wno-cast-qual 219