mirror of
				https://sourceware.org/git/glibc.git
				synced 2025-10-31 22:10:34 +03:00 
			
		
		
		
	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"
 |