projects
/
musl
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
add deprecated capabilities functions
[musl]
/
include
/
pthread.h
diff --git
a/include/pthread.h
b/include/pthread.h
index
43754dd
..
d4ffb9a
100644
(file)
--- a/
include/pthread.h
+++ b/
include/pthread.h
@@
-53,9
+53,9
@@
extern "C" {
#define PTHREAD_PROCESS_SHARED 1
#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
#define PTHREAD_ONCE_INIT 0
@@
-76,8
+76,13
@@
int pthread_detach(pthread_t);
void pthread_exit(void *);
int pthread_join(pthread_t, void **);
void pthread_exit(void *);
int pthread_join(pthread_t, void **);
+#ifdef __GNUC__
+__attribute__((const))
+#endif
pthread_t pthread_self(void);
pthread_t pthread_self(void);
+
int pthread_equal(pthread_t, pthread_t);
int pthread_equal(pthread_t, pthread_t);
+#define pthread_equal(x,y) ((x)==(y))
int pthread_setcancelstate(int, int *);
int pthread_setcanceltype(int, int *);
int pthread_setcancelstate(int, int *);
int pthread_setcanceltype(int, int *);
@@
-178,24
+183,20
@@
int pthread_barrierattr_setpshared(pthread_barrierattr_t *, int);
int pthread_atfork(void (*)(void), void (*)(void), void (*)(void));
int pthread_atfork(void (*)(void), void (*)(void), void (*)(void));
-#include <bits/pthread.h>
-
-int __setjmp(void *);
-#ifndef __pthread_register_cancel
-void __pthread_register_cancel(struct __ptcb *);
-void __pthread_unregister_cancel(struct __ptcb *);
-void __pthread_unwind_next(struct __ptcb *);
-#endif
+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
}
#ifdef __cplusplus
}