mirror of
				https://sourceware.org/git/glibc.git
				synced 2025-10-30 10:45:40 +03:00 
			
		
		
		
	This patch makes math-tests.h, as used to describe support of given floating-point types for sNaNs, rounding modes and exceptions, handle distinguishing _Float128 from long double. This is needed for x86_64, where if building with GCC 6 or earlier there is no __builtin_nansq, so no way to get a signaling NaN of _Float128 type, so associated tests cannot be run (although glibc itself works fine, as there is never any need to create such an sNaN with a built-in function inside glibc). Tested for x86_64 (in conjunction with float128 patches). * sysdeps/generic/math-tests.h: Include <bits/floatn.h>. (MATH_TESTS_TG): New macro. (SNAN_TESTS_float128): Likewise. (ROUNDING_TESTS_float128): Likewise. (EXCEPTION_TESTS_float128): Likewise. (SNAN_TESTS): Define using MATH_TESTS_TG. (ROUNDING_TESTS): Likewise. (EXCEPTION_TESTS): Likewise.
		
			
				
	
	
		
			125 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			125 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* Configuration for math tests.  Generic version.
 | |
|    Copyright (C) 2013-2017 Free Software Foundation, Inc.
 | |
|    This file is part of the GNU C Library.
 | |
| 
 | |
|    The GNU C Library is free software; you can redistribute it and/or
 | |
|    modify it under the terms of the GNU Lesser General Public
 | |
|    License as published by the Free Software Foundation; either
 | |
|    version 2.1 of the License, or (at your option) any later version.
 | |
| 
 | |
|    The GNU C Library is distributed in the hope that it will be useful,
 | |
|    but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 | |
|    Lesser General Public License for more details.
 | |
| 
 | |
|    You should have received a copy of the GNU Lesser General Public
 | |
|    License along with the GNU C Library; if not, see
 | |
|    <http://www.gnu.org/licenses/>.  */
 | |
| 
 | |
| #include <bits/floatn.h>
 | |
| 
 | |
| /* Expand the appropriate macro for whether to enable tests for a
 | |
|    given type.  */
 | |
| #if __HAVE_DISTINCT_FLOAT128
 | |
| # define MATH_TESTS_TG(PREFIX, ARGS, TYPE)				\
 | |
