diff options
author | Sunil K Pandey <skpgkp2@gmail.com> | 2024-02-13 12:23:14 -0800 |
---|---|---|
committer | H.J. Lu <hjl.tools@gmail.com> | 2024-04-14 05:41:02 -0700 |
commit | 423099a03264ea28298f47355d7811b8efe03c97 (patch) | |
tree | f97479dc0237ab13396d8a07bab4e9016374e7b5 /sysdeps/x86_64/fpu/multiarch/w_exp.c | |
parent | 04df8652eb1919da18d54b3dcd6db1675993d45d (diff) | |
download | glibc-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.c | 7 |
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 |