mirror of
git://sourceware.org/git/glibc.git
synced 2024-12-09 04:11:27 +08:00
e15f7de60c
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).
77 lines
1.7 KiB
C
77 lines
1.7 KiB
C
/* BZ 12420 */
|
|
|
|
#include <errno.h>
|
|
#include <fenv.h>
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <ucontext.h>
|
|
#include <libc-diag.h>
|
|
|
|
static int
|
|
do_test (void)
|
|
{
|
|
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
|
|
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);
|
|
|
|
/* On nios2 and tilepro, GCC 5 warns that except_mask may be used
|
|
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");
|
|
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);
|
|
DIAG_POP_NEEDS_COMMENT;
|
|
|
|
return 0;
|
|
}
|
|
|
|
#define TEST_FUNCTION do_test ()
|
|
#include "../test-skeleton.c"
|