summaryrefslogtreecommitdiff
path: root/gcc/testsuite/c-c++-common/gomp/loop-transforms/unroll-2.c
blob: 8f7c3088a2e0cd467459a72b0b78791e3d10ecd1 (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
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
/* { dg-prune-output "error: invalid controlling predicate" } */
/* { dg-additional-options "-std=c++11" { target c++} } */

extern void dummy (int);

void
test ()
{
#pragma omp unroll partial
#pragma omp unroll full /* { dg-error {'full' clause is invalid here; turns loop into non-loop} } */
  for (int i = -300; i != 100; ++i)
    dummy (i);

#pragma omp for
#pragma omp unroll full /* { dg-error {'full' clause is invalid here; turns loop into non-loop} } */
#pragma omp unroll partial
  for (int i = -300; i != 100; ++i)
    dummy (i);

#pragma omp for
#pragma omp unroll full /* { dg-error {'full' clause is invalid here; turns loop into non-loop} } */
#pragma omp unroll full /* { dg-error {'full' clause is invalid here; turns loop into non-loop} } */
  for (int i = -300; i != 100; ++i)
    dummy (i);

#pragma omp for
#pragma omp unroll partial partial /* { dg-error {too many 'partial' clauses} } */
  for (int i = -300; i != 100; ++i)
    dummy (i);

#pragma omp unroll full full /* { dg-error {too many 'full' clauses} } */
  for (int i = -300; i != 100; ++i)
    dummy (i);

#pragma omp unroll partial
#pragma omp unroll /* { dg-error {'#pragma omp unroll' without 'partial' clause is invalid here; turns loop into non-loop} } */
  for (int i = -300; i != 100; ++i)
    dummy (i);

#pragma omp for
#pragma omp unroll /* { dg-error {'#pragma omp unroll' without 'partial' clause is invalid here; turns loop into non-loop} } */
  for (int i = -300; i != 100; ++i)
    dummy (i);

  int i;
#pragma omp for
#pragma omp unroll( /* { dg-error {expected '#pragma omp' clause before '\(' token} } */
  /* { dg-error {'#pragma omp unroll' without 'partial' clause is invalid here; turns loop into non-loop} "" { target *-*-* } .-1 } */
  for (int i = -300; i != 100; ++i)
    dummy (i);

#pragma omp for
#pragma omp unroll foo /* { dg-error {expected '#pragma omp' clause before 'foo'} } */
  /* { dg-error {'#pragma omp unroll' without 'partial' clause is invalid here; turns loop into non-loop} "" { target *-*-* } .-1 } */
  for (int i = -300; i != 100; ++i)
    dummy (i);

#pragma omp unroll partial( /* { dg-error {expected expression before end of line} "" { target c } } */
  /* { dg-error {expected primary-expression before end of line} "" { target c++ } .-1 } */
  for (int i = -300; i != 100; ++i)
    dummy (i);

#pragma omp unroll partial() /* { dg-error {expected expression before '\)' token} "" { target c } } */
  /* { dg-error {expected primary-expression before '\)' token} "" { target c++ } .-1 } */
  for (int i = -300; i != 100; ++i)
    dummy (i);

#pragma omp unroll partial(i)
 /* { dg-error {the value of 'i' is not usable in a constant expression} "" { target c++ } .-1 } */
 /* { dg-error {partial argument needs positive constant integer expression} "" { target c } .-2 } */
  for (int i = -300; i != 100; ++i)
    dummy (i);

#pragma omp unroll parti /* { dg-error {expected '#pragma omp' clause before 'parti'} } */
  for (int i = -300; i != 100; ++i)
    dummy (i);

#pragma omp for
#pragma omp unroll partial(1)
#pragma omp unroll parti /* { dg-error {expected '#pragma omp' clause before 'parti'} } */
  /* { dg-error {'#pragma omp unroll' without 'partial' clause is invalid here; turns loop into non-loop} "" { target *-*-* } .-1 } */
  for (int i = -300; i != 100; ++i)
    dummy (i);

#pragma omp for
#pragma omp unroll partial(1)
#pragma omp unroll parti /* { dg-error {expected '#pragma omp' clause before 'parti'} } */
  /* { dg-error {'#pragma omp unroll' without 'partial' clause is invalid here; turns loop into non-loop} "" { target *-*-* } .-1 } */
  for (int i = -300; i != 100; ++i)
    dummy (i);

int sum = 0;
#pragma omp parallel for reduction(+ : sum) collapse(2) /* { dg-error {collapse cannot be larger than 1 on an unrolled loop} "" { target c } } */
#pragma omp unroll partial(1) /* { dg-error {collapse cannot be larger than 1 on an unrolled loop} "" { target c++ } } */
  for (int i = 3; i < 10; ++i)
    for (int j = -2; j < 7; ++j)
      sum++;
}