X-Git-Url: http://nsz.repo.hu/git/?p=musl;a=blobdiff_plain;f=include%2Fpthread.h;fp=include%2Fpthread.h;h=1b7f9fd37a8bf69646ece3bdc61cf1678236adf2;hp=44a710197210a5cc1abd4edf6e52c74b8be2a701;hb=afc35d5efde48b82a7786d9c89b115965da6b637;hpb=ed2911a11317729c1a13e779237fed736c676c1b diff --git a/include/pthread.h b/include/pthread.h index 44a71019..1b7f9fd3 100644 --- a/include/pthread.h +++ b/include/pthread.h @@ -186,24 +186,17 @@ int pthread_atfork(void (*)(void), void (*)(void), void (*)(void)); int pthread_getconcurrency(void); int pthread_setconcurrency(int); -#include +struct __ptcb { + void (*__f)(void *); + void *__x; + struct __ptcb *__next; +}; -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 - -#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); { - -#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 }