123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159 |
- /* Copyright (C) 2006 Manuel Novoa III <mjn3@codepoet.org>
- *
- * GNU Library General Public License (LGPL) version 2 or later.
- *
- * Dedicated to Toni. See uClibc/DEDICATION.mjn3 for details.
- */
- #ifndef _UCLIBC_MUTEX_H
- #define _UCLIBC_MUTEX_H
- #include <features.h>
- #ifdef __UCLIBC_HAS_THREADS__
- #include <pthread.h>
- #ifdef _LIBC
- #include <bits/uClibc_pthread.h>
- #endif
- #define __UCLIBC_MUTEX_TYPE pthread_mutex_t
- #define __UCLIBC_MUTEX(M) pthread_mutex_t M
- #define __UCLIBC_MUTEX_INIT(M,I) pthread_mutex_t M = I
- #define __UCLIBC_MUTEX_STATIC(M,I) static pthread_mutex_t M = I
- #define __UCLIBC_MUTEX_EXTERN(M) extern pthread_mutex_t M
- #define __UCLIBC_MUTEX_INIT_VAR(M) \
- ((M) = (pthread_mutex_t) PTHREAD_RECURSIVE_MUTEX_INITIALIZER_NP)
- #define __UCLIBC_MUTEX_LOCK_CANCEL_UNSAFE(M) \
- __pthread_mutex_lock(&(M))
- #define __UCLIBC_MUTEX_UNLOCK_CANCEL_UNSAFE(M) \
- __pthread_mutex_unlock(&(M))
- #define __UCLIBC_MUTEX_TRYLOCK_CANCEL_UNSAFE(M) \
- __pthread_mutex_trylock(&(M))
- #define __UCLIBC_MUTEX_CONDITIONAL_LOCK(M,C) \
- do { \
- struct _pthread_cleanup_buffer __infunc_pthread_cleanup_buffer; \
- int __infunc_need_locking = (C); \
- if (__infunc_need_locking) { \
- _pthread_cleanup_push_defer(&__infunc_pthread_cleanup_buffer, \
- (void (*) (void *))__pthread_mutex_unlock, \
- &(M)); \
- __pthread_mutex_lock(&(M)); \
- } \
- ((void)0)
- #define __UCLIBC_MUTEX_CONDITIONAL_UNLOCK(M,C) \
- if (__infunc_need_locking) { \
- _pthread_cleanup_pop_restore(&__infunc_pthread_cleanup_buffer,1); \
- } \
- } while (0)
- #define __UCLIBC_MUTEX_AUTO_LOCK_VAR(A) int A
- #define __UCLIBC_MUTEX_AUTO_LOCK(M,A,V) \
- __UCLIBC_MUTEX_CONDITIONAL_LOCK(M,((A=(V)) == 0))
- #define __UCLIBC_MUTEX_AUTO_UNLOCK(M,A) \
- __UCLIBC_MUTEX_CONDITIONAL_UNLOCK(M,(A == 0))
- #define __UCLIBC_MUTEX_LOCK(M) \
- __UCLIBC_MUTEX_CONDITIONAL_LOCK(M, 1)
- #define __UCLIBC_MUTEX_UNLOCK(M) \
- __UCLIBC_MUTEX_CONDITIONAL_UNLOCK(M, 1)
- #ifdef __USE_STDIO_FUTEXES__
- #include <bits/stdio-lock.h>
- #define __UCLIBC_IO_MUTEX(M) _IO_lock_t M
- #define __UCLIBC_IO_MUTEX_LOCK(M) _IO_lock_lock(M)
- #define __UCLIBC_IO_MUTEX_UNLOCK(M) _IO_lock_unlock(M)
- #define __UCLIBC_IO_MUTEX_TRYLOCK(M) _IO_lock_trylock(M)
- #define __UCLIBC_IO_MUTEX_INIT(M) _IO_lock_t M = _IO_lock_initializer
- #define __UCLIBC_IO_MUTEX_EXTERN(M) extern _IO_lock_t M
- #define __UCLIBC_IO_MUTEX_CONDITIONAL_LOCK(M,C) \
- if (C) { \
- _IO_lock_lock(M); \
- }
- #define __UCLIBC_IO_MUTEX_CONDITIONAL_UNLOCK(M,C) \
- if (C) { \
- _IO_lock_unlock(M); \
- }
- #define __UCLIBC_IO_MUTEX_AUTO_LOCK(M,A,V) \
- __UCLIBC_IO_MUTEX_CONDITIONAL_LOCK(M,((A=(V))) == 0)
- #define __UCLIBC_IO_MUTEX_AUTO_UNLOCK(M,A) \
- __UCLIBC_IO_MUTEX_CONDITIONAL_UNLOCK(M,((A) == 0))
- #define __UCLIBC_IO_MUTEX_LOCK_CANCEL_UNSAFE(M) _IO_lock_lock(M)
- #define __UCLIBC_IO_MUTEX_UNLOCK_CANCEL_UNSAFE(M) _IO_lock_unlock(M)
- #else /* of __USE_STDIO_FUTEXES__ */
- #define __UCLIBC_IO_MUTEX(M) __UCLIBC_MUTEX(M)
- #define __UCLIBC_IO_MUTEX_LOCK(M) __UCLIBC_MUTEX_CONDITIONAL_LOCK(M, 1)
- #define __UCLIBC_IO_MUTEX_UNLOCK(M) __UCLIBC_MUTEX_CONDITIONAL_UNLOCK(M, 1)
- #define __UCLIBC_IO_MUTEX_TRYLOCK(M) __UCLIBC_MUTEX_TRYLOCK_CANCEL_UNSAFE(M)
- #define __UCLIBC_IO_MUTEX_INIT(M) __UCLIBC_MUTEX_INIT(M, PTHREAD_RECURSIVE_MUTEX_INITIALIZER_NP)
- #define __UCLIBC_IO_MUTEX_EXTERN(M) __UCLIBC_MUTEX_EXTERN(M)
- #define __UCLIBC_IO_MUTEX_AUTO_LOCK(M,A,V) __UCLIBC_MUTEX_AUTO_LOCK(M,A,V)
- #define __UCLIBC_IO_MUTEX_AUTO_UNLOCK(M,A) __UCLIBC_MUTEX_AUTO_UNLOCK(M,A)
- #define __UCLIBC_IO_MUTEX_LOCK_CANCEL_UNSAFE(M) __UCLIBC_MUTEX_LOCK_CANCEL_UNSAFE(M)
- #define __UCLIBC_IO_MUTEX_UNLOCK_CANCEL_UNSAFE(M) __UCLIBC_MUTEX_UNLOCK_CANCEL_UNSAFE(M)
- #define __UCLIBC_IO_MUTEX_CONDITIONAL_LOCK(M,C) __UCLIBC_MUTEX_CONDITIONAL_LOCK(M,C)
- #define __UCLIBC_IO_MUTEX_CONDITIONAL_UNLOCK(M,C) __UCLIBC_MUTEX_CONDITIONAL_UNLOCK(M,C)
- #endif /* of __USE_STDIO_FUTEXES__ */
- #else /* of __UCLIBC_HAS_THREADS__ */
- #define __UCLIBC_MUTEX(M) void *__UCLIBC_MUTEX_DUMMY_ ## M
- #define __UCLIBC_MUTEX_INIT(M,I) extern void *__UCLIBC_MUTEX_DUMMY_ ## M
- #define __UCLIBC_MUTEX_STATIC(M,I) extern void *__UCLIBC_MUTEX_DUMMY_ ## M
- #define __UCLIBC_MUTEX_EXTERN(M) extern void *__UCLIBC_MUTEX_DUMMY_ ## M
- #define __UCLIBC_MUTEX_INIT_VAR(M) ((void)0)
- #define __UCLIBC_MUTEX_LOCK_CANCEL_UNSAFE(M) ((void)0)
- #define __UCLIBC_MUTEX_UNLOCK_CANCEL_UNSAFE(M) ((void)0)
- #define __UCLIBC_MUTEX_TRYLOCK_CANCEL_UNSAFE(M) (0) /* Always succeed? */
- #define __UCLIBC_MUTEX_CONDITIONAL_LOCK(M,C) ((void)0)
- #define __UCLIBC_MUTEX_CONDITIONAL_UNLOCK(M,C) ((void)0)
- #define __UCLIBC_MUTEX_AUTO_LOCK_VAR(A) ((void)0)
- #define __UCLIBC_MUTEX_AUTO_LOCK(M,A,V) ((void)0)
- #define __UCLIBC_MUTEX_AUTO_UNLOCK(M,A) ((void)0)
- #define __UCLIBC_MUTEX_LOCK(M) ((void)0)
- #define __UCLIBC_MUTEX_UNLOCK(M) ((void)0)
- #define __UCLIBC_IO_MUTEX(M) __UCLIBC_MUTEX(M)
- #define __UCLIBC_IO_MUTEX_LOCK(M) __UCLIBC_MUTEX_CONDITIONAL_LOCK(M, 1)
- #define __UCLIBC_IO_MUTEX_UNLOCK(M) __UCLIBC_MUTEX_CONDITIONAL_UNLOCK(M, 1)
- #define __UCLIBC_IO_MUTEX_TRYLOCK(M) __UCLIBC_MUTEX_TRYLOCK_CANCEL_UNSAFE(M)
- #define __UCLIBC_IO_MUTEX_INIT(M) __UCLIBC_MUTEX_INIT(M, PTHREAD_RECURSIVE_MUTEX_INITIALIZER_NP)
- #define __UCLIBC_IO_MUTEX_EXTERN(M) __UCLIBC_MUTEX_EXTERN(M)
- #define __UCLIBC_IO_MUTEX_AUTO_LOCK(M,A,V) __UCLIBC_MUTEX_AUTO_LOCK(M,A,V)
- #define __UCLIBC_IO_MUTEX_AUTO_UNLOCK(M,A) __UCLIBC_MUTEX_AUTO_UNLOCK(M,A)
- #define __UCLIBC_IO_MUTEX_LOCK_CANCEL_UNSAFE(M) __UCLIBC_MUTEX_LOCK_CANCEL_UNSAFE(M)
- #define __UCLIBC_IO_MUTEX_UNLOCK_CANCEL_UNSAFE(M) __UCLIBC_MUTEX_UNLOCK_CANCEL_UNSAFE(M)
- #define __UCLIBC_IO_MUTEX_CONDITIONAL_LOCK(M,C) __UCLIBC_MUTEX_CONDITIONAL_LOCK(M,C)
- #define __UCLIBC_IO_MUTEX_CONDITIONAL_UNLOCK(M,C) __UCLIBC_MUTEX_CONDITIONAL_UNLOCK(M,C)
- #endif /* of __UCLIBC_HAS_THREADS__ */
- #define __UCLIBC_IO_MUTEX_TRYLOCK_CANCEL_UNSAFE(M) \
- __UCLIBC_IO_MUTEX_TRYLOCK(M)
- #endif /* _UCLIBC_MUTEX_H */
|