aboutsummaryrefslogtreecommitdiff
path: root/libgomp
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2022-02-08 09:30:17 +0100
committerJakub Jelinek <jakub@redhat.com>2022-05-10 10:14:32 +0200
commitae536532103c0cd1116865dbca5cc02ba4ccca12 (patch)
treed05399cabf627dfbe492d44be06aa6bc642149e1 /libgomp
parentfb1792e4c96cf0e969d5fde2a857da3fb4b2a5aa (diff)
downloadgcc-ae536532103c0cd1116865dbca5cc02ba4ccca12.zip
gcc-ae536532103c0cd1116865dbca5cc02ba4ccca12.tar.gz
gcc-ae536532103c0cd1116865dbca5cc02ba4ccca12.tar.bz2
libgomp: Fix segfault with posthumous orphan tasks [PR104385]
The following patch fixes crashes with posthumous orphan tasks. When a parent task finishes, gomp_clear_parent clears the parent pointers of its children tasks present in the parent->children_queue. But children that are still waiting for dependencies aren't in that queue yet, they will be added there only when the sibling they are waiting for exits. Unfortunately we were adding those tasks into the queues with the original task->parent which then causes crashes because that task is gone and freed. The following patch fixes that by clearing the parent field when we schedule such task for running by adding it into the queues and we know that the sibling task which is about to finish has NULL parent. 2022-02-08 Jakub Jelinek <jakub@redhat.com> PR libgomp/104385 * task.c (gomp_task_run_post_handle_dependers): If parent is NULL, clear task->parent. * testsuite/libgomp.c/pr104385.c: New test. (cherry picked from commit 0af7ef050aed9f678d70d79931ede38374fde863)
Diffstat (limited to 'libgomp')
-rw-r--r--libgomp/task.c2
-rw-r--r--libgomp/testsuite/libgomp.c/pr104385.c26
2 files changed, 28 insertions, 0 deletions
diff --git a/libgomp/task.c b/libgomp/task.c
index a95067c..dc64b9a 100644
--- a/libgomp/task.c
+++ b/libgomp/task.c
@@ -1188,6 +1188,8 @@ gomp_task_run_post_handle_dependers (struct gomp_task *child_task,
}
}
}
+ else
+ task->parent = NULL;
if (taskgroup)
{
priority_queue_insert (PQ_TASKGROUP, &taskgroup->taskgroup_queue,
diff --git a/libgomp/testsuite/libgomp.c/pr104385.c b/libgomp/testsuite/libgomp.c/pr104385.c
new file mode 100644
index 0000000..07495e6
--- /dev/null
+++ b/libgomp/testsuite/libgomp.c/pr104385.c
@@ -0,0 +1,26 @@
+/* PR libgomp/104385 */
+
+#include <unistd.h>
+
+int
+main ()
+{
+ int j = 0;
+ #pragma omp parallel shared(j) num_threads(2)
+ {
+ #pragma omp barrier
+ #pragma omp master
+ #pragma omp task shared(j)
+ {
+ #pragma omp task depend(out: j) shared(j)
+ {
+ usleep (10000);
+ j = 1;
+ }
+
+ #pragma omp task depend(inout: j) shared(j)
+ j += 1;
+ }
+ }
+ return j - 2;
+}