<table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Issue</th>
<td>
<a href=https://github.com/llvm/llvm-project/issues/57522>57522</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>
Taskgroup task_reduction with target in_reduction segfaults
</td>
</tr>
<tr>
<th>Labels</th>
<td>
</td>
</tr>
<tr>
<th>Assignees</th>
<td>
</td>
</tr>
<tr>
<th>Reporter</th>
<td>
tomdeakin
</td>
</tr>
</table>
<pre>
The following code segfaults at the end of the taskgroup when waiting for all tasks. If I remove nowait on the target tasks, the segfault goes away, which suggests the synchronisation at the end of the taskgroup construct is failing.
Tested with LLVM at commit 9ad0ace2, built for `-fopenmp-targets=nvtpx64` on a node with four A100 GPUs.
```cpp
#include <stdio.h>
#include <stdlib.h>
#include <assert.h>
#include <math.h>
#include <omp.h>
int main(void) {
int N = 1000000;
double *A, *B;
A = malloc(N*sizeof(double));
B = malloc(N*sizeof(double));
double sum = 0.0;
for (int i = 0; i < N; ++i) {
A[i] = 1.5;
B[i] = 2.0;
}
int num_devices = omp_get_num_devices();
printf("Num devices: %d\n", num_devices);
assert (N % num_devices == 0);
int len = N / num_devices;
#pragma omp taskgroup task_reduction(+:sum)
{
for (int dev = 0; dev < num_devices; ++dev) {
int start = dev * len;
int end = start + len;
#pragma omp target map(to: A[start:len], B[start:len]) device(dev) in_reduction(+:sum) nowait
{
#pragma omp loop
for (int i = start; i < end; ++i) {
sum += A[i] * B[i];
}
}
}
}
assert(fabs(sum - (3.0*N)) < 1.0E-10);
printf("Success\n");
}
```
Some preliminary discussion occurred on [Discourse](https://discourse.llvm.org/t/taskgroup-task-reduction-with-target-in-reduction-segfaults/64683)
</pre>
<img width="1px" height="1px" alt="" src="http://email.email.llvm.org/o/eJyVVluvozYQ_jXkxQoiJiTkgYdcdquVtlGlPe3rkQED7hqMsEl6-us7YyAxyclKRSSxPRd_882MnVTlH8lbxUmhpFRX0ZQkUzknmpcF66XRhBliQM6bnKjCDg3TP8tO9S25VrwhVyYM2hWqI0xKK9Y--VaQb6Tjtbpw0ihUIqoZ7buSm0HPo0e7Nu1HSsVhzyv7QMm1EllFdF-WXAMUq_jRZFWnGqGZEeDwV_Ay1WjT9ZkhQpOCCQkwfS84ecF--H4DtzwnV2Eq8v37X7-jt0zVNWDdsTxgGacII-0FIMP4vE2wLFTLm7pdDmFoLzw1F9P-s1mDEENkEC4waJ0Wqu_IfhUE5Lc__tTT3ptgeLO2HVdoKJpM9mDmhUdtcqH8ygu_vJBKkb4UM615Z16Ka2YqV_iJiqrbJw3RGFIz0Xg0viiRe3RHvO3B1SAEdc7g4EQgXny88DDJctWnErzT_R4Jhd-DI91bqxqKR2WwwxnEWvzLVQGTwRI2xPducvi_Jg9IdF9bD4EfPKnYRNMY4xGDEqjY4ZGccejRA7xixgKBZ-9FsBqdBhL8yMELiF0h9V12vO3pNnTIbPr6PecXkUFHoBEk5h0q7t1ZB5hzXtoOLAu7TM8Q46QXAsc0yr3oCDm0RT3z4roYKggZOKPNI4yBkJkFgpVwEqAIbb7OnD_SC9XWdqysGQbkdCuO3jueQ79CY9sQoEj2kCnc7UaVQ6mTKNjsnqphcnxAMaYNFp4SN4SgoaON9WId0D0GNcvhoIdnDWqN-vQw13PVH2O1B1_NWkBtFCYFS8b6gQl6iU6Ym8Mnq7sxl1jgQwiieUnXeOLOoMwDfsQmlWrn8qc2GBFNrQA0_KoZ3Md2G8I7OT0C_E498UDyrCOepm63TMN57QLqgqXYHLjxEqMIoeHo_jwcChb-yg--LFfBZ2eE20Q_-gzKR98a51H7DmE61V3pD1VzcMelqEXDug-SC531WuPNpbKs7yCBeGcADyeQwG2huc12XBnTYttCN8GbT0Jfykvtq66ERYOfqX2WOFre6mGJ1894RS1F4whuNztYb9abOISYFjxZbTZ0tVpFm3CRJ2G-C3dsYYSRPHl70aHDDTfWtFuL9z8Pi76TyTySEoz61IdbFiYYzPizbDv1N88wJqF1j4fS12gbUbqokmjLeMHjdZqGjHHAvI3igMbRjq7zrIi3C8lSLnUCLAJ5C5HQgNJgF8An3FHqb_NNkMabbbZdxzyMV9464HCbyRuZiy6xGNK-1CCUAv5t3IVQVKJsOJ_8s95UqkuMqnPOfopmYQEnFu1_ccGzSw">