1*d3f52b84Sriastradh# $NetBSD: Makefile,v 1.99 2024/11/22 15:51:34 riastradh Exp $ 2c62a74e6Sthorpej# 3c62a74e6Sthorpej 4aa669564SchristosNOSANITIZER= # defined 5fa835e8cSmattWARNS?= 5 6082d249aSpookaLIB= pthread 7c62a74e6Sthorpej 8c62a74e6Sthorpej.include <bsd.own.mk> 9c62a74e6Sthorpej 102e0a3287SbradUSE_SHLIBDIR= yes 112e0a3287Sbrad 12fb8d95d8Smrg.if defined(PTHREAD_MACHINE_ARCH) && !empty(PTHREAD_MACHINE_ARCH) && \ 13fb8d95d8Smrg exists(${.CURDIR}/arch/${PTHREAD_MACHINE_ARCH}) 14fb8d95d8SmrgARCHSUBDIR= ${PTHREAD_MACHINE_ARCH} 1511614bb2Smatt.elif defined(PTHREAD_MACHINE_CPU) && !empty(PTHREAD_MACHINE_CPU) && \ 1611614bb2Smatt exists(${.CURDIR}/arch/${PTHREAD_MACHINE_CPU}) 1711614bb2SmattARCHSUBDIR= ${PTHREAD_MACHINE_CPU} 18fb8d95d8Smrg.elif exists(${.CURDIR}/arch/${MACHINE_ARCH}) 19c62a74e6SthorpejARCHSUBDIR= ${MACHINE_ARCH} 20c62a74e6Sthorpej.elif exists(${.CURDIR}/arch/${MACHINE_CPU}) 21c62a74e6SthorpejARCHSUBDIR= ${MACHINE_CPU} 22c62a74e6Sthorpej.else 23c62a74e6Sthorpej.BEGIN: 24439830cbSthorpej @echo "WARNING: no ARCHSUBDIR for ${MACHINE_ARCH}/${MACHINE_CPU}; skipping..." 25c62a74e6Sthorpej.endif 26c62a74e6Sthorpej 27439830cbSthorpejINCS= pthread.h pthread_types.h pthread_queue.h 28439830cbSthorpejINCSDIR=/usr/include 29439830cbSthorpej 30c62a74e6Sthorpej.if defined(ARCHSUBDIR) 31c62a74e6Sthorpej 32c62a74e6SthorpejARCHDIR= ${.CURDIR}/arch/${ARCHSUBDIR} 33c62a74e6Sthorpej.PATH: ${ARCHDIR} 34c62a74e6Sthorpej 35*d3f52b84SriastradhEXPSYM_SRCS+= pthread_mi.expsym 36*d3f52b84Sriastradh. if ${MACHINE_ARCH} == "alpha" || ${MACHINE_ARCH} == "hppa" 37*d3f52b84Sriastradh# PTHREAD__ASM_RASOPS 38*d3f52b84SriastradhEXPSYM_SRCS+= pthread_md.expsym 39*d3f52b84Sriastradh. else 40*d3f52b84Sriastradh# !PTHREAD__ASM_RASOPS 41*d3f52b84Sriastradh# XXX These really shouldn't be exported. 42*d3f52b84SriastradhEXPSYM_SRCS+= pthread_ras.expsym 43*d3f52b84Sriastradh. endif 44*d3f52b84Sriastradh 45*d3f52b84SriastradhLIB_EXPSYM= pthread.expsym 46*d3f52b84Sriastradhpthread.expsym: ${EXPSYM_SRCS} 47*d3f52b84Sriastradh ${_MKTARGET_CREATE} 48*d3f52b84Sriastradh LC_ALL=C sort -m ${.ALLSRC} >${.TARGET}.tmp && \ 49*d3f52b84Sriastradh ${MV} ${.TARGET}.tmp ${.TARGET} 50*d3f52b84SriastradhCLEANFILES+= pthread.expsym pthread.expsym.tmp 51*d3f52b84Sriastradh 5271d484f9SchristosCPPFLAGS+= -I${ARCHDIR} -I${.CURDIR} -I${.OBJDIR} -D_LIBC -D_REENTRANT 5371d484f9SchristosCPPFLAGS+= -I${.CURDIR}/../libc/include 5471d484f9SchristosCPPFLAGS+= -D__LIBPTHREAD_SOURCE__ -D__LIBC_THREAD_STUBS 55c62a74e6Sthorpej 5676c7fc5fSjoerg# Since <pthread.h> is not used, allow declaring pthread_create and 5776c7fc5fSjoerg# friends locally. 5876c7fc5fSjoergCWARNFLAGS.clang+= -Wno-builtin-requires-header 5976c7fc5fSjoerg 60d7e5caf4Schristos# XXX: This crappy poke at libc's internals needs to be fixed. 61d7e5caf4SchristosCPPFLAGS+=-I${NETBSDSRCDIR}/sys -I${.CURDIR}/../libc 62d7e5caf4Schristos 63082d249aSpooka# providing alternative MI implementations for creating an lwp is 64082d249aSpooka# possible by setting PTHREAD_MAKELWP. Currently, alternatives are 65cfee6e91Slukem# set by the rumprun software stacks (see https://github.com/rumpkernel/rumprun ) 66082d249aSpookaPTHREAD_MAKELWP?= pthread_makelwp_netbsd.c 67c62a74e6Sthorpej 68c62a74e6Sthorpej# 69c62a74e6Sthorpej# NOTE: When you create a new file for libpthread, make sure that pthread.c 70c62a74e6Sthorpej# gets a reference to a symbol in that file. Otherwise, Unix's stupid static 71c62a74e6Sthorpej# library semantics will end up discarding potentially important objects. 72c62a74e6Sthorpej# 73c62a74e6SthorpejSRCS= pthread.c 74ec2c1698SnathanwSRCS+= pthread_attr.c 75c62a74e6SthorpejSRCS+= pthread_barrier.c 76082d249aSpooka# used by rumprun-posix to work around symbol collisions 77082d249aSpooka.if ${PTHREAD_CANCELSTUB:Uyes} != "no" 78c62a74e6SthorpejSRCS+= pthread_cancelstub.c 79082d249aSpooka.endif 80c62a74e6SthorpejSRCS+= pthread_cond.c 81d394d2a9SchristosSRCS+= pthread_getcpuclockid.c 82c62a74e6SthorpejSRCS+= pthread_lock.c 83082d249aSpookaSRCS+= ${PTHREAD_MAKELWP} 84de213816SadSRCS+= pthread_misc.c 85c62a74e6SthorpejSRCS+= pthread_mutex.c 8677bfe129SjoergSRCS+= pthread_once.c 87c62a74e6SthorpejSRCS+= pthread_rwlock.c 88c62a74e6SthorpejSRCS+= pthread_specific.c 89d9adedd7SadSRCS+= pthread_spin.c 90bd9a18b7SnathanwSRCS+= pthread_tsd.c 919b99e159SchristosSRCS+= res_state.c 9268e270a2Sthorpej.PATH: ${.CURDIR}/../librt 9390135cf7SchristosSRCS+= sem.c 94c62a74e6Sthorpej# Architecture-dependent files 95a61915e9Sad.if exists(${ARCHDIR}/pthread_md.S) 96a61915e9SadSRCS+= pthread_md.S 97c62a74e6Sthorpej.endif 9806cb4b73Smatt.if exists(${ARCHDIR}/Makefile.inc) 9906cb4b73Smatt.include "${ARCHDIR}/Makefile.inc" 10006cb4b73Smatt.endif 101c62a74e6Sthorpej 1026cee3c7cSapb# The PTHREAD__COMPAT flag builds a libpthread that can be dropped 1036cee3c7cSapb# into a NetBSD 2/3/4 chroot with a NetBSD 5 or later kernel. 1046cee3c7cSapb# This makes threading work in the chroot, no other modifications 1056cee3c7cSapb# required. 1066cee3c7cSapb# 107844fcfc9Sad.if defined(PTHREAD__COMPAT) 108844fcfc9SadSRCS+= pthread_compat.c 109844fcfc9Sad.PATH.c: ${.CURDIR}/../../common/lib/libc/arch/${ARCHSUBDIR}/atomic 110844fcfc9Sad.PATH.S: ${.CURDIR}/../../common/lib/libc/arch/${ARCHSUBDIR}/atomic 111844fcfc9Sad.PATH.c: ${.CURDIR}/../../common/lib/libc/atomic 112844fcfc9Sad.PATH.c: ${.CURDIR}/../libc/misc 113844fcfc9Sad.include "../../common/lib/libc/arch/${ARCHSUBDIR}/atomic/Makefile.inc" 114844fcfc9Sad.endif 115844fcfc9Sad 116b757af43SjoergALIGN_FUNCTIONS= ${${ACTIVE_CC} == "gcc":? -falign-functions=32 :} 117b757af43Sjoerg 118bd9a18b7Snathanw# The TSD routines are used in the implementation of profiling, and so 119bd9a18b7Snathanw# can't be profiled themselves. 1209f52f229SchsCOPTS.pthread_specific.c+= ${ALIGN_FUNCTIONS} 121bd9a18b7Snathanwpthread_specific.po: pthread_specific.o 122d597f546Slukem ${_MKTARGET_CREATE} 123bd9a18b7Snathanw cp pthread_specific.o pthread_specific.po 124bd9a18b7Snathanw 1255353040fSchristosCOPTS.pthread.c += -Wno-stack-protector -Wno-format-nonliteral 1265353040fSchristosCOPTS.pthread_attr.c += -Wno-format-nonliteral 12766687b0cSjnemeth 128e6acd90eSrmindMAN+= affinity.3 pthread.3 \ 12945cbede9Syamt pthread_attr.3 \ 130935deb26Sjruoho pthread_attr_get_np.3 \ 131dbb0e63cSjruoho pthread_attr_getdetachstate.3 \ 132904af291Sjruoho pthread_attr_getguardsize.3 \ 133cf6053f7Sjruoho pthread_attr_getinheritsched.3 \ 13445cbede9Syamt pthread_attr_getname_np.3 \ 135edddb28aSjruoho pthread_attr_getschedparam.3 \ 13669ff1aa9Sjruoho pthread_attr_getscope.3 \ 1372bf45345Sjruoho pthread_attr_getstack.3 \ 13845cbede9Syamt pthread_attr_setcreatesuspend_np.3 \ 139d199be97Srmind pthread_barrier.3 pthread_barrierattr.3 \ 14033314cffSnathanw pthread_cancel.3 pthread_cleanup_push.3 \ 141d199be97Srmind pthread_cond.3 pthread_condattr.3 \ 142d199be97Srmind pthread_create.3 pthread_detach.3 pthread_equal.3 \ 1439c5d9163Syamt pthread_curcpu_np.3 \ 14445cbede9Syamt pthread_exit.3 \ 145d394d2a9Schristos pthread_getcpuclockid.3 \ 14645cbede9Syamt pthread_getname_np.3 \ 14745cbede9Syamt pthread_getspecific.3 pthread_join.3 \ 1486aa48921Sjruoho pthread_key_create.3 pthread_kill.3 \ 149d199be97Srmind pthread_mutex.3 pthread_mutexattr.3 \ 150d199be97Srmind pthread_once.3 pthread_rwlock.3 pthread_rwlockattr.3 \ 15133314cffSnathanw pthread_schedparam.3 pthread_self.3 \ 1526aa48921Sjruoho pthread_sigmask.3 pthread_spin.3 \ 1532ac12931Srmind pthread_suspend_np.3 pthread_testcancel.3 15433314cffSnathanw 155ea1f852aSchristosMLINKS+= pthread_attr_get_np.3 pthread_getattr_np.3 156e6acd90eSrmindMLINKS+= affinity.3 pthread_setaffinity_np.3 157e6acd90eSrmindMLINKS+= affinity.3 pthread_getaffinity_np.3 1589bfaa34dSjruoho 15933314cffSnathanwMLINKS+= pthread_attr.3 pthread_attr_init.3 16033314cffSnathanwMLINKS+= pthread_attr.3 pthread_attr_destroy.3 16169ff1aa9Sjruoho 162dbb0e63cSjruohoMLINKS+= pthread_attr_getdetachstate.3 pthread_attr_setdetachstate.3 163904af291SjruohoMLINKS+= pthread_attr_getguardsize.3 pthread_attr_setguardsize.3 164cf6053f7SjruohoMLINKS+= pthread_attr_getinheritsched.3 pthread_attr_setinheritsched.3 1653cc3be4dSjruohoMLINKS+= pthread_attr_getname_np.3 pthread_attr_setname_np.3 166ec0cdba3Sjruoho 167ec0cdba3SjruohoMLINKS+= pthread_attr_getschedparam.3 pthread_attr_setschedparam.3 \ 168ec0cdba3Sjruoho pthread_attr_getschedparam.3 pthread_attr_getschedpolicy.3 \ 169ec0cdba3Sjruoho pthread_attr_getschedparam.3 pthread_attr_setschedpolicy.3 170ec0cdba3Sjruoho 17169ff1aa9SjruohoMLINKS+= pthread_attr_getscope.3 pthread_attr_setscope.3 172ec0cdba3Sjruoho 1732bf45345SjruohoMLINKS+= pthread_attr_getstack.3 pthread_attr_setstack.3 \ 1742bf45345Sjruoho pthread_attr_getstack.3 pthread_attr_getstacksize.3 \ 1752bf45345Sjruoho pthread_attr_getstack.3 pthread_attr_setstacksize.3 \ 1762bf45345Sjruoho pthread_attr_getstack.3 pthread_attr_getstackaddr.3 \ 1772bf45345Sjruoho pthread_attr_getstack.3 pthread_attr_setstackaddr.3 1789bfaa34dSjruoho 179d199be97SrmindMLINKS+= pthread_cleanup_push.3 pthread_cleanup_pop.3 180d199be97Srmind 181d199be97SrmindMLINKS+= pthread_barrier.3 pthread_barrier_init.3 182d199be97SrmindMLINKS+= pthread_barrier.3 pthread_barrier_destroy.3 183d199be97SrmindMLINKS+= pthread_barrier.3 pthread_barrier_wait.3 184d199be97Srmind 185a28acffeSpeterMLINKS+= pthread_barrierattr.3 pthread_barrierattr_init.3 186a28acffeSpeterMLINKS+= pthread_barrierattr.3 pthread_barrierattr_destroy.3 1877cf7644fSchristosMLINKS+= pthread_barrierattr.3 pthread_barrierattr_getpshared.3 1887cf7644fSchristosMLINKS+= pthread_barrierattr.3 pthread_barrierattr_setpshared.3 189d199be97Srmind 190d199be97SrmindMLINKS+= pthread_cond.3 pthread_cond_init.3 191d199be97SrmindMLINKS+= pthread_cond.3 pthread_cond_destroy.3 192d199be97SrmindMLINKS+= pthread_cond.3 pthread_cond_broadcast.3 193d199be97SrmindMLINKS+= pthread_cond.3 pthread_cond_wait.3 194d199be97SrmindMLINKS+= pthread_cond.3 pthread_cond_signal.3 195d199be97SrmindMLINKS+= pthread_cond.3 pthread_cond_timedwait.3 196d199be97Srmind 19733314cffSnathanwMLINKS+= pthread_condattr.3 pthread_condattr_init.3 19833314cffSnathanwMLINKS+= pthread_condattr.3 pthread_condattr_destroy.3 199d8632819SriastradhMLINKS+= pthread_condattr.3 pthread_condattr_setclock.3 2007cf7644fSchristosMLINKS+= pthread_condattr.3 pthread_condattr_getclock.3 2017cf7644fSchristosMLINKS+= pthread_condattr.3 pthread_condattr_getpshared.3 2027cf7644fSchristosMLINKS+= pthread_condattr.3 pthread_condattr_setpshared.3 203d199be97Srmind 2043cc3be4dSjruohoMLINKS+= pthread_getname_np.3 pthread_setname_np.3 2056aa48921SjruohoMLINKS+= pthread_getspecific.3 pthread_setspecific.3 2066aa48921SjruohoMLINKS+= pthread_key_create.3 pthread_key_delete.3 2073cc3be4dSjruoho 208d199be97SrmindMLINKS+= pthread_mutex.3 pthread_mutex_init.3 209d199be97SrmindMLINKS+= pthread_mutex.3 pthread_mutex_destroy.3 210d199be97SrmindMLINKS+= pthread_mutex.3 pthread_mutex_lock.3 211d199be97SrmindMLINKS+= pthread_mutex.3 pthread_mutex_trylock.3 212d199be97SrmindMLINKS+= pthread_mutex.3 pthread_mutex_unlock.3 2137cf7644fSchristosMLINKS+= pthread_mutex.3 pthread_mutex_timedlock.3 2147cf7644fSchristosMLINKS+= pthread_mutex.3 pthread_mutex_getprioceiling.3 2157cf7644fSchristosMLINKS+= pthread_mutex.3 pthread_mutex_setprioceiling.3 216d199be97Srmind 21733314cffSnathanwMLINKS+= pthread_mutexattr.3 pthread_mutexattr_init.3 21833314cffSnathanwMLINKS+= pthread_mutexattr.3 pthread_mutexattr_destroy.3 2197cf7644fSchristosMLINKS+= pthread_mutexattr.3 pthread_mutexattr_getpshared.3 2207cf7644fSchristosMLINKS+= pthread_mutexattr.3 pthread_mutexattr_setpshared.3 22133314cffSnathanwMLINKS+= pthread_mutexattr.3 pthread_mutexattr_settype.3 22233314cffSnathanwMLINKS+= pthread_mutexattr.3 pthread_mutexattr_gettype.3 2237cf7644fSchristosMLINKS+= pthread_mutexattr.3 pthread_mutexattr_getprotocol.3 2247cf7644fSchristosMLINKS+= pthread_mutexattr.3 pthread_mutexattr_setprotocol.3 2257cf7644fSchristosMLINKS+= pthread_mutexattr.3 pthread_mutexattr_getprioceiling.3 2267cf7644fSchristosMLINKS+= pthread_mutexattr.3 pthread_mutexattr_setprioceiling.3 227d199be97Srmind 228d199be97SrmindMLINKS+= pthread_rwlock.3 pthread_rwlock_init.3 229d199be97SrmindMLINKS+= pthread_rwlock.3 pthread_rwlock_destroy.3 230d199be97SrmindMLINKS+= pthread_rwlock.3 pthread_rwlock_rdlock.3 231d199be97SrmindMLINKS+= pthread_rwlock.3 pthread_rwlock_wrlock.3 232d199be97SrmindMLINKS+= pthread_rwlock.3 pthread_rwlock_unlock.3 233d199be97Srmind 234d199be97SrmindMLINKS+= pthread_rwlock.3 pthread_rwlock_timedrdlock.3 235d199be97SrmindMLINKS+= pthread_rwlock.3 pthread_rwlock_timedwrlock.3 236d199be97SrmindMLINKS+= pthread_rwlock.3 pthread_rwlock_tryrdlock.3 237d199be97SrmindMLINKS+= pthread_rwlock.3 pthread_rwlock_trywrlock.3 238d199be97Srmind 23933314cffSnathanwMLINKS+= pthread_rwlockattr.3 pthread_rwlockattr_init.3 24033314cffSnathanwMLINKS+= pthread_rwlockattr.3 pthread_rwlockattr_destroy.3 2417cf7644fSchristosMLINKS+= pthread_rwlockattr.3 pthread_rwlockattr_getpshared.3 2427cf7644fSchristosMLINKS+= pthread_rwlockattr.3 pthread_rwlockattr_setpshared.3 243d199be97Srmind 244d199be97SrmindMLINKS+= pthread_spin.3 pthread_spin_init.3 245d199be97SrmindMLINKS+= pthread_spin.3 pthread_spin_destroy.3 246d199be97SrmindMLINKS+= pthread_spin.3 pthread_spin_lock.3 247d199be97SrmindMLINKS+= pthread_spin.3 pthread_spin_trylock.3 248d199be97SrmindMLINKS+= pthread_spin.3 pthread_spin_unlock.3 249d199be97Srmind 25033314cffSnathanwMLINKS+= pthread_schedparam.3 pthread_setschedparam.3 25133314cffSnathanwMLINKS+= pthread_schedparam.3 pthread_getschedparam.3 252c8608b90SchristosMLINKS+= pthread_suspend_np.3 pthread_resume_np.3 25333314cffSnathanwMLINKS+= pthread_testcancel.3 pthread_setcancelstate.3 25433314cffSnathanwMLINKS+= pthread_testcancel.3 pthread_setcanceltype.3 25533314cffSnathanw 256a9ca1710Skamil# ISO C threads (ISO/IEC 9899:2011) 257a9ca1710Skamil 258a9ca1710SkamilSRCS+= call_once.c cnd.c mtx.c thrd.c tss.c 259a9ca1710SkamilMAN+= threads.3 call_once.3 cnd.3 mtx.3 thrd.3 tss.3 260a9ca1710Skamil 261a9ca1710SkamilMLINKS+= call_once.3 ONCE_FLAG_INIT.3 262a9ca1710SkamilMLINKS+= call_once.3 once_flag.3 263a9ca1710Skamil 264a9ca1710SkamilMLINKS+= cnd.3 cnd_broadcast.3 265a9ca1710SkamilMLINKS+= cnd.3 cnd_destroy.3 266a9ca1710SkamilMLINKS+= cnd.3 cnd_init.3 267a9ca1710SkamilMLINKS+= cnd.3 cnd_signal.3 268a9ca1710SkamilMLINKS+= cnd.3 cnd_timedwait.3 269a9ca1710SkamilMLINKS+= cnd.3 cnd_wait.3 270a9ca1710Skamil 271a9ca1710SkamilMLINKS+= mtx.3 mtx_destroy.3 272a9ca1710SkamilMLINKS+= mtx.3 mtx_init.3 273a9ca1710SkamilMLINKS+= mtx.3 mtx_lock.3 274a9ca1710SkamilMLINKS+= mtx.3 mtx_timedlock.3 275a9ca1710SkamilMLINKS+= mtx.3 mtx_trylock.3 276a9ca1710SkamilMLINKS+= mtx.3 mtx_unlock.3 277a9ca1710Skamil 278a9ca1710SkamilMLINKS+= thrd.3 thrd_create.3 279a9ca1710SkamilMLINKS+= thrd.3 thrd_current.3 280a9ca1710SkamilMLINKS+= thrd.3 thrd_detach.3 281a9ca1710SkamilMLINKS+= thrd.3 thrd_equal.3 282a9ca1710SkamilMLINKS+= thrd.3 thrd_exit.3 283a9ca1710SkamilMLINKS+= thrd.3 thrd_join.3 284a9ca1710SkamilMLINKS+= thrd.3 thrd_sleep.3 285a9ca1710SkamilMLINKS+= thrd.3 thrd_yield.3 286a9ca1710Skamil 287a9ca1710SkamilMLINKS+= tss.3 TSS_DTOR_ITERATIONS.3 288a9ca1710SkamilMLINKS+= tss.3 tss_create.3 289a9ca1710SkamilMLINKS+= tss.3 tss_delete.3 290a9ca1710SkamilMLINKS+= tss.3 tss_get.3 291a9ca1710SkamilMLINKS+= tss.3 tss_set.3 292a9ca1710Skamil 293a9ca1710SkamilINCS+= threads.h 294a9ca1710Skamil 29553af5ae4Smaya# PR lib/54001: create libpthread.a as a single large object, with all the 29653af5ae4Smaya# symbols in one section. ensures that if any libpthread function is used, 29753af5ae4Smaya# you get all of them from libpthread, and not the libc stubs. 29853af5ae4Smaya# 29953af5ae4Smaya# This makes -lpthread equivalent to -Wl,--whole-archive -lpthread 30053af5ae4Smaya 30153af5ae4Smaya__archivebuild: .USE 30253af5ae4Smaya ${_MKTARGET_BUILD} 30353af5ae4Smaya @rm -f ${.TARGET} 30453af5ae4Smaya ${LD} -r -o ${.TARGET}.o `NM=${NM} ${LORDER} ${.ALLSRC:M*o} | ${TSORT}` 30553af5ae4Smaya ${AR} ${_ARFL} ${.TARGET} ${.TARGET}.o 30653af5ae4Smaya 30707975b22SmayaCLEANFILES+= ${_LIBS:=.o} 30853af5ae4Smaya 309c62a74e6Sthorpej.include <bsd.lib.mk> 310c62a74e6Sthorpej 311c62a74e6Sthorpej.else 312c62a74e6Sthorpej 313c62a74e6Sthorpej.include <bsd.man.mk> 314439830cbSthorpej.include <bsd.files.mk> 315439830cbSthorpej.include <bsd.inc.mk> 316c62a74e6Sthorpej 317c62a74e6Sthorpej.endif 318c62a74e6Sthorpej 319c62a74e6Sthorpej# WARNS=2 sets -Wcast-qual. This causes problems for one of 320c62a74e6Sthorpej# pthread_setspecific() and pthread_getspecific(), since the constness 321c62a74e6Sthorpej# of the argument to setspecific() has to be discarded *somewhere* 322c62a74e6Sthorpej# before returning it from getspecific(). 323234b0534SmattCWARNFLAGS+= -Wno-cast-qual 324