about summary refs log tree commit diff
path: root/sysdeps/x86_64/fpu/multiarch/s_rintf-sse4_1.S
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/s_rintf-sse4_1.S
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/s_rintf-sse4_1.S')
-rw-r--r--sysdeps/x86_64/fpu/multiarch/s_rintf-sse4_1.S12
1 files changed, 12 insertions, 0 deletions
diff --git a/sysdeps/x86_64/fpu/multiarch/s_rintf-sse4_1.S b/sysdeps/x86_64/fpu/multiarch/s_rintf-sse4_1.S
index 8ac67ce767..fc1e70f0c9 100644
--- a/sysdeps/x86_64/fpu/multiarch/s_rintf-sse4_1.S
+++ b/sysdeps/x86_64/fpu/multiarch/s_rintf-sse4_1.S
@@ -17,8 +17,20 @@
 
 #include <sysdep.h>
 
+#include <sysdeps/x86/isa-level.h>
+#if MINIMUM_X86_ISA_LEVEL == SSE4_1_X86_ISA_LEVEL
+# include <libm-alias-float.h>
+# define __rintf_sse41 __rintf
+	.text
+#else
 	.section .text.sse4.1,"ax",@progbits
+#endif
+
 ENTRY(__rintf_sse41)
 	roundss	$4, %xmm0, %xmm0
 	ret
 END(__rintf_sse41)
+
+#if MINIMUM_X86_ISA_LEVEL == SSE4_1_X86_ISA_LEVEL
+libm_alias_float (__rint, rint)
+#endif