[Openmp-commits] [PATCH] D151138: [OpenMP] Insert missing variable update inside loop
Jonathan Peyton via Phabricator via Openmp-commits
openmp-commits at lists.llvm.org
Mon May 22 12:17:02 PDT 2023
jlpeyton created this revision.
jlpeyton added reviewers: tlwilmar, hbae, Nawrin.
jlpeyton added a project: OpenMP.
Herald added subscribers: sunshaoce, guansong, yaxunl.
Herald added a project: All.
jlpeyton requested review of this revision.
Herald added a reviewer: jdoerfert.
Herald added subscribers: jplehr, sstefan1.
A loop within task priority code did not have necessary update of `ntasks` variable which leads to hangs if two threads collide when both attempt to execute the `__kmp_atomic_compare_store()`
Fixes: https://github.com/llvm/llvm-project/issues/62867
Repository:
rG LLVM Github Monorepo
https://reviews.llvm.org/D151138
Files:
openmp/runtime/src/kmp_tasking.cpp
openmp/runtime/test/tasking/omp_task_priority3.c
Index: openmp/runtime/test/tasking/omp_task_priority3.c
===================================================================
--- /dev/null
+++ openmp/runtime/test/tasking/omp_task_priority3.c
@@ -0,0 +1,33 @@
+// RUN: %libomp-compile && env OMP_MAX_TASK_PRIORITY=42 %libomp-run
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <omp.h>
+
+int a = 0;
+
+int main(void) {
+ int i;
+ int max_task_priority = omp_get_max_task_priority();
+ if (max_task_priority != 42) {
+ fprintf(stderr,
+ "error: omp_get_max_task_priority() returned %d instead of 42\n",
+ max_task_priority);
+ exit(EXIT_FAILURE);
+ }
+
+ for (i = 0; i < 250; ++i) {
+ #pragma omp parallel
+ {
+ #pragma omp task priority(42)
+ {
+ #pragma omp atomic
+ a++;
+ }
+ }
+ }
+
+ printf("a = %d\n", a);
+
+ return EXIT_SUCCESS;
+}
Index: openmp/runtime/src/kmp_tasking.cpp
===================================================================
--- openmp/runtime/src/kmp_tasking.cpp
+++ openmp/runtime/src/kmp_tasking.cpp
@@ -3048,6 +3048,7 @@
if (__kmp_atomic_compare_store(&task_team->tt.tt_num_task_pri, ntasks,
ntasks - 1))
break;
+ ntasks = task_team->tt.tt_num_task_pri;
} while (ntasks > 0);
if (ntasks == 0) {
KA_TRACE(20, ("__kmp_get_priority_task(exit #2): T#%d No tasks to get\n",
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D151138.524426.patch
Type: text/x-patch
Size: 1387 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/openmp-commits/attachments/20230522/4b596c20/attachment.bin>
More information about the Openmp-commits
mailing list