Commit 7f8ae019 by lhchavez

Avoid using `__builtin_mul_overflow` with the clang+32-bit combo

This causes clang to produce an undefined reference to `__mulodi4`. This
could be fixed by statically linking some compiler-rt libraries to
provide this symbol, but let's first stop the bleeding since doing the
correct long-term fix requires some non-trivial CMake knowledge which I
lack.
parent 530d37be
...@@ -79,8 +79,12 @@ GIT_INLINE(int) git__is_int(long long p) ...@@ -79,8 +79,12 @@ GIT_INLINE(int) git__is_int(long long p)
# define git__add_int64_overflow(out, one, two) \ # define git__add_int64_overflow(out, one, two) \
__builtin_add_overflow(one, two, out) __builtin_add_overflow(one, two, out)
# define git__multiply_int64_overflow(out, one, two) \
__builtin_mul_overflow(one, two, out) /* clang on 32-bit systems produces an undefined reference to `__mulodi4`. */
# if !defined(__clang__) || !defined(GIT_ARCH_32)
# define git__multiply_int64_overflow(out, one, two) \
__builtin_mul_overflow(one, two, out)
# endif
/* Use Microsoft's safe integer handling functions where available */ /* Use Microsoft's safe integer handling functions where available */
#elif defined(_MSC_VER) #elif defined(_MSC_VER)
...@@ -156,6 +160,10 @@ GIT_INLINE(bool) git__add_int64_overflow(int64_t *out, int64_t one, int64_t two) ...@@ -156,6 +160,10 @@ GIT_INLINE(bool) git__add_int64_overflow(int64_t *out, int64_t one, int64_t two)
return false; return false;
} }
#endif
/* If we could not provide an intrinsic implementation for this, provide a (slow) fallback. */
#if !defined(git__multiply_int64_overflow)
GIT_INLINE(bool) git__multiply_int64_overflow(int64_t *out, int64_t one, int64_t two) GIT_INLINE(bool) git__multiply_int64_overflow(int64_t *out, int64_t one, int64_t two)
{ {
if ((one == -1 && two == INT_MIN) || if ((one == -1 && two == INT_MIN) ||
...@@ -166,7 +174,6 @@ GIT_INLINE(bool) git__multiply_int64_overflow(int64_t *out, int64_t one, int64_t ...@@ -166,7 +174,6 @@ GIT_INLINE(bool) git__multiply_int64_overflow(int64_t *out, int64_t one, int64_t
*out = one * two; *out = one * two;
return false; return false;
} }
#endif #endif
#endif #endif
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment