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