diff options
Diffstat (limited to 'openmp/tools/archer/tests/reduction/parallel-reduction.c')
-rw-r--r-- | openmp/tools/archer/tests/reduction/parallel-reduction.c | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/openmp/tools/archer/tests/reduction/parallel-reduction.c b/openmp/tools/archer/tests/reduction/parallel-reduction.c new file mode 100644 index 00000000000..375c7fa06b0 --- /dev/null +++ b/openmp/tools/archer/tests/reduction/parallel-reduction.c @@ -0,0 +1,34 @@ +/* + * parallel-reduction.c -- Archer testcase + */ + +//===----------------------------------------------------------------------===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// +// See tools/archer/LICENSE.txt for details. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// + + +// RUN: %libarcher-compile-and-run| FileCheck %s +#include <omp.h> +#include <stdio.h> + +int main(int argc, char *argv[]) { + int var = 0; + +// Number of threads is empirical: We need enough threads so that +// the reduction is really performed hierarchically in the barrier! +#pragma omp parallel num_threads(5) reduction(+ : var) + { var = 1; } + + fprintf(stderr, "DONE\n"); + int error = (var != 5); + return error; +} + +// CHECK-NOT: ThreadSanitizer: data race +// CHECK-NOT: ThreadSanitizer: reported +// CHECK: DONE |