[Openmp-commits] [PATCH] D125013: [OpenMP][libomp] Hold old __kmp_threads arrays until library shutdown
Jonathan Peyton via Phabricator via Openmp-commits
openmp-commits at lists.llvm.org
Thu May 5 07:23:32 PDT 2022
jlpeyton created this revision.
jlpeyton added reviewers: tlwilmar, hbae, AndreyChurbanov.
jlpeyton added a project: OpenMP.
Herald added subscribers: guansong, yaxunl.
Herald added a project: All.
jlpeyton requested review of this revision.
Herald added a reviewer: jdoerfert.
Herald added a subscriber: sstefan1.
When many nested teams are formed, `__kmp_threads` may be reallocated
to accommodate new threads. This reallocation causes a data
race when another existing team's thread simultaneously references
`__kmp_threads`. This patch keeps the old thread arrays around until library
shutdown so these lingering references can complete without issue and
access to `__kmp_threads` remains a simple array reference.
Fixes: https://github.com/llvm/llvm-project/issues/54708
Repository:
rG LLVM Github Monorepo
https://reviews.llvm.org/D125013
Files:
openmp/runtime/src/kmp.h
openmp/runtime/src/kmp_global.cpp
openmp/runtime/src/kmp_runtime.cpp
Index: openmp/runtime/src/kmp_runtime.cpp
===================================================================
--- openmp/runtime/src/kmp_runtime.cpp
+++ openmp/runtime/src/kmp_runtime.cpp
@@ -3669,11 +3669,16 @@
__kmp_threads_capacity * sizeof(kmp_info_t *));
KMP_MEMCPY(newRoot, __kmp_root,
__kmp_threads_capacity * sizeof(kmp_root_t *));
+ // Put old __kmp_threads array on a list. Any ongoing references to the old
+ // list will be valid. This list is cleaned up at library shutdown.
+ kmp_old_threads_list_t *node =
+ (kmp_old_threads_list_t *)__kmp_allocate(sizeof(kmp_old_threads_list_t));
+ node->threads = __kmp_threads;
+ node->next = __kmp_old_threads_list;
+ __kmp_old_threads_list = node;
- kmp_info_t **temp_threads = __kmp_threads;
*(kmp_info_t * *volatile *)&__kmp_threads = newThreads;
*(kmp_root_t * *volatile *)&__kmp_root = newRoot;
- __kmp_free(temp_threads);
added += newCapacity - __kmp_threads_capacity;
*(volatile int *)&__kmp_threads_capacity = newCapacity;
@@ -8101,6 +8106,15 @@
__kmp_root = NULL;
__kmp_threads_capacity = 0;
+ // Free old __kmp_threads arrays if they exist.
+ kmp_old_threads_list_t *ptr = __kmp_old_threads_list;
+ while (ptr) {
+ kmp_old_threads_list_t *next = ptr->next;
+ __kmp_free(ptr->threads);
+ __kmp_free(ptr);
+ ptr = next;
+ }
+
#if KMP_USE_DYNAMIC_LOCK
__kmp_cleanup_indirect_user_locks();
#else
Index: openmp/runtime/src/kmp_global.cpp
===================================================================
--- openmp/runtime/src/kmp_global.cpp
+++ openmp/runtime/src/kmp_global.cpp
@@ -441,6 +441,7 @@
KMP_ALIGN_CACHE
kmp_info_t **__kmp_threads = NULL;
kmp_root_t **__kmp_root = NULL;
+kmp_old_threads_list_t *__kmp_old_threads_list = NULL;
/* data read/written to often by primary threads */
KMP_ALIGN_CACHE
Index: openmp/runtime/src/kmp.h
===================================================================
--- openmp/runtime/src/kmp.h
+++ openmp/runtime/src/kmp.h
@@ -2989,6 +2989,15 @@
kmp_int32 data;
};
+// This list type exists to hold old __kmp_threads arrays so that
+// old references to them may complete while reallocation takes place when
+// expanding the array. The items in this list are kept alive until library
+// shutdown.
+typedef struct kmp_old_threads_list_t {
+ kmp_info_t **threads;
+ struct kmp_old_threads_list_t *next;
+} kmp_old_threads_list_t;
+
/* ------------------------------------------------------------------------ */
extern int __kmp_settings;
@@ -3269,6 +3278,8 @@
/* the following are protected by the fork/join lock */
/* write: lock read: anytime */
extern kmp_info_t **__kmp_threads; /* Descriptors for the threads */
+/* Holds old arrays of __kmp_threads until library shutdown */
+extern kmp_old_threads_list_t *__kmp_old_threads_list;
/* read/write: lock */
extern volatile kmp_team_t *__kmp_team_pool;
extern volatile kmp_info_t *__kmp_thread_pool;
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D125013.427315.patch
Type: text/x-patch
Size: 2969 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/openmp-commits/attachments/20220505/ececd56f/attachment.bin>
More information about the Openmp-commits
mailing list