[Openmp-commits] [PATCH] D56103: Add lock function definitions to fix Bug 40042
Hansang Bae via Phabricator via Openmp-commits
openmp-commits at lists.llvm.org
Thu Dec 27 07:51:10 PST 2018
hbae created this revision.
hbae added reviewers: tlwilmar, jlpeyton, AndreyChurbanov.
hbae added a project: OpenMP.
This change fixes the sanity issue reported in Bug 40042 <https://bugs.llvm.org/show_bug.cgi?id=40042>.
Lock function definitions for the three lock kinds were added to disambiguate calls to the lock functions done directly and indirectly.
Repository:
rOMP OpenMP
https://reviews.llvm.org/D56103
Files:
runtime/src/kmp_lock.cpp
Index: runtime/src/kmp_lock.cpp
===================================================================
--- runtime/src/kmp_lock.cpp
+++ runtime/src/kmp_lock.cpp
@@ -2874,6 +2874,47 @@
static int __kmp_test_indirect_lock_with_checks(kmp_dyna_lock_t *lock,
kmp_int32);
+// Lock function definitions for the union parameter type
+#define KMP_FOREACH_LOCK_KIND(m, a) m(ticket, a) m(queuing, a) m(drdpa, a)
+
+#define expand1(lk, op) \
+ static void __kmp_##op##_##lk##_##lock(kmp_user_lock_p lock) { \
+ __kmp_##op##_##lk##_##lock(&lock->lk); \
+ }
+#define expand2(lk, op) \
+ static int __kmp_##op##_##lk##_##lock(kmp_user_lock_p lock, \
+ kmp_int32 gtid) { \
+ return __kmp_##op##_##lk##_##lock(&lock->lk, gtid); \
+ }
+#define expand3(lk, op) \
+ static void __kmp_set_##lk##_##lock_flags(kmp_user_lock_p lock, \
+ kmp_lock_flags_t flags) { \
+ __kmp_set_##lk##_lock_flags(&lock->lk, flags); \
+ }
+#define expand4(lk, op) \
+ static void __kmp_set_##lk##_##lock_location(kmp_user_lock_p lock, \
+ const ident_t *loc) { \
+ __kmp_set_##lk##_lock_location(&lock->lk, loc); \
+ }
+
+KMP_FOREACH_LOCK_KIND(expand1, init)
+KMP_FOREACH_LOCK_KIND(expand1, init_nested)
+KMP_FOREACH_LOCK_KIND(expand1, destroy)
+KMP_FOREACH_LOCK_KIND(expand1, destroy_nested)
+KMP_FOREACH_LOCK_KIND(expand2, acquire)
+KMP_FOREACH_LOCK_KIND(expand2, acquire_nested)
+KMP_FOREACH_LOCK_KIND(expand2, release)
+KMP_FOREACH_LOCK_KIND(expand2, release_nested)
+KMP_FOREACH_LOCK_KIND(expand2, test)
+KMP_FOREACH_LOCK_KIND(expand2, test_nested)
+KMP_FOREACH_LOCK_KIND(expand3, )
+KMP_FOREACH_LOCK_KIND(expand4, )
+
+#undef expand1
+#undef expand2
+#undef expand3
+#undef expand4
+
// Jump tables for the indirect lock functions
// Only fill in the odd entries, that avoids the need to shift out the low bit
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D56103.179553.patch
Type: text/x-patch
Size: 2404 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/openmp-commits/attachments/20181227/27a86e15/attachment.bin>
More information about the Openmp-commits
mailing list