change jmp_buf to share an underlying type and struct tag with sigjmp_buf

this is necessary to meet the C++ ABI target. alternatives were
considered to avoid the size increase for non-sig jmp_buf objects, but
they seemed to have worse properties. moreover, the relative size
increase is only extreme on x86[_64]; one way of interpreting this is
that, if the size increase from this patch makes jmp_buf use too much
memory, then the program was already using too much memory when built
for non-x86 archs.
This commit is contained in:
Rich Felker 2013-07-24 02:17:02 -04:00
parent 4a30ba5ca4
commit 9693501c15
9 changed files with 14 additions and 15 deletions

View File

@ -1 +1 @@
typedef unsigned long long jmp_buf[32]; typedef unsigned long long __jmp_buf[32];

View File

@ -1 +1 @@
typedef unsigned long jmp_buf[6]; typedef unsigned long __jmp_buf[6];

View File

@ -1 +1 @@
typedef unsigned long jmp_buf[18]; typedef unsigned long __jmp_buf[18];

View File

@ -1 +1 @@
typedef unsigned long long jmp_buf [15]; typedef unsigned long long __jmp_buf[15];

View File

@ -1 +1 @@
typedef unsigned long long jmp_buf [56]; typedef unsigned long long __jmp_buf[56];

View File

@ -1 +1 @@
typedef unsigned long jmp_buf[8]; typedef unsigned long __jmp_buf[8];

View File

@ -9,27 +9,26 @@ extern "C" {
#include <bits/setjmp.h> #include <bits/setjmp.h>
typedef struct __jmp_buf_tag {
__jmp_buf __jb;
unsigned long __fl;
unsigned long __ss[128/sizeof(long)];
} jmp_buf[1];
#if defined(_POSIX_SOURCE) || defined(_POSIX_C_SOURCE) \ #if defined(_POSIX_SOURCE) || defined(_POSIX_C_SOURCE) \
|| defined(_XOPEN_SOURCE) || defined(_GNU_SOURCE) \ || defined(_XOPEN_SOURCE) || defined(_GNU_SOURCE) \
|| defined(_BSD_SOURCE) || defined(_BSD_SOURCE)
typedef struct __sigjmp_buf { typedef jmp_buf sigjmp_buf;
jmp_buf __jb;
unsigned long __fl;
unsigned long __ss[128/sizeof(long)];
} sigjmp_buf[1];
int sigsetjmp (sigjmp_buf, int); int sigsetjmp (sigjmp_buf, int);
_Noreturn void siglongjmp (sigjmp_buf, int); _Noreturn void siglongjmp (sigjmp_buf, int);
#endif #endif
#if defined(_XOPEN_SOURCE) || defined(_GNU_SOURCE) \ #if defined(_XOPEN_SOURCE) || defined(_GNU_SOURCE) \
|| defined(_BSD_SOURCE) || defined(_BSD_SOURCE)
int _setjmp (jmp_buf); int _setjmp (jmp_buf);
_Noreturn void _longjmp (jmp_buf, int); _Noreturn void _longjmp (jmp_buf, int);
#endif #endif
int setjmp (jmp_buf); int setjmp (jmp_buf);
_Noreturn void longjmp (jmp_buf, int); _Noreturn void longjmp (jmp_buf, int);

View File

@ -7,5 +7,5 @@
_Noreturn void siglongjmp(sigjmp_buf buf, int ret) _Noreturn void siglongjmp(sigjmp_buf buf, int ret)
{ {
if (buf->__fl) __restore_sigs(buf->__ss); if (buf->__fl) __restore_sigs(buf->__ss);
longjmp(buf->__jb, ret); longjmp(buf, ret);
} }

View File

@ -11,5 +11,5 @@ int sigsetjmp(sigjmp_buf buf, int save)
{ {
if ((buf->__fl = save)) if ((buf->__fl = save))
pthread_sigmask(SIG_SETMASK, 0, (sigset_t *)buf->__ss); pthread_sigmask(SIG_SETMASK, 0, (sigset_t *)buf->__ss);
return setjmp(buf->__jb); return setjmp(buf);
} }