aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAdhemerval Zanella <adhemerval.zanella@linaro.org>2022-03-10 14:41:31 -0300
committerPranav Kant <prka@google.com>2023-09-26 19:02:33 +0000
commit950a6559add2cf1a547ae93651e3a96880206054 (patch)
treedbbab213702b4eba576f52c640aa3d21518e380b
parent3697387eaba3c225239ba2ddd636231033273788 (diff)
downloadglibc-950a6559add2cf1a547ae93651e3a96880206054.zip
glibc-950a6559add2cf1a547ae93651e3a96880206054.tar.gz
glibc-950a6559add2cf1a547ae93651e3a96880206054.tar.bz2
math: x86: Avoid the use of __libgcc_cmp_return__ for __gcc_CMPtype
-rw-r--r--sysdeps/x86/fpu/sfp-machine.h13
1 files changed, 11 insertions, 2 deletions
diff --git a/sysdeps/x86/fpu/sfp-machine.h b/sysdeps/x86/fpu/sfp-machine.h
index df8906a..fcbcf69 100644
--- a/sysdeps/x86/fpu/sfp-machine.h
+++ b/sysdeps/x86/fpu/sfp-machine.h
@@ -1,10 +1,19 @@
/* Configure soft-fp for building sqrtf128. Based on sfp-machine.h in
libgcc, with soft-float and other irrelevant parts removed. */
+#if defined __x86_64__ && defined __ILP32__
+typedef long long int __gcc_CMPtype;
+#else
+typedef long int __gcc_CMPtype;
+#endif
+#if !defined(__clang__) && defined(__GNUC__)
/* The type of the result of a floating point comparison. This must
match `__libgcc_cmp_return__' in GCC for the target. */
-typedef int __gcc_CMPtype __attribute__ ((mode (__libgcc_cmp_return__)));
-#define CMPtype __gcc_CMPtype
+typedef int __gcc_CMPtype_GCC __attribute__ ((mode (__libgcc_cmp_return__)));
+# define CMPtype __gcc_CMPtype
+_Static_assert(sizeof(__gcc_CMPtype) == sizeof(__gcc_CMPtype_GCC),
+ "sizeof(__gcc_CMPtype) != sizeof(__gcc_CMPtype_GCC)");
+#endif
#ifdef __x86_64__
# define _FP_W_TYPE_SIZE 64