commit 75b80516d5133202b1e6848ad0c6d640543b313c
parent dc69c475a5804c6c01987722f4cf6298d4e33e64
Author: Famiu Haque <famiuhaque@proton.me>
Date: Fri, 5 Apr 2024 07:56:35 +0600
build: fix link error for `_BitScanForward64` (#28173)
Problem: The usage of `_BitScanForward64` causes linking to fail on some systems.
Solution: Correctly check if it exists using `check_c_source_compiles`.
Diffstat:
3 files changed, 13 insertions(+), 1 deletion(-)
diff --git a/cmake.config/CMakeLists.txt b/cmake.config/CMakeLists.txt
@@ -79,6 +79,17 @@ int main(void)
}
" HAVE_PWD_FUNCS)
+check_c_source_compiles("
+#include <intrin.h>
+
+int main(void)
+{
+ unsigned long index;
+ unsigned char mask = 0x8000;
+ _BitScanForward64(&index, mask);
+ return 0;
+}
+" HAVE_BITSCANFORWARD64)
if(CMAKE_SYSTEM_NAME STREQUAL "SunOS")
check_c_source_compiles("
diff --git a/cmake.config/config.h.in b/cmake.config/config.h.in
@@ -52,3 +52,4 @@
#cmakedefine HAVE_EXECINFO_BACKTRACE
#cmakedefine HAVE_BUILTIN_ADD_OVERFLOW
#cmakedefine HAVE_WIMPLICIT_FALLTHROUGH_FLAG
+#cmakedefine HAVE_BITSCANFORWARD64
diff --git a/src/nvim/math.c b/src/nvim/math.c
@@ -56,7 +56,7 @@ int xctz(uint64_t x)
// Use compiler builtin if possible.
#if defined(__clang__) || (defined(__GNUC__) && (__GNUC__ >= 4))
return __builtin_ctzll(x);
-#elif defined(_MSC_VER)
+#elif defined(HAVE_BITSCANFORWARD64)
unsigned long index;
_BitScanForward64(&index, x);
return (int)index;