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