From: Ivan Maidanski Date: Thu, 23 Mar 2017 08:09:40 +0000 (+0300) Subject: Use sigsetjmp() in setjmp_t tool if available X-Git-Tag: v8.0.0~824 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=403d2f839b6b0b4ed2327411002cc1d6ba3fceca;p=gc Use sigsetjmp() in setjmp_t tool if available * tools/setjmp_t.c (main): Replace jmp_buf, setjmp(), longjmp() to JMP_BUF, SETJMP(), LONGJMP(), respectively; cast result of SETJMP() to void type. --- diff --git a/tools/setjmp_t.c b/tools/setjmp_t.c index b3bb86da..2b4c4dc8 100644 --- a/tools/setjmp_t.c +++ b/tools/setjmp_t.c @@ -80,7 +80,7 @@ int main(void) { volatile word sp; unsigned ps = GETPAGESIZE(); - jmp_buf b; + JMP_BUF b; register int x = (int)strlen("a"); /* 1, slightly disguised */ static volatile int y = 0; @@ -109,7 +109,7 @@ int main(void) x = 2*x-1; printf("\n"); x = 2*x-1; - setjmp(b); + (void)SETJMP(b); if (y == 1) { if (x == 2) { printf("Setjmp-based generic mark_regs code probably won't work.\n"); @@ -123,7 +123,7 @@ int main(void) } y++; x = 2; - if (y == 1) longjmp(b,1); + if (y == 1) LONGJMP(b, 1); printf("Some GC internal configuration stuff: \n"); printf("\tWORDSZ = %lu, ALIGNMENT = %d, GC_GRANULE_BYTES = %d\n", (unsigned long)WORDSZ, ALIGNMENT, GC_GRANULE_BYTES);