1.23
2.0
main
test-branch
| Line | |
|---|
| 1 | /*
|
|---|
| 2 | !!!~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~!!!
|
|---|
| 3 | !!! Copyright (c) 2017-20, Lawrence Livermore National Security, LLC
|
|---|
| 4 | !!! and DataRaceBench project contributors. See the DataRaceBench/COPYRIGHT file for details.
|
|---|
| 5 | !!!
|
|---|
| 6 | !!! SPDX-License-Identifier: (BSD-3-Clause)
|
|---|
| 7 | !!!~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~!!!
|
|---|
| 8 | */
|
|---|
| 9 |
|
|---|
| 10 | /*
|
|---|
| 11 | The barrier construct specifies an explicit barrier at the point at which the construct appears.
|
|---|
| 12 | Barrier construct at line:27 ensures that there is no data race.
|
|---|
| 13 | */
|
|---|
| 14 |
|
|---|
| 15 | #include <omp.h>
|
|---|
| 16 | #include <stdio.h>
|
|---|
| 17 |
|
|---|
| 18 | int main(int argc, char* argv[])
|
|---|
| 19 | {
|
|---|
| 20 | int var = 0;
|
|---|
| 21 |
|
|---|
| 22 | #pragma omp parallel shared(var)
|
|---|
| 23 | {
|
|---|
| 24 | #pragma omp single
|
|---|
| 25 | var++;
|
|---|
| 26 |
|
|---|
| 27 | #pragma omp barrier
|
|---|
| 28 |
|
|---|
| 29 | #pragma omp single
|
|---|
| 30 | var++;
|
|---|
| 31 | }
|
|---|
| 32 |
|
|---|
| 33 | if(var != 2) printf("%d\n",var);
|
|---|
| 34 | int error = (var != 2);
|
|---|
| 35 | return error;
|
|---|
| 36 | }
|
|---|
Note:
See
TracBrowser
for help on using the repository browser.