|   (sizeof (TYPE) == sizeof (float) ? PREFIX ## float ARGS		\
 | |
|    : sizeof (TYPE) == sizeof (double) ? PREFIX ## double ARGS		\
 | |
|    : __builtin_types_compatible_p (TYPE, _Float128) ? PREFIX ## float128 ARGS \
 | |
|    : PREFIX ## long_double ARGS)
 | |
| # else
 | |
| # define MATH_TESTS_TG(PREFIX, ARGS, TYPE)				\
 | |
|   (sizeof (TYPE) == sizeof (float) ? PREFIX ## float ARGS		\
 | |
|    : sizeof (TYPE) == sizeof (double) ? PREFIX ## double ARGS		\
 | |
|    : PREFIX ## long_double ARGS)
 | |
| #endif
 | |
| 
 | |
| /* Indicate whether to run tests involving sNaN values for the float, double,
 | |
|    and long double C data types, respectively.  All are run unless
 | |
|    overridden.  */
 | |
| #ifndef SNAN_TESTS_float
 | |
| # define SNAN_TESTS_float	1
 | |
| #endif
 | |
| #ifndef SNAN_TESTS_double
 | |
| # define SNAN_TESTS_double	1
 | |
| #endif
 | |
| #ifndef SNAN_TESTS_long_double
 | |
| # define SNAN_TESTS_long_double	1
 | |
| #endif
 | |
| #ifndef SNAN_TESTS_float128
 | |
| # define SNAN_TESTS_float128	1
 | |
| #endif
 | |
| 
 | |
| /* Return nonzero value if to run tests involving sNaN values for X.  */
 | |
| #define SNAN_TESTS(x) MATH_TESTS_TG (SNAN_TESTS_, , x)
 | |
| 
 | |
| /* Indicate whether to run tests involving type casts of sNaN values.  These
 | |
|    are run unless overridden.  */
 | |
| #ifndef SNAN_TESTS_TYPE_CAST
 | |
| # define SNAN_TESTS_TYPE_CAST	1
 | |
| #endif
 | |
| 
 | |
| /* Indicate whether operations on signaling NaNs preserve the payload
 | |
|    (if possible; it is not possible with a zero payload if the high
 | |
|    bit is set for signaling NaNs) when generating a quiet NaN, and
 | |
|    this should be tested.  */
 | |
| #ifndef SNAN_TESTS_PRESERVE_PAYLOAD
 | |
| # define SNAN_TESTS_PRESERVE_PAYLOAD	1
 | |
| #endif
 | |
| 
 | |
| /* Indicate whether to run tests involving a given rounding mode for a
 | |
|    given floating-point type, given that fesetround succeeds for that
 | |
|    mode.  All are run if fesetround succeeds unless overridden.  */
 | |
| #ifndef ROUNDING_TESTS_float
 | |
| # define ROUNDING_TESTS_float(MODE)	1
 | |
| #endif
 | |
| #ifndef ROUNDING_TESTS_double
 | |
| # define ROUNDING_TESTS_double(MODE)	1
 | |
| #endif
 | |
| #ifndef ROUNDING_TESTS_long_double
 | |
| # define ROUNDING_TESTS_long_double(MODE)	1
 | |
| #endif
 | |
| #ifndef ROUNDING_TESTS_float128
 | |
| # define ROUNDING_TESTS_float128(MODE)	1
 | |
| #endif
 | |
| 
 | |
| #define ROUNDING_TESTS(TYPE, MODE)		\
 | |
|   MATH_TESTS_TG (ROUNDING_TESTS_, (MODE), TYPE)
 | |
| 
 | |
| /* Indicate whether to run tests of floating-point exceptions for a
 | |
|    given floating-point type, given that the exception macros are
 | |
|    defined.  All are run unless overridden.  */
 | |
| #ifndef EXCEPTION_TESTS_float
 | |
| # define EXCEPTION_TESTS_float	1
 | |
| #endif
 | |
| #ifndef EXCEPTION_TESTS_double
 | |
| # define EXCEPTION_TESTS_double	1
 | |
| #endif
 | |
| #ifndef EXCEPTION_TESTS_long_double
 | |
| # define EXCEPTION_TESTS_long_double	1
 | |
| #endif
 | |
| #ifndef EXCEPTION_TESTS_float128
 | |
| # define EXCEPTION_TESTS_float128	1
 | |
| #endif
 | |
| 
 | |
| #define EXCEPTION_TESTS(TYPE) MATH_TESTS_TG (EXCEPTION_TESTS_, , TYPE)
 | |
| 
 | |
| /* Indicate whether the given exception trap(s) can be enabled
 | |
|    in feenableexcept.  If non-zero, the traps are always supported.
 | |
|    If zero, traps may or may not be supported depending on the
 | |
|    target (this can be determined by checking the return value
 | |
|    of feenableexcept).  This enables skipping of tests which use
 | |
|    traps.  By default traps are supported unless overridden.  */
 | |
| #ifndef EXCEPTION_ENABLE_SUPPORTED
 | |
| # define EXCEPTION_ENABLE_SUPPORTED(EXCEPT)			\
 | |
|    (EXCEPTION_TESTS_float || EXCEPTION_TESTS_double)
 | |
| #endif
 | |
| 
 | |
| /* Indicate whether exception traps, if enabled, occur whenever an
 | |
|    exception flag is set explicitly, so it is not possible to set flag
 | |
|    bits with traps enabled without causing traps to be taken.  If
 | |
|    traps cannot be enabled, the value of this macro does not
 | |
|    matter.  */
 | |
| #ifndef EXCEPTION_SET_FORCES_TRAP
 | |
| # define EXCEPTION_SET_FORCES_TRAP 0
 | |
| #endif
 |