Add vector ABI tests for cos, exp, log, pow and sin functions.
Reviewed-by: H.J. Lu <hjl.tools@gmail.com>
sin \
sincos \
-# FIXME: Add ABI tests for all libmvec functions and replace
-# libmvec-abi-funcs with libmvec-funcs.
-libmvec-abi-funcs = \
- sincos
-
# The base libmvec ABI tests.
libmvec-abi-func-tests = \
- $(addprefix test-double-libmvec-,$(libmvec-abi-funcs)) \
- $(addsuffix f,$(addprefix test-float-libmvec-,$(libmvec-abi-funcs)))
+ $(addprefix test-double-libmvec-,$(libmvec-funcs)) \
+ $(addsuffix f,$(addprefix test-float-libmvec-,$(libmvec-funcs)))
# The AVX libmvec ABI tests.
libmvec-abi-func-avx-tests = \
echo; \
done; \
done; \
- for t in $(libmvec-abi-funcs); do \
+ for t in $(libmvec-funcs); do \
echo "CFLAGS-test-double-libmvec-$$t.c = \\"; \
echo " \$$(libmvec-abi-test-cflags)"; \
echo "CFLAGS-test-double-libmvec-$$t-avx.c = \\"; \
--- /dev/null
+#include "test-double-libmvec-cos.c"
--- /dev/null
+#include "test-double-libmvec-cos.c"
--- /dev/null
+#include "test-double-libmvec-cos.c"
--- /dev/null
+#define LIBMVEC_TYPE double
+#define LIBMVEC_FUNC cos
+#include "test-vector-abi-arg1.h"
--- /dev/null
+#include "test-double-libmvec-exp.c"
--- /dev/null
+#include "test-double-libmvec-exp.c"
--- /dev/null
+#include "test-double-libmvec-exp.c"
--- /dev/null
+#define LIBMVEC_TYPE double
+#define LIBMVEC_FUNC exp
+#include "test-vector-abi-arg1.h"
--- /dev/null
+#include "test-double-libmvec-log.c"
--- /dev/null
+#include "test-double-libmvec-log.c"
--- /dev/null
+#include "test-double-libmvec-log.c"
--- /dev/null
+#define LIBMVEC_TYPE double
+#define LIBMVEC_FUNC log
+#include "test-vector-abi-arg1.h"
--- /dev/null
+#include "test-double-libmvec-pow.c"
--- /dev/null
+#include "test-double-libmvec-pow.c"
--- /dev/null
+#include "test-double-libmvec-pow.c"
--- /dev/null
+#define LIBMVEC_TYPE double
+#define LIBMVEC_FUNC pow
+#include "test-vector-abi-arg2.h"
--- /dev/null
+#include "test-double-libmvec-sin.c"
--- /dev/null
+#include "test-double-libmvec-sin.c"
--- /dev/null
+#include "test-double-libmvec-sin.c"
--- /dev/null
+#define LIBMVEC_TYPE double
+#define LIBMVEC_FUNC sin
+#include "test-vector-abi-arg1.h"
--- /dev/null
+#include "test-float-libmvec-cosf.c"
--- /dev/null
+#include "test-float-libmvec-cosf.c"
--- /dev/null
+#include "test-float-libmvec-cosf.c"
--- /dev/null
+#define LIBMVEC_TYPE float
+#define LIBMVEC_FUNC cosf
+#include "test-vector-abi-arg1.h"
--- /dev/null
+#include "test-float-libmvec-expf.c"
--- /dev/null
+#include "test-float-libmvec-expf.c"
--- /dev/null
+#include "test-float-libmvec-expf.c"
--- /dev/null
+#define LIBMVEC_TYPE float
+#define LIBMVEC_FUNC expf
+#include "test-vector-abi-arg1.h"
--- /dev/null
+#include "test-float-libmvec-logf.c"
--- /dev/null
+#include "test-float-libmvec-logf.c"
--- /dev/null
+#include "test-float-libmvec-logf.c"
--- /dev/null
+#define LIBMVEC_TYPE float
+#define LIBMVEC_FUNC logf
+#include "test-vector-abi-arg1.h"
--- /dev/null
+#include "test-float-libmvec-powf.c"
--- /dev/null
+#include "test-float-libmvec-powf.c"
--- /dev/null
+#include "test-float-libmvec-powf.c"
--- /dev/null
+#define LIBMVEC_TYPE float
+#define LIBMVEC_FUNC powf
+#include "test-vector-abi-arg2.h"
--- /dev/null
+#include "test-float-libmvec-sinf.c"
--- /dev/null
+#include "test-float-libmvec-sinf.c"
--- /dev/null
+#include "test-float-libmvec-sinf.c"
--- /dev/null
+#define LIBMVEC_TYPE float
+#define LIBMVEC_FUNC sinf
+#include "test-vector-abi-arg1.h"
--- /dev/null
+/* Test for vector ABI with a single argument.
+ Copyright (C) 2016-2021 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
+ <https://www.gnu.org/licenses/>. */
+
+#include <math.h>
+#include <support/test-driver.h>
+
+/* Since libsupport_nonshared.a is placed before test-libmvec*.o, which
+ defines do_test, reference support_test_main here to include it to
+ avoid undefined reference to support_test_main. The libmvec ABI test
+ doesn't need other symbols in libsupport_nonshared.a. */
+__typeof (support_test_main) *support_test_main_p = support_test_main;
+
+#define N 1000
+LIBMVEC_TYPE x[N], c[N];
+
+int
+test_vector_abi (void)
+{
+ int i;
+ for(i = 0; i < N; i++)
+ c[i] = i / 3;
+
+#pragma omp simd
+ for(i = 0; i < N; i++)
+ x[i] = LIBMVEC_FUNC (c[i]);
+
+ return 0;
+}
--- /dev/null
+/* Test for vector ABI with 2 arguments.
+ Copyright (C) 2016-2021 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
+ <https://www.gnu.org/licenses/>. */
+
+#include <math.h>
+#include <support/test-driver.h>
+
+/* Since libsupport_nonshared.a is placed before test-libmvec*.o, which
+ defines do_test, reference support_test_main here to include it to
+ avoid undefined reference to support_test_main. The libmvec ABI test
+ doesn't need other symbols in libsupport_nonshared.a. */
+__typeof (support_test_main) *support_test_main_p = support_test_main;
+
+#define N 1000
+LIBMVEC_TYPE x[N], s[N], c[N];
+
+int
+test_vector_abi (void)
+{
+ int i;
+ for(i = 0; i < N; i++)
+ {
+ c[i] = i / 3;
+ s[i] = c[i];
+ }
+
+#pragma omp simd
+ for(i = 0; i < N; i++)
+ x[i] = LIBMVEC_FUNC (s[i], c[i]);
+
+ return 0;
+}