X-Git-Url: http://nsz.repo.hu/git/?p=musl;a=blobdiff_plain;f=include%2Fpthread.h;h=d4ffb9ab0916715d103d8b2478b2cb7f88097ee7;hp=d40002e6ad430cdec9b7efd3200db35b4e7008d1;hb=2242bf616b893e85886ed0a2348b96bf1cf7623e;hpb=d8d19f4d46284d5b6124710a5235b6fe090c013f diff --git a/include/pthread.h b/include/pthread.h index d40002e6..d4ffb9ab 100644 --- a/include/pthread.h +++ b/include/pthread.h @@ -53,9 +53,9 @@ extern "C" { #define PTHREAD_PROCESS_SHARED 1 -#define PTHREAD_MUTEX_INITIALIZER {0} -#define PTHREAD_RWLOCK_INITIALIZER {0} -#define PTHREAD_COND_INITIALIZER {0} +#define PTHREAD_MUTEX_INITIALIZER {{{0}}} +#define PTHREAD_RWLOCK_INITIALIZER {{{0}}} +#define PTHREAD_COND_INITIALIZER {{{0}}} #define PTHREAD_ONCE_INIT 0 @@ -65,7 +65,7 @@ extern "C" { #define PTHREAD_CANCEL_DEFERRED 0 #define PTHREAD_CANCEL_ASYNCHRONOUS 1 -#define PTHREAD_CANCELLED ((void *)-1) +#define PTHREAD_CANCELED ((void *)-1) #define PTHREAD_BARRIER_SERIAL_THREAD (-1) @@ -76,8 +76,13 @@ int pthread_detach(pthread_t); void pthread_exit(void *); int pthread_join(pthread_t, void **); +#ifdef __GNUC__ +__attribute__((const)) +#endif pthread_t pthread_self(void); + int pthread_equal(pthread_t, pthread_t); +#define pthread_equal(x,y) ((x)==(y)) int pthread_setcancelstate(int, int *); int pthread_setcanceltype(int, int *); @@ -92,6 +97,7 @@ int pthread_mutex_unlock(pthread_mutex_t *); int pthread_mutex_trylock(pthread_mutex_t *); int pthread_mutex_timedlock(pthread_mutex_t *, const struct timespec *); int pthread_mutex_destroy(pthread_mutex_t *); +int pthread_mutex_consistent(pthread_mutex_t *); int pthread_cond_init(pthread_cond_t *, const pthread_condattr_t *); int pthread_cond_destroy(pthread_cond_t *); @@ -177,22 +183,20 @@ int pthread_barrierattr_setpshared(pthread_barrierattr_t *, int); int pthread_atfork(void (*)(void), void (*)(void), void (*)(void)); -#include - -int __setjmp(void *); -void __pthread_register_cancel(struct __ptcb *); -void __pthread_unregister_cancel(struct __ptcb *); -void __pthread_unwind_next(struct __ptcb *); +int pthread_getconcurrency(void); +int pthread_setconcurrency(int); -#define pthread_cleanup_push(f, x) \ -do { struct __ptcb __cb; void (*__f)(void *) = (f); void *__x = (x); \ -if (__setjmp(__cb.__jb)) __f(__x), __pthread_unwind_next(&__cb); \ -__pthread_register_cancel(&__cb); { +struct __ptcb { + void (*__f)(void *); + void *__x; + struct __ptcb *__next; +}; -#define pthread_cleanup_pop(r) ; } \ -__pthread_unregister_cancel(&__cb); \ -if (r) __f(__x); } while (0) +void _pthread_cleanup_push(struct __ptcb *, void (*)(void *), void *); +void _pthread_cleanup_pop(struct __ptcb *, int); +#define pthread_cleanup_push(f, x) do { struct __ptcb __cb; _pthread_cleanup_push(&__cb, f, x); +#define pthread_cleanup_pop(r) _pthread_cleanup_pop(&__cb, (r)); } while(0) #ifdef __cplusplus }