Makefile revision 1.32
11.32Speter# $NetBSD: Makefile,v 1.32 2005/06/17 18:23:19 peter Exp $ 21.9Sthorpej# 31.9Sthorpej 41.9SthorpejWARNS= 2 51.24Scl 61.24Scl# Define PT_FIXEDSTACKSIZE_LG to set a fixed stacksize 71.24Scl#CPPFLAGS+=-DPT_FIXEDSTACKSIZE_LG=18 81.9Sthorpej 91.9Sthorpej.include <bsd.own.mk> 101.9Sthorpej 111.9Sthorpej.if 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.30SchristosCPPFLAGS+= -D__LIBPTHREAD_SOURCE__ -DPTHREAD_MLOCK_KLUDGE 301.9Sthorpej 311.9SthorpejDPSRCS+= assym.h 321.20SlukemCLEANFILES+= assym.h 331.9Sthorpej 341.31Sthorpejassym.h: ${ARCHDIR}/genassym.cf pthread.h pthread_int.h pthread_md.h 351.25Slukem ${_MKTARGET_CREATE} 361.31Sthorpej ${TOOL_GENASSYM} -- ${CC} ${CFLAGS} ${CPPFLAGS} ${PROF} \ 371.9Sthorpej < ${ARCHDIR}/genassym.cf > assym.h.tmp && \ 381.9Sthorpej mv -f assym.h.tmp assym.h 391.9Sthorpej 401.9SthorpejLIB= pthread 411.9Sthorpej 421.9Sthorpej# 431.9Sthorpej# NOTE: When you create a new file for libpthread, make sure that pthread.c 441.9Sthorpej# gets a reference to a symbol in that file. Otherwise, Unix's stupid static 451.9Sthorpej# library semantics will end up discarding potentially important objects. 461.9Sthorpej# 471.9SthorpejSRCS= pthread.c 481.9SthorpejSRCS+= pthread_alarms.c 491.18SnathanwSRCS+= pthread_attr.c 501.9SthorpejSRCS+= pthread_barrier.c 511.9SthorpejSRCS+= pthread_cancelstub.c 521.9SthorpejSRCS+= pthread_cond.c 531.9SthorpejSRCS+= pthread_lock.c 541.9SthorpejSRCS+= pthread_mutex.c 551.9SthorpejSRCS+= pthread_run.c 561.9SthorpejSRCS+= pthread_rwlock.c 571.9SthorpejSRCS+= pthread_sa.c 581.9SthorpejSRCS+= pthread_sig.c 591.16SnathanwSRCS+= pthread_sleep.c 601.9SthorpejSRCS+= pthread_specific.c 611.9SthorpejSRCS+= pthread_stack.c 621.21SnathanwSRCS+= pthread_tsd.c 631.9SthorpejSRCS+= pthread_debug.c 641.26SchristosSRCS+= res_state.c 651.9SthorpejSRCS+= sched.c 661.11SchristosSRCS+= sem.c 671.9Sthorpej# Architecture-dependent files 681.9SthorpejSRCS+= pthread_switch.S _context_u.S 691.9Sthorpej.if exists(${ARCHDIR}/pthread_md.c) 701.9SthorpejSRCS+= pthread_md.c 711.9Sthorpej.endif 721.21Snathanw 731.21Snathanw# The TSD routines are used in the implementation of profiling, and so 741.21Snathanw# can't be profiled themselves. 751.21Snathanwpthread_specific.po: pthread_specific.o 761.25Slukem ${_MKTARGET_CREATE} 771.21Snathanw cp pthread_specific.o pthread_specific.po 781.21Snathanw 791.21Snathanw_context_u.po: _context_u.o 801.25Slukem ${_MKTARGET_CREATE} 811.21Snathanw cp _context_u.o _context_u.po 821.17Snathanw 831.19SwizMAN+= pthread.3 \ 841.23Schristos pthread_attr.3 pthread_attr_setcreatesuspend_np.3 \ 851.17Snathanw pthread_barrier_destroy.3 pthread_barrier_init.3 \ 861.17Snathanw pthread_barrier_wait.3 pthread_barrierattr.3 \ 871.17Snathanw pthread_cancel.3 pthread_cleanup_push.3 \ 881.17Snathanw pthread_cond_broadcast.3 pthread_cond_destroy.3 pthread_cond_init.3 \ 891.17Snathanw pthread_cond_wait.3 \ 901.17Snathanw pthread_condattr.3 pthread_create.3 pthread_detach.3 pthread_equal.3 \ 911.17Snathanw pthread_exit.3 pthread_getspecific.3 pthread_join.3 \ 921.17Snathanw pthread_key_create.3 pthread_key_delete.3 pthread_kill.3 \ 931.17Snathanw pthread_mutex_destroy.3 pthread_mutex_init.3 pthread_mutex_lock.3 \ 941.17Snathanw pthread_mutex_unlock.3 pthread_mutexattr.3 \ 951.17Snathanw pthread_once.3 pthread_rwlock_destroy.3 pthread_rwlock_init.3 \ 961.17Snathanw pthread_rwlock_rdlock.3 pthread_rwlock_unlock.3 \ 971.17Snathanw pthread_rwlock_wrlock.3 pthread_rwlockattr.3 \ 981.17Snathanw pthread_schedparam.3 pthread_self.3 \ 991.17Snathanw pthread_setspecific.3 pthread_sigmask.3 pthread_spin_destroy.3 \ 1001.17Snathanw pthread_spin_init.3 pthread_spin_lock.3 pthread_spin_unlock.3 \ 1011.29Syamt pthread_suspend_np.3 pthread_testcancel.3 \ 1021.29Syamt sched_yield.3 1031.17Snathanw 1041.17SnathanwMLINKS+= pthread_attr.3 pthread_attr_init.3 1051.17SnathanwMLINKS+= pthread_attr.3 pthread_attr_destroy.3 1061.17SnathanwMLINKS+= pthread_attr.3 pthread_attr_setdetachstate.3 1071.17SnathanwMLINKS+= pthread_attr.3 pthread_attr_getdetachstate.3 1081.32SpeterMLINKS+= pthread_barrierattr.3 pthread_barrierattr_init.3 1091.32SpeterMLINKS+= pthread_barrierattr.3 pthread_barrierattr_destroy.3 1101.17SnathanwMLINKS+= pthread_cleanup_push.3 pthread_cleanup_pop.3 1111.17SnathanwMLINKS+= pthread_cond_broadcast.3 pthread_cond_signal.3 1121.17SnathanwMLINKS+= pthread_cond_wait.3 pthread_cond_timedwait.3 1131.17SnathanwMLINKS+= pthread_condattr.3 pthread_condattr_init.3 1141.17SnathanwMLINKS+= pthread_condattr.3 pthread_condattr_destroy.3 1151.17SnathanwMLINKS+= pthread_mutex_lock.3 pthread_mutex_trylock.3 1161.17SnathanwMLINKS+= pthread_mutexattr.3 pthread_mutexattr_init.3 1171.17SnathanwMLINKS+= pthread_mutexattr.3 pthread_mutexattr_destroy.3 1181.17SnathanwMLINKS+= pthread_mutexattr.3 pthread_mutexattr_settype.3 1191.17SnathanwMLINKS+= pthread_mutexattr.3 pthread_mutexattr_gettype.3 1201.17SnathanwMLINKS+= pthread_rwlock_rdlock.3 pthread_rwlock_timedrdlock.3 1211.17SnathanwMLINKS+= pthread_rwlock_rdlock.3 pthread_rwlock_tryrdlock.3 1221.17SnathanwMLINKS+= pthread_rwlock_wrlock.3 pthread_rwlock_timedwrlock.3 1231.17SnathanwMLINKS+= pthread_rwlock_wrlock.3 pthread_rwlock_trywrlock.3 1241.17SnathanwMLINKS+= pthread_rwlockattr.3 pthread_rwlockattr_init.3 1251.17SnathanwMLINKS+= pthread_rwlockattr.3 pthread_rwlockattr_destroy.3 1261.17SnathanwMLINKS+= pthread_schedparam.3 pthread_setschedparam.3 1271.17SnathanwMLINKS+= pthread_schedparam.3 pthread_getschedparam.3 1281.27SpookaMLINKS+= pthread_spin_lock.3 pthread_spin_trylock.3 1291.23SchristosMLINKS+= pthread_suspend_np.3 pthread_resume_np.3 1301.17SnathanwMLINKS+= pthread_testcancel.3 pthread_setcancelstate.3 1311.17SnathanwMLINKS+= pthread_testcancel.3 pthread_setcanceltype.3 1321.9Sthorpej 1331.9Sthorpejpthread_switch.S _context_u.S: assym.h 1341.9Sthorpej 1351.9Sthorpejdebuglog: debuglog.o 1361.9Sthorpej $(CC) -o debuglog debuglog.o -lpthread 1371.1Sproven 1381.1Sproven.include <bsd.lib.mk> 1391.1Sproven 1401.9Sthorpej.else 1411.9Sthorpej 1421.9Sthorpej.include <bsd.man.mk> 1431.10Sthorpej.include <bsd.files.mk> 1441.10Sthorpej.include <bsd.inc.mk> 1451.9Sthorpej 1461.9Sthorpej.endif 1471.9Sthorpej 1481.9Sthorpej# WARNS=2 sets -Wcast-qual. This causes problems for one of 1491.9Sthorpej# pthread_setspecific() and pthread_getspecific(), since the constness 1501.9Sthorpej# of the argument to setspecific() has to be discarded *somewhere* 1511.9Sthorpej# before returning it from getspecific(). 1521.9SthorpejCFLAGS+= -Wno-cast-qual 153