]> git.ipfire.org Git - thirdparty/glibc.git/blame - sysdeps/x86_64/fpu/Makeconfig
x86-64: Add vector log1p/log1pf to libmvec microbenchmark
[thirdparty/glibc.git] / sysdeps / x86_64 / fpu / Makeconfig
CommitLineData
d962cce1
L
1# Generate libmvec.mk for libmvec ABI tests.
2
581c785b 3# Copyright (C) 2021-2022 Free Software Foundation, Inc.
d962cce1
L
4# This file is part of the GNU C Library.
5
6# The GNU C Library is free software; you can redistribute it and/or
7# modify it under the terms of the GNU Lesser General Public
8# License as published by the Free Software Foundation; either
9# version 2.1 of the License, or (at your option) any later version.
10
11# The GNU C Library is distributed in the hope that it will be useful,
12# but WITHOUT ANY WARRANTY; without even the implied warranty of
13# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14# Lesser General Public License for more details.
15
16# You should have received a copy of the GNU Lesser General Public
17# License along with the GNU C Library; if not, see
18# <https://www.gnu.org/licenses/>.
19
20-include $(common-objpfx)libmvec.mk
21postclean-generated += libmvec.mk
22
23# Define for both math and mathvec directories.
24libmvec-funcs = \
f20f980c 25 acos \
0625489c 26 acosh \
11c01de1 27 asin \
e682d015 28 asinh \
14631017 29 atan \
2941a24f 30 atan2 \
6dea4dd3 31 atanh \
2bf02c58 32 cbrt \
d962cce1 33 cos \
ef7ea9c1 34 cosh \
f9ce13fd 35 erf \
8881cca8 36 erfc \
d962cce1 37 exp \
8b726453 38 exp10 \
3fc9ccc2 39 exp2 \
76ddc74e 40 expm1 \
37475ba8 41 hypot \
d962cce1 42 log \
8f856602 43 log10 \
74265c16 44 log1p \
7e1722fe 45 log2 \
d962cce1
L
46 pow \
47 sin \
48 sincos \
aa1809a1 49 sinh \
c21c7bc2 50 tan \
c0f36fc3 51 tanh \
d962cce1 52
a43c0b54
SP
53# Define libmvec function for benchtests directory.
54libmvec-bench-funcs = \
811124ce 55 acos \
e96f2542 56 asin \
7e05d94e 57 atan \
16aec301 58 atan2 \
fec48238 59 cbrt \
44436955 60 cos \
54cf4f31 61 cosh \
37df38bd 62 exp \
abebb261 63 exp10 \
b0e43607 64 exp2 \
049555aa 65 expm1 \
b0a11070 66 hypot \
8ab8afb3 67 log \
e43b757e 68 log10 \
171817d8 69 log1p \
b6b2be5c 70 log2 \
6a556bac 71 pow \
c58d3b7d 72 sin \
6acc09c5 73 sinh \
a43c0b54
SP
74
75bench-libmvec-double = \
76 $(addprefix double-vlen1-, $(libmvec-bench-funcs)) \
77 $(addprefix double-vlen2-, $(libmvec-bench-funcs)) \
78 $(addprefix double-vlen4-, $(libmvec-bench-funcs)) \
79 $(addprefix double-vlen4-avx2-, $(libmvec-bench-funcs)) \
80 $(addprefix double-vlen8-, $(libmvec-bench-funcs)) \
81
82bench-libmvec-float = \
83 $(addsuffix f, $(addprefix float-vlen1-, $(libmvec-bench-funcs))) \
84 $(addsuffix f, $(addprefix float-vlen4-, $(libmvec-bench-funcs))) \
85 $(addsuffix f, $(addprefix float-vlen8-, $(libmvec-bench-funcs))) \
86 $(addsuffix f, $(addprefix float-vlen8-avx2-, $(libmvec-bench-funcs))) \
87 $(addsuffix f, $(addprefix float-vlen16-, $(libmvec-bench-funcs))) \
88
d962cce1
L
89# The base libmvec ABI tests.
90libmvec-abi-func-tests = \
4f690aad
SP
91 $(addprefix test-double-libmvec-,$(libmvec-funcs)) \
92 $(addsuffix f,$(addprefix test-float-libmvec-,$(libmvec-funcs)))
d962cce1
L
93
94# The AVX libmvec ABI tests.
95libmvec-abi-func-avx-tests = \
96 $(addsuffix -avx,$(libmvec-abi-func-tests))
97#
98# The AVX2 libmvec ABI tests.
99libmvec-abi-func-avx2-tests = \
100 $(addsuffix -avx2,$(libmvec-abi-func-tests))
101#
102# The AVX512F libmvec ABI tests.
103libmvec-abi-func-avx512f-tests = \
104 $(addsuffix -avx512f,$(libmvec-abi-func-tests))
105
106$(common-objpfx)libmvec.mk: $(common-objpfx)config.make
107 (echo "ifeq (\$$(subdir)\$$(build-mathvec),mathyes)"; \
108 echo; \
109 for i in "" "-avx" "-avx2" "-avx512f"; do \
110 for t in $(libmvec-abi-func-tests); do \
111 echo "\$$(objpfx)$$t$$i: \\"; \
112 echo " \$$(objpfx)$$t$$i.o \\"; \
113 echo " \$$(objpfx)test-libmvec$$i.o \$$(libmvec)"; \
114 echo; \
115 done; \
116 done; \
4f690aad 117 for t in $(libmvec-funcs); do \
d962cce1
L
118 echo "CFLAGS-test-double-libmvec-$$t.c = \\"; \
119 echo " \$$(libmvec-abi-test-cflags)"; \
120 echo "CFLAGS-test-double-libmvec-$$t-avx.c = \\"; \
121 echo " \$$(libmvec-abi-test-cflags) \\"; \
122 echo " \$$(double-vlen4-arch-ext-cflags)"; \
123 echo "CFLAGS-test-double-libmvec-$$t-avx2.c = \\"; \
124 echo " \$$(libmvec-abi-test-cflags) \\"; \
125 echo " \$$(double-vlen4-arch-ext2-cflags)"; \
126 echo "CFLAGS-test-double-libmvec-$$t-avx512f.c = \\"; \
127 echo " \$$(libmvec-abi-test-cflags) \\"; \
128 echo " \$$(double-vlen8-arch-ext-cflags)"; \
129 echo; \
130 echo "CFLAGS-test-float-libmvec-$${t}f.c = \\"; \
131 echo " \$$(libmvec-abi-test-cflags)"; \
132 echo "CFLAGS-test-float-libmvec-$${t}f-avx.c = \\"; \
133 echo " \$$(libmvec-abi-test-cflags) \\"; \
134 echo " \$$(float-vlen8-arch-ext-cflags)"; \
135 echo "CFLAGS-test-float-libmvec-$${t}f-avx2.c = \\"; \
136 echo " \$$(libmvec-abi-test-cflags) \\"; \
137 echo " \$$(float-vlen8-arch-ext2-cflags)"; \
138 echo "CFLAGS-test-float-libmvec-$${t}f-avx512f.c = \\"; \
139 echo " \$$(libmvec-abi-test-cflags) \\"; \
140 echo " \$$(float-vlen16-arch-ext-cflags)"; \
141 echo; \
142 done; \
a43c0b54
SP
143 echo "endif"; \
144 echo "ifeq (\$$(subdir),benchtests)"; \
145 for t in $(libmvec-bench-funcs); do \
146 echo "CFLAGS-bench-double-vlen4-$$t.c = \\"; \
147 echo " \$$(double-vlen4-arch-ext-cflags)"; \
148 echo "CFLAGS-bench-double-vlen4-avx2-$$t.c = \\"; \
149 echo " \$$(double-vlen4-arch-ext2-cflags)"; \
150 echo "CFLAGS-bench-double-vlen8-$$t.c = \\"; \
151 echo " \$$(double-vlen8-arch-ext-cflags)"; \
152 echo; \
153 echo "CFLAGS-bench-float-vlen8-$${t}f.c = \\"; \
154 echo " \$$(float-vlen8-arch-ext-cflags)"; \
155 echo "CFLAGS-bench-float-vlen8-avx2-$${t}f.c = \\"; \
156 echo " \$$(float-vlen8-arch-ext2-cflags)"; \
157 echo "CFLAGS-bench-float-vlen16-$${t}f.c = \\"; \
158 echo " \$$(float-vlen16-arch-ext-cflags)"; \
159 echo; \
160 done; \
d962cce1
L
161 echo "endif") > $@T
162 mv -f $@T $@