[Openmp-commits] [openmp] a356782 - [OpenMP][mingw] Fix build for aarch64 target
Martin Storsjö via Openmp-commits
openmp-commits at lists.llvm.org
Tue Nov 8 05:28:08 PST 2022
Author: Alvin Wong
Date: 2022-11-08T15:27:03+02:00
New Revision: a356782426f5bf54a00570e1f925345e5fda7b2e
URL: https://github.com/llvm/llvm-project/commit/a356782426f5bf54a00570e1f925345e5fda7b2e
DIFF: https://github.com/llvm/llvm-project/commit/a356782426f5bf54a00570e1f925345e5fda7b2e.diff
LOG: [OpenMP][mingw] Fix build for aarch64 target
This patch changes AArch64 + `__GNUC__` to use `__sync` builtins to
implement internal atomic macros just like for Unix, because mingw-w64
is missing some of the intrinsics which the MSVC codepath is using.
Then some remaining intel-only functions are removed from dllexport to
fix linking.
This should fix https://github.com/llvm/llvm-project/issues/56349.
Reviewed By: natgla
Differential Revision: https://reviews.llvm.org/D137168
Added:
Modified:
openmp/runtime/src/dllexports
openmp/runtime/src/kmp_os.h
openmp/runtime/src/kmp_utility.cpp
Removed:
################################################################################
diff --git a/openmp/runtime/src/dllexports b/openmp/runtime/src/dllexports
index 2fd1d90982a3d..a541f582a940e 100644
--- a/openmp/runtime/src/dllexports
+++ b/openmp/runtime/src/dllexports
@@ -1243,7 +1243,6 @@ kmp_set_disp_num_buffers 890
%ifdef IS_IA_ARCH
__kmpc_atomic_float10_max 2139
__kmpc_atomic_float10_min 2140
- %endif
__kmpc_atomic_float10_max_cpt 2141
__kmpc_atomic_float10_min_cpt 2142
@@ -1263,6 +1262,7 @@ kmp_set_disp_num_buffers 890
__kmpc_atomic_val_2_cas_cpt 2156
__kmpc_atomic_val_4_cas_cpt 2157
__kmpc_atomic_val_8_cas_cpt 2158
+ %endif
%endif
diff --git a/openmp/runtime/src/kmp_os.h b/openmp/runtime/src/kmp_os.h
index 458609cb6fe76..1a802ced69c11 100644
--- a/openmp/runtime/src/kmp_os.h
+++ b/openmp/runtime/src/kmp_os.h
@@ -456,7 +456,7 @@ enum kmp_mem_fence_type {
// Synchronization primitives
-#if KMP_ASM_INTRINS && KMP_OS_WINDOWS
+#if KMP_ASM_INTRINS && KMP_OS_WINDOWS && !(KMP_ARCH_AARCH64 && defined(__GNUC__))
#if KMP_MSVC_COMPAT && !KMP_COMPILER_CLANG
#pragma intrinsic(InterlockedExchangeAdd)
diff --git a/openmp/runtime/src/kmp_utility.cpp b/openmp/runtime/src/kmp_utility.cpp
index 48d31e5ee7b73..53ff1788a074b 100644
--- a/openmp/runtime/src/kmp_utility.cpp
+++ b/openmp/runtime/src/kmp_utility.cpp
@@ -370,7 +370,7 @@ void __kmp_expand_file_name(char *result, size_t rlen, char *pattern) {
case 'I':
case 'i': {
pid_t id = getpid();
-#if KMP_ARCH_X86_64 && defined(__MINGW32__)
+#if (KMP_ARCH_X86_64 || KMP_ARCH_AARCH64) && defined(__MINGW32__)
snp_result = KMP_SNPRINTF(pos, end - pos + 1, "%0*lld", width, id);
#else
snp_result = KMP_SNPRINTF(pos, end - pos + 1, "%0*d", width, id);
More information about the Openmp-commits
mailing list