]> git.ipfire.org Git - thirdparty/glibc.git/commit
x86-64: Add vector exp10/exp10f implementation to libmvec
authorSunil K Pandey <skpgkp2@gmail.com>
Wed, 29 Dec 2021 16:47:16 +0000 (08:47 -0800)
committerSunil K Pandey <skpgkp2@gmail.com>
Wed, 29 Dec 2021 19:37:35 +0000 (11:37 -0800)
commit8b726453d560eef536c9ff730f5f5be05b4ad6a7
treee0c268c135f5970bf6c6d20022cae4dfdaa72e4d
parent3fc9ccc20b6d0d5e4517d2e766f14ce780a228a5
x86-64: Add vector exp10/exp10f implementation to libmvec

Implement vectorized exp10/exp10f containing SSE, AVX, AVX2 and
AVX512 versions for libmvec as per vector ABI.  It also contains
accuracy and ABI tests for vector exp10/exp10f with regenerated ulps.

Reviewed-by: H.J. Lu <hjl.tools@gmail.com>
50 files changed:
bits/libm-simd-decl-stubs.h
math/bits/mathcalls.h
sysdeps/unix/sysv/linux/x86_64/libmvec.abilist
sysdeps/x86/fpu/bits/math-vector.h
sysdeps/x86/fpu/finclude/math-vector-fortran.h
sysdeps/x86_64/fpu/Makeconfig
sysdeps/x86_64/fpu/Versions
sysdeps/x86_64/fpu/libm-test-ulps
sysdeps/x86_64/fpu/multiarch/svml_d_exp102_core-sse2.S [new file with mode: 0644]
sysdeps/x86_64/fpu/multiarch/svml_d_exp102_core.c [new file with mode: 0644]
sysdeps/x86_64/fpu/multiarch/svml_d_exp102_core_sse4.S [new file with mode: 0644]
sysdeps/x86_64/fpu/multiarch/svml_d_exp104_core-sse.S [new file with mode: 0644]
sysdeps/x86_64/fpu/multiarch/svml_d_exp104_core.c [new file with mode: 0644]
sysdeps/x86_64/fpu/multiarch/svml_d_exp104_core_avx2.S [new file with mode: 0644]
sysdeps/x86_64/fpu/multiarch/svml_d_exp108_core-avx2.S [new file with mode: 0644]
sysdeps/x86_64/fpu/multiarch/svml_d_exp108_core.c [new file with mode: 0644]
sysdeps/x86_64/fpu/multiarch/svml_d_exp108_core_avx512.S [new file with mode: 0644]
sysdeps/x86_64/fpu/multiarch/svml_s_exp10f16_core-avx2.S [new file with mode: 0644]
sysdeps/x86_64/fpu/multiarch/svml_s_exp10f16_core.c [new file with mode: 0644]
sysdeps/x86_64/fpu/multiarch/svml_s_exp10f16_core_avx512.S [new file with mode: 0644]
sysdeps/x86_64/fpu/multiarch/svml_s_exp10f4_core-sse2.S [new file with mode: 0644]
sysdeps/x86_64/fpu/multiarch/svml_s_exp10f4_core.c [new file with mode: 0644]
sysdeps/x86_64/fpu/multiarch/svml_s_exp10f4_core_sse4.S [new file with mode: 0644]
sysdeps/x86_64/fpu/multiarch/svml_s_exp10f8_core-sse.S [new file with mode: 0644]
sysdeps/x86_64/fpu/multiarch/svml_s_exp10f8_core.c [new file with mode: 0644]
sysdeps/x86_64/fpu/multiarch/svml_s_exp10f8_core_avx2.S [new file with mode: 0644]
sysdeps/x86_64/fpu/svml_d_exp102_core.S [new file with mode: 0644]
sysdeps/x86_64/fpu/svml_d_exp104_core.S [new file with mode: 0644]
sysdeps/x86_64/fpu/svml_d_exp104_core_avx.S [new file with mode: 0644]
sysdeps/x86_64/fpu/svml_d_exp108_core.S [new file with mode: 0644]
sysdeps/x86_64/fpu/svml_s_exp10f16_core.S [new file with mode: 0644]
sysdeps/x86_64/fpu/svml_s_exp10f4_core.S [new file with mode: 0644]
sysdeps/x86_64/fpu/svml_s_exp10f8_core.S [new file with mode: 0644]
sysdeps/x86_64/fpu/svml_s_exp10f8_core_avx.S [new file with mode: 0644]
sysdeps/x86_64/fpu/test-double-libmvec-exp10-avx.c [new file with mode: 0644]
sysdeps/x86_64/fpu/test-double-libmvec-exp10-avx2.c [new file with mode: 0644]
sysdeps/x86_64/fpu/test-double-libmvec-exp10-avx512f.c [new file with mode: 0644]
sysdeps/x86_64/fpu/test-double-libmvec-exp10.c [new file with mode: 0644]
sysdeps/x86_64/fpu/test-double-vlen2-wrappers.c
sysdeps/x86_64/fpu/test-double-vlen4-avx2-wrappers.c
sysdeps/x86_64/fpu/test-double-vlen4-wrappers.c
sysdeps/x86_64/fpu/test-double-vlen8-wrappers.c
sysdeps/x86_64/fpu/test-float-libmvec-exp10f-avx.c [new file with mode: 0644]
sysdeps/x86_64/fpu/test-float-libmvec-exp10f-avx2.c [new file with mode: 0644]
sysdeps/x86_64/fpu/test-float-libmvec-exp10f-avx512f.c [new file with mode: 0644]
sysdeps/x86_64/fpu/test-float-libmvec-exp10f.c [new file with mode: 0644]
sysdeps/x86_64/fpu/test-float-vlen16-wrappers.c
sysdeps/x86_64/fpu/test-float-vlen4-wrappers.c
sysdeps/x86_64/fpu/test-float-vlen8-avx2-wrappers.c
sysdeps/x86_64/fpu/test-float-vlen8-wrappers.c