X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=include%2Fsetjmp.h;h=1976af231b8c4acee1a4115c20afb48d12a85d6a;hb=35fdfe62a4ff471074ca53b7626ec80e83d244bd;hp=28ff92e402b60daa14bcde580e868219ff413caf;hpb=d6c0efe106b1016108207fb6872820c06dcef4f8;p=musl diff --git a/include/setjmp.h b/include/setjmp.h index 28ff92e4..1976af23 100644 --- a/include/setjmp.h +++ b/include/setjmp.h @@ -5,34 +5,42 @@ extern "C" { #endif +#include + #include +typedef struct __jmp_buf_tag { + __jmp_buf __jb; + unsigned long __fl; + unsigned long __ss[128/sizeof(long)]; +} jmp_buf[1]; + +#if __GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 1) +#define __setjmp_attr __attribute__((__returns_twice__)) +#else +#define __setjmp_attr +#endif #if defined(_POSIX_SOURCE) || defined(_POSIX_C_SOURCE) \ || defined(_XOPEN_SOURCE) || defined(_GNU_SOURCE) \ || defined(_BSD_SOURCE) -typedef struct { - jmp_buf __jb; - unsigned long __fl; - unsigned long __ss[128]; -} sigjmp_buf[1]; -int sigsetjmp (sigjmp_buf, int); -void siglongjmp (sigjmp_buf, int); +typedef jmp_buf sigjmp_buf; +int sigsetjmp (sigjmp_buf, int) __setjmp_attr; +_Noreturn void siglongjmp (sigjmp_buf, int); #endif - #if defined(_XOPEN_SOURCE) || defined(_GNU_SOURCE) \ || defined(_BSD_SOURCE) -int _setjmp (jmp_buf); -void _longjmp (jmp_buf, int); +int _setjmp (jmp_buf) __setjmp_attr; +_Noreturn void _longjmp (jmp_buf, int); #endif - -int setjmp (jmp_buf); -void longjmp (jmp_buf, int); +int setjmp (jmp_buf) __setjmp_attr; +_Noreturn void longjmp (jmp_buf, int); #define setjmp setjmp -#define longjmp longjmp + +#undef __setjmp_attr #ifdef __cplusplus }