mirror of
https://sourceware.org/git/glibc.git
synced 2024-11-24 18:23:41 +08:00
24a2718f59
We test vector math functions using scalar tests infrastructure with help of special wrappers from scalar versions to vector ones. Wrapper implemented using platform specific vector types and placed in separate file for compilation with architecture specific options, main part of test has no such options. With help of system of definitions unfolding of which is drived from test code we have wrapper called in individual testing function instead of scalar function. Also system of definitions includes generated during make check header math/libm-have-vector-test.h with series of conditional definitions which help to avoid build fails for functions having no vector versions; runtime architecture check to prevent runtime fails of test run on inappropriate hardware. * math/Makefile: Added rules for vector tests. * math/gen-libm-have-vector-test.sh: Added generation of wrapper declaration under condition. * math/test-double-vlen2.h: New file. * math/test-double-vlen4.h: New file. * math/test-double-vlen8.h: New file. * math/test-vec-loop.h: Added initialization macro. * sysdeps/x86_64/fpu/Makefile: Added variables for vector tests. * sysdeps/x86_64/fpu/libm-test-ulps: Regenarated. * sysdeps/x86_64/fpu/math-tests-arch.h: New file. * sysdeps/x86_64/fpu/test-double-vlen2-wrappers.c: New file. * sysdeps/x86_64/fpu/test-double-vlen2.c: New file. * sysdeps/x86_64/fpu/test-double-vlen4-avx2-wrappers.c: New file. * sysdeps/x86_64/fpu/test-double-vlen4-avx2.c: New file. * sysdeps/x86_64/fpu/test-double-vlen4-wrappers.c: New file. * sysdeps/x86_64/fpu/test-double-vlen4.c: New file. * sysdeps/x86_64/fpu/test-double-vlen8-wrappers.c: New file. * sysdeps/x86_64/fpu/test-double-vlen8.c: New file.
72 lines
2.4 KiB
C
72 lines
2.4 KiB
C
/* Definitions for double vector tests with vector length 4.
|
|
Copyright (C) 2014-2015 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/>. */
|
|
|
|
#define FLOAT double
|
|
#define FUNC(function) function
|
|
#define TEST_MSG "testing double vector math (without inline functions)\n"
|
|
#define MATHCONST(x) x
|
|
#define CHOOSE(Clongdouble,Cdouble,Cfloat,Cinlinelongdouble,Cinlinedouble,Cinlinefloat) Cdouble
|
|
#define PRINTF_EXPR "e"
|
|
#define PRINTF_XEXPR "a"
|
|
#define PRINTF_NEXPR "f"
|
|
#define TEST_DOUBLE 1
|
|
#define TEST_MATHVEC 1
|
|
|
|
#ifndef __NO_MATH_INLINES
|
|
# define __NO_MATH_INLINES
|
|
#endif
|
|
|
|
#define EXCEPTION_TESTS_double 0
|
|
#define ROUNDING_TESTS_double(MODE) ((MODE) == FE_TONEAREST)
|
|
|
|
#define CNCT(x, y) x ## y
|
|
#define CONCAT(a, b) CNCT (a, b)
|
|
|
|
#define VEC_SUFF _vlen4
|
|
#define WRAPPER_NAME(function) CONCAT (function, VEC_SUFF)
|
|
|
|
#define FUNC_TEST(function) function ## _VEC_SUFF
|
|
|
|
#define WRAPPER_DECL(function) extern FLOAT function (FLOAT);
|
|
#define WRAPPER_DECL_ff(function) extern FLOAT function (FLOAT, FLOAT);
|
|
|
|
// Wrapper from scalar to vector function with vector length 4.
|
|
#define VECTOR_WRAPPER(scalar_func, vector_func) \
|
|
extern VEC_TYPE vector_func (VEC_TYPE); \
|
|
FLOAT scalar_func (FLOAT x) \
|
|
{ \
|
|
int i; \
|
|
VEC_TYPE mx; \
|
|
INIT_VEC_LOOP (mx, x, 4); \
|
|
VEC_TYPE mr = vector_func (mx); \
|
|
TEST_VEC_LOOP (4); \
|
|
}
|
|
|
|
// Wrapper from scalar 2 argument function to vector one.
|
|
#define VECTOR_WRAPPER_ff(scalar_func, vector_func) \
|
|
extern VEC_TYPE vector_func (VEC_TYPE, VEC_TYPE); \
|
|
FLOAT scalar_func (FLOAT x, FLOAT y) \
|
|
{ \
|
|
int i; \
|
|
VEC_TYPE mx, my; \
|
|
INIT_VEC_LOOP (mx, x, 4); \
|
|
INIT_VEC_LOOP (my, y, 4); \
|
|
VEC_TYPE mr = vector_func (mx, my); \
|
|
TEST_VEC_LOOP (4); \
|
|
}
|