2011-04-18 09:51:26 +08:00
|
|
|
/* BZ 12420 */
|
|
|
|
|
|
|
|
#include <errno.h>
|
|
|
|
#include <fenv.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <ucontext.h>
|
Split DIAG_* macros to new header libc-diag.h.
Quite a few tests include libc-internal.h just for the DIAG_* macros.
Split those macros to their own file, which can be included safely in
_ISOMAC mode. I also moved ignore_value, since it seems logically
related, even though I didn't notice any tests needing it.
Also add -Wnonnull suppressions to two tests that _should_ have them,
but the error is masked when compiling against internal headers.
* include/libc-diag.h: New file. Define ignore_value,
DIAG_PUSH_NEEDS_COMMENT, DIAG_POP_NEEDS_COMMENT,
DIAG_IGNORE_NEEDS_COMMENT, and DIAG_IGNORE_Os_NEEDS_COMMENT here.
* include/libc-internal.h: Definitions of above macros moved from
here. Include libc-diag.h. Add copyright notice.
* malloc/tst-malloc.c, malloc/tst-memcheck.c, malloc/tst-realloc.c
* misc/tst-error1.c, posix/tst-dir.c, stdio-common/bug21.c
* stdio-common/scanf14.c, stdio-common/scanf4.c, stdio-common/scanf7.c
* stdio-common/test-vfprintf.c, stdio-common/tst-printf.c
* stdio-common/tst-printfsz.c, stdio-common/tst-sprintf.c
* stdio-common/tst-unlockedio.c, stdio-common/tstdiomisc.c
* stdlib/bug-getcontext.c, string/tester.c, string/tst-endian.c
* time/tst-strptime2.c, wcsmbs/tst-wcstof.c:
Include libc-diag.h instead of libc-internal.h.
* stdlib/tst-environ.c: Include libc-diag.h. Suppress -Wnonnull for
call to unsetenv (NULL).
* nptl/tst-mutex1.c: Include libc-diag.h. Suppress -Wnonnull for
call to pthread_mutexattr_destroy (NULL).
2016-11-21 09:46:30 +08:00
|
|
|
#include <libc-diag.h>
|
2011-04-18 09:51:26 +08:00
|
|
|
|
|
|
|
static int
|
|
|
|
do_test (void)
|
|
|
|
{
|
2012-07-16 22:51:13 +08:00
|
|
|
if (FE_ALL_EXCEPT == 0)
|
|
|
|
{
|
|
|
|
printf("Skipping test; no support for FP exceptions.\n");
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int except_mask = 0;
|
|
|
|
#ifdef FE_DIVBYZERO
|
|
|
|
except_mask |= FE_DIVBYZERO;
|
|
|
|
#endif
|
|
|
|
#ifdef FE_INVALID
|
|
|
|
except_mask |= FE_INVALID;
|
|
|
|
#endif
|
|
|
|
#ifdef FE_OVERFLOW
|
|
|
|
except_mask |= FE_OVERFLOW;
|
|
|
|
#endif
|
|
|
|
#ifdef FE_UNDERFLOW
|
|
|
|
except_mask |= FE_UNDERFLOW;
|
|
|
|
#endif
|
2011-04-18 09:51:26 +08:00
|
|
|
int status = feenableexcept (except_mask);
|
|
|
|
|
|
|
|
except_mask = fegetexcept ();
|
|
|
|
if (except_mask == -1)
|
|
|
|
{
|
|
|
|
printf("\nBefore getcontext(): fegetexcept returned: %d\n",
|
|
|
|
except_mask);
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
ucontext_t ctx;
|
|
|
|
status = getcontext(&ctx);
|
|
|
|
if (status)
|
|
|
|
{
|
|
|
|
printf("\ngetcontext failed, errno: %d.\n", errno);
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
printf ("\nDone with getcontext()!\n");
|
|
|
|
fflush (NULL);
|
|
|
|
|
2017-12-13 21:43:39 +08:00
|
|
|
/* On nios2 GCC 5 warns that except_mask may be used
|
2016-11-12 05:05:51 +08:00
|
|
|
uninitialized. Because it is always initialized and nothing in
|
|
|
|
this test ever calls setcontext (a setcontext call could result
|
|
|
|
in local variables being clobbered on the second return from
|
|
|
|
getcontext), in fact an uninitialized use is not possible. */
|
|
|
|
DIAG_PUSH_NEEDS_COMMENT;
|
|
|
|
DIAG_IGNORE_NEEDS_COMMENT (5, "-Wmaybe-uninitialized");
|
2011-04-18 09:51:26 +08:00
|
|
|
int mask = fegetexcept ();
|
|
|
|
if (mask != except_mask)
|
|
|
|
{
|
|
|
|
printf("\nAfter getcontext(): fegetexcept returned: %d, expected: %d.\n",
|
|
|
|
mask, except_mask);
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
printf("\nAt end fegetexcept() returned %d, expected: %d.\n",
|
|
|
|
mask, except_mask);
|
2016-11-12 05:05:51 +08:00
|
|
|
DIAG_POP_NEEDS_COMMENT;
|
2012-07-16 22:51:13 +08:00
|
|
|
|
2011-04-18 09:51:26 +08:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
#define TEST_FUNCTION do_test ()
|
|
|
|
#include "../test-skeleton.c"
|