about summary refs log tree commit diff
path: root/sysdeps/x86_64/fpu/multiarch/w_exp.c
diff options
context:
space:
mode:
authorSunil K Pandey <skpgkp2@gmail.com>2024-02-13 12:23:14 -0800
committerH.J. Lu <hjl.tools@gmail.com>2024-04-14 05:41:02 -0700
commit423099a03264ea28298f47355d7811b8efe03c97 (patch)
treef97479dc0237ab13396d8a07bab4e9016374e7b5 /sysdeps/x86_64/fpu/multiarch/w_exp.c
parent04df8652eb1919da18d54b3dcd6db1675993d45d (diff)
downloadglibc-423099a03264ea28298f47355d7811b8efe03c97.tar.gz
glibc-423099a03264ea28298f47355d7811b8efe03c97.tar.xz
glibc-423099a03264ea28298f47355d7811b8efe03c97.zip
x86_64: Exclude SSE, AVX and FMA4 variants in libm multiarch
When glibc is built with ISA level 3 or higher by default, the resulting
glibc binaries won't run on SSE or FMA4 processors.  Exclude SSE, AVX and
FMA4 variants in libm multiarch when ISA level 3 or higher is enabled by
default.

When glibc is built with ISA level 2 enabled by default, only keep SSE4.1
variant.

Fixes BZ 31335.

NB: elf/tst-valgrind-smoke test fails with ISA level 4, because valgrind
doesn't support AVX512 instructions:

https://bugs.kde.org/show_bug.cgi?id=383010

Reviewed-by: H.J. Lu <hjl.tools@gmail.com>
(cherry picked from commit 9f78a7c1d0963282608da836b840f0d5ae1c478e)
Diffstat (limited to 'sysdeps/x86_64/fpu/multiarch/w_exp.c')
-rw-r--r--sysdeps/x86_64/fpu/multiarch/w_exp.c7
1 files changed, 6 insertions, 1 deletions
diff --git a/sysdeps/x86_64/fpu/multiarch/w_exp.c b/sysdeps/x86_64/fpu/multiarch/w_exp.c
index 27eee98a0a..3584187e0e 100644
--- a/sysdeps/x86_64/fpu/multiarch/w_exp.c
+++ b/sysdeps/x86_64/fpu/multiarch/w_exp.c
@@ -1 +1,6 @@
-#include <sysdeps/../math/w_exp.c>
+#include <sysdeps/x86/isa-level.h>
+#if MINIMUM_X86_ISA_LEVEL >= AVX2_X86_ISA_LEVEL
+# include <sysdeps/ieee754/dbl-64/w_exp.c>
+#else
+# include <sysdeps/../math/w_exp.c>
+#endif