summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.dg/gomp/_Atomic-2.c
blob: 159a5b3ee7d4a83a815f7ec6359b5cbb2a2ba4c0 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
/* PR c/65467 */
/* { dg-do compile } */
/* { dg-additional-options "-std=c11" } */

void
f1 (void)
{
  _Atomic int i;
  #pragma omp for		/* { dg-error "'_Atomic' iteration variable 'i'" } */
  for (i = 0; i < 64; i++)
    ;
  #pragma omp parallel for	/* { dg-error "'_Atomic' iteration variable 'i'" } */
  for (i = 0; i < 64; i++)
    ;
  #pragma omp simd		/* { dg-error "'_Atomic' iteration variable 'i'" } */
  for (i = 0; i < 64; i++)
    ;
  #pragma omp parallel for simd	/* { dg-error "'_Atomic' iteration variable 'i'" } */
  for (i = 0; i < 64; i++)
    ;
  #pragma omp for simd		/* { dg-error "'_Atomic' iteration variable 'i'" } */
  for (i = 0; i < 64; i++)
    ;
  #pragma omp for		/* { dg-error "'_Atomic' iteration variable 'j'" } */
  for (_Atomic int j = 0; j < 64; j++)
    ;
  #pragma omp parallel for	/* { dg-error "'_Atomic' iteration variable 'j'" } */
  for (_Atomic int j = 0; j < 64; j++)
    ;
  #pragma omp simd		/* { dg-error "'_Atomic' iteration variable 'j'" } */
  for (_Atomic int j = 0; j < 64; j++)
    ;
  #pragma omp parallel for simd	/* { dg-error "'_Atomic' iteration variable 'j'" } */
  for (_Atomic int j = 0; j < 64; j++)
    ;
  #pragma omp for simd		/* { dg-error "'_Atomic' iteration variable 'j'" } */
  for (_Atomic int j = 0; j < 64; j++)
    ;
}

void
f2 (void)
{
  _Atomic int i;
  #pragma omp distribute		/* { dg-error "'_Atomic' iteration variable 'i'" } */
  for (i = 0; i < 64; i++)
    ;
  #pragma omp distribute parallel for	/* { dg-error "'_Atomic' iteration variable 'i'" } */
  for (i = 0; i < 64; i++)
    ;
  #pragma omp distribute parallel for simd /* { dg-error "'_Atomic' iteration variable 'i'" } */
  for (i = 0; i < 64; i++)
    ;
  #pragma omp distribute		/* { dg-error "'_Atomic' iteration variable 'j'" } */
  for (_Atomic int j = 0; j < 64; j++)
    ;
  #pragma omp distribute parallel for	/* { dg-error "'_Atomic' iteration variable 'j'" } */
  for (_Atomic int j = 0; j < 64; j++)
    ;
  #pragma omp distribute parallel for simd /* { dg-error "'_Atomic' iteration variable 'j'" } */
  for (_Atomic int j = 0; j < 64; j++)
    ;
}

void
f3 (void)
{
  int i;
  _Atomic int j = 0;
  #pragma omp simd linear(j:2)		/* { dg-error "'_Atomic' 'j' in 'linear' clause" } */
  for (i = 0; i < 64; i++)
    j += 2;
  #pragma omp parallel for linear(j:1)	/* { dg-error "'_Atomic' 'j' in 'linear' clause" } */
  for (i = 0; i < 64; i++)
    j++;
}