summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorPaul Eggert <eggert@cs.ucla.edu>2021-12-06 10:29:54 -0800
committerPaul Eggert <eggert@cs.ucla.edu>2021-12-06 10:30:25 -0800
commitebc4aef867bdac47d82f990b3ee0e6cd25424a42 (patch)
tree8f5723f30e92f39f91d195677d4e81f332b0debc /lib
parent1c86f7f3ffa2fd7584df3be376a5ab6a45dc96da (diff)
downloadgnulib-ebc4aef867bdac47d82f990b3ee0e6cd25424a42.tar.gz
intprops: streamline and get ready for Clang 14
* lib/intprops.h (_GL_HAS_BUILTIN_ADD_OVERFLOW): Rely on __has_builtin first, since GCC didn’t introduce it until GCC 9 so we don’t need to special-case GCC first. (_GL_HAS_BUILTIN_ADD_OVERFLOW, _GL_HAS_BUILTIN_OVERFLOW_P): Look at __EDG__ rather than __ICC, since icc defines __EDG__ too. (_GL_HAS_BUILTIN_MUL_OVERFLOW): Define to 1 in Clang 14 and later, as a bug fix is scheduled for Clang 14. (_GL_HAS_BUILTIN_OVERFLOW_P): Do not bother to special-case __clang__, since __has_builtin should do the right thing anyway.
Diffstat (limited to 'lib')
-rw-r--r--lib/intprops.h20
1 files changed, 9 insertions, 11 deletions
diff --git a/lib/intprops.h b/lib/intprops.h
index b36e0bbed9..7f20f09fa0 100644
--- a/lib/intprops.h
+++ b/lib/intprops.h
@@ -229,18 +229,18 @@
/* True if __builtin_add_overflow (A, B, P) and __builtin_sub_overflow
(A, B, P) work when P is non-null. */
+#if defined __has_builtin
+# define _GL_HAS_BUILTIN_ADD_OVERFLOW __has_builtin (__builtin_add_overflow)
/* __builtin_{add,sub}_overflow exists but is not reliable in GCC 5.x and 6.x,
see <https://gcc.gnu.org/bugzilla/show_bug.cgi?id=98269>. */
-#if 7 <= __GNUC__ && !defined __ICC
+#elif 7 <= __GNUC__ && !defined __EDG__
# define _GL_HAS_BUILTIN_ADD_OVERFLOW 1
-#elif defined __has_builtin
-# define _GL_HAS_BUILTIN_ADD_OVERFLOW __has_builtin (__builtin_add_overflow)
#else
# define _GL_HAS_BUILTIN_ADD_OVERFLOW 0
#endif
/* True if __builtin_mul_overflow (A, B, P) works when P is non-null. */
-#ifdef __clang__
+#if defined __clang_major_ && __clang_major__ < 14
/* Work around Clang bug <https://bugs.llvm.org/show_bug.cgi?id=16404>. */
# define _GL_HAS_BUILTIN_MUL_OVERFLOW 0
#else
@@ -249,12 +249,10 @@
/* True if __builtin_add_overflow_p (A, B, C) works, and similarly for
__builtin_sub_overflow_p and __builtin_mul_overflow_p. */
-#if defined __clang__ || defined __ICC || defined __EDG__
-/* Clang 11 lacks __builtin_mul_overflow_p, and even if it did it
- would presumably run afoul of Clang bug 16404. In ICC 2021.1 and
- the EDG-based MCST Elbrus LCC compiler, __builtin_add_overflow_p etc.
- are not treated as integral constant expressions even when all
- arguments are. */
+#ifdef __EDG__
+/* In EDG-based compilers like ICC 2021.3 and earlier,
+ __builtin_add_overflow_p etc. are not treated as integral constant
+ expressions even when all arguments are. */
# define _GL_HAS_BUILTIN_OVERFLOW_P 0
#elif defined __has_builtin
# define _GL_HAS_BUILTIN_OVERFLOW_P __has_builtin (__builtin_mul_overflow_p)
@@ -401,7 +399,7 @@
#if _GL_HAS_BUILTIN_MUL_OVERFLOW
# if ((9 < __GNUC__ + (3 <= __GNUC_MINOR__) \
|| (__GNUC__ == 8 && 4 <= __GNUC_MINOR__)) \
- && !defined __ICC)
+ && !defined __EDG__)
# define INT_MULTIPLY_WRAPV(a, b, r) __builtin_mul_overflow (a, b, r)
# else
/* Work around GCC bug 91450. */