diff options
Diffstat (limited to '')
-rw-r--r-- | auto/threads | 282 |
1 files changed, 282 insertions, 0 deletions
diff --git a/auto/threads b/auto/threads new file mode 100644 index 00000000..9187caab --- /dev/null +++ b/auto/threads @@ -0,0 +1,282 @@ + +# Copyright (C) Igor Sysoev +# Copyright (C) NGINX, Inc. + + +case "$NXT_SYSTEM" in + + Linux) + NXT_PTHREAD="-lpthread" + ;; + + FreeBSD) + # FreeBSD libc supports only pthread stubs. + NXT_PTHREAD="-lpthread" + ;; + + SunOS) + case "$NXT_SYSTEM_VERSION" in + 5.8 | 5.9) + NXT_PTHREAD="-lpthread" + ;; + *) + # Solaris 10 libpthread.so.1 is a filter to libc.so.1. + NXT_PTHREAD= + ;; + esac + ;; + + Darwin) + # MacOSX libpthread.dylib is a symlink to libSystem.dylib. + NXT_PTHREAD= + ;; + + *) + NXT_PTHREAD="-lpthread" + ;; +esac + + +# Linux, FreeBSD. + +nxt_feature="pthread_yield()" +nxt_feature_name=NXT_HAVE_PTHREAD_YIELD +nxt_feature_run= +nxt_feature_incs= +nxt_feature_libs=$NXT_PTHREAD +nxt_feature_test="#define _GNU_SOURCE + #include <pthread.h> + + int main() { + pthread_yield(); + return 0; + }" +. auto/feature + + +if [ $nxt_found = no ]; then + + # MacOSX. + + nxt_feature="pthread_yield_np()" + nxt_feature_name=NXT_HAVE_PTHREAD_YIELD_NP + nxt_feature_run= + nxt_feature_incs= + nxt_feature_libs=$NXT_PTHREAD + nxt_feature_test="#include <pthread.h> + + int main() { + pthread_yield_np(); + return 0; + }" + . auto/feature +fi + + +# FreeBSD, Solaris, AIX. + +nxt_feature="pthread spinlock" +nxt_feature_name=NXT_HAVE_PTHREAD_SPINLOCK +nxt_feature_run=yes +nxt_feature_incs= +nxt_feature_libs=$NXT_PTHREAD +nxt_feature_test="#include <pthread.h> + + int main() { + pthread_spinlock_t lock; + + if (pthread_spin_init(&lock, PTHREAD_PROCESS_PRIVATE) != 0) + return 1; + if (pthread_spin_lock(&lock) != 0) + return 1; + if (pthread_spin_unlock(&lock) != 0) + return 1; + if (pthread_spin_destroy(&lock) != 0) + return 1; + return 0; + }" +. auto/feature + + +if [ $nxt_found = yes ]; then + + # Linux glibc uses 0 as pthread_spinlock_t initial value on the most + # platforms. However, on i386 and x86_64 the initial value is 1. + + nxt_feature="pthread spinlock zero initial value" + nxt_feature_name=NXT_HAVE_PTHREAD_SPINLOCK_ZERO + nxt_feature_run=yes + nxt_feature_incs= + nxt_feature_libs=$NXT_PTHREAD + nxt_feature_test="#include <pthread.h> + + pthread_spinlock_t lock = 0; + + int main() { + if (pthread_spin_trylock(&lock) != 0) + return 1; + if (pthread_spin_unlock(&lock) != 0) + return 1; + return 0; + }" + . auto/feature +fi + + +if [ $nxt_found = no ]; then + + # MacOSX spinlock(3). + + nxt_feature="MacOSX spinlock" + nxt_feature_name=NXT_HAVE_MACOSX_SPINLOCK + nxt_feature_run=yes + nxt_feature_incs= + nxt_feature_libs=$NXT_PTHREAD + nxt_feature_test="#include <libkern/OSAtomic.h> + + int main() { + OSSpinLock lock = 0; + + if (OSSpinLockTry(&lock) == 0) + return 1; + OSSpinLockUnlock(&lock); + return 0; + }" + . auto/feature +fi + + +nxt_feature="sem_timedwait()" +nxt_feature_name=NXT_HAVE_SEM_TIMEDWAIT +nxt_feature_run=yes +nxt_feature_incs= +nxt_feature_libs= +nxt_feature_test="#include <semaphore.h> + + int main() { + sem_t sem; + struct timespec ts; + + if (sem_init(&sem, 0, 0) != 0) + return 1; + if (sem_post(&sem) != 0) + return 1; + + ts.tv_sec = 0; + ts.tv_nsec = 0; + if (sem_timedwait(&sem, &ts) != 0) + return 1; + + if (sem_destroy(&sem) != 0) + return 1; + return 0; + }" +. auto/feature + + +if [ $nxt_found = no ]; then + + if [ -n "$NXT_PTHREAD" ]; then + + # Linux requires libpthread. + + nxt_feature="sem_timedwait() in libpthread" + nxt_feature_libs=$NXT_PTHREAD + . auto/feature + fi + + if [ $nxt_found = no ]; then + + # Solaris 10 requires librt. + + nxt_feature="sem_timedwait() in librt" + nxt_feature_libs="-lrt" + . auto/feature + + if [ $nxt_found = yes ]; then + NXT_LIBRT="-lrt" + fi + fi +fi + + +# Thread Local Storage / Thread Specific Data. +# +# Linux, FreeBSD 5.3, Solaris. +# MacOSX 10.7 (Lion) Clang. However, if the -mmacosx-version-min +# option is specified it must be at least 10.7. + +nxt_feature="__thread" +nxt_feature_name=NXT_HAVE_THREAD_STORAGE_CLASS +nxt_feature_run=yes +nxt_feature_incs= +nxt_feature_libs=$NXT_PTHREAD +nxt_feature_test="#include <pthread.h> + #include <stdlib.h> + + __thread int key; + + void *func(void *p); + + void *func(void *p) { + key = 0x9abcdef0; + return NULL; + } + + int main() { + void *n; + pthread_t pt; + + key = 0x12345678; + if (pthread_create(&pt, NULL, func, NULL)) + return 1; + if (pthread_join(pt, &n)) + return 1; + if (key != 0x12345678) + return 1; + return 0; + }" +. auto/feature + + +if [ $nxt_found = no ]; then + + # MacOSX GCC lacks __thread support. + # On NetBSD __thread causes segmentation fault. + + nxt_feature="phtread_key_t" + nxt_feature_name=NXT_HAVE_PTHREAD_SPECIFIC_DATA + nxt_feature_run=yes + nxt_feature_incs= + nxt_feature_libs=$NXT_PTHREAD + nxt_feature_test="#include <pthread.h> + + int main() { + pthread_key_t key = -1; + + if (pthread_key_create(&key, NULL)) + return 1; + if (pthread_setspecific(key, (void *) 0x12345678)) + return 1; + if (pthread_getspecific(key) != (void *) 0x12345678) + return 1; + return 0; + }" + . auto/feature + + + nxt_feature="PTHREAD_KEYS_MAX" + nxt_feature_name= + nxt_feature_run=value + nxt_feature_incs= + nxt_feature_libs= + nxt_feature_test="#include <limits.h> + #include <pthread.h> + #include <stdio.h> + + int main() { + printf(\"%d\", PTHREAD_KEYS_MAX); + return 0; + }" + . auto/feature +fi |