xref: /minix3/external/bsd/llvm/dist/clang/test/OpenMP/simd_safelen_messages.cpp (revision 0a6a1f1d05b60e214de2f05a7310ddd1f0e590e7)
1*0a6a1f1dSLionel Sambuc // RUN: %clang_cc1 -verify -fopenmp=libiomp5 %s
2*0a6a1f1dSLionel Sambuc 
foo()3*0a6a1f1dSLionel Sambuc void foo() {
4*0a6a1f1dSLionel Sambuc }
5*0a6a1f1dSLionel Sambuc 
foobool(int argc)6*0a6a1f1dSLionel Sambuc bool foobool(int argc) {
7*0a6a1f1dSLionel Sambuc   return argc;
8*0a6a1f1dSLionel Sambuc }
9*0a6a1f1dSLionel Sambuc 
10*0a6a1f1dSLionel Sambuc struct S1; // expected-note {{declared here}}
11*0a6a1f1dSLionel Sambuc 
12*0a6a1f1dSLionel Sambuc template <class T, typename S, int N, int ST> // expected-note {{declared here}}
tmain(T argc,S ** argv)13*0a6a1f1dSLionel Sambuc T tmain(T argc, S **argv) { //expected-note 2 {{declared here}}
14*0a6a1f1dSLionel Sambuc   #pragma omp simd safelen // expected-error {{expected '(' after 'safelen'}}
15*0a6a1f1dSLionel Sambuc   for (int i = ST; i < N; i++) argv[0][i] = argv[0][i] - argv[0][i-ST];
16*0a6a1f1dSLionel Sambuc   #pragma omp simd safelen ( // expected-error {{expected expression}} expected-error {{expected ')'}} expected-note {{to match this '('}}
17*0a6a1f1dSLionel Sambuc   for (int i = ST; i < N; i++) argv[0][i] = argv[0][i] - argv[0][i-ST];
18*0a6a1f1dSLionel Sambuc   #pragma omp simd safelen () // expected-error {{expected expression}}
19*0a6a1f1dSLionel Sambuc   for (int i = ST; i < N; i++) argv[0][i] = argv[0][i] - argv[0][i-ST];
20*0a6a1f1dSLionel Sambuc   // expected-error@+3 {{expected ')'}} expected-note@+3 {{to match this '('}}
21*0a6a1f1dSLionel Sambuc   // expected-error@+2 2 {{expression is not an integral constant expression}}
22*0a6a1f1dSLionel Sambuc   // expected-note@+1 2 {{read of non-const variable 'argc' is not allowed in a constant expression}}
23*0a6a1f1dSLionel Sambuc   #pragma omp simd safelen (argc
24*0a6a1f1dSLionel Sambuc   for (int i = ST; i < N; i++) argv[0][i] = argv[0][i] - argv[0][i-ST];
25*0a6a1f1dSLionel Sambuc   // expected-error@+1 {{argument to 'safelen' clause must be a positive integer value}}
26*0a6a1f1dSLionel Sambuc   #pragma omp simd safelen (ST // expected-error {{expected ')'}} expected-note {{to match this '('}}
27*0a6a1f1dSLionel Sambuc   for (int i = ST; i < N; i++) argv[0][i] = argv[0][i] - argv[0][i-ST];
28*0a6a1f1dSLionel Sambuc   #pragma omp simd safelen (1)) // expected-warning {{extra tokens at the end of '#pragma omp simd' are ignored}}
29*0a6a1f1dSLionel Sambuc   for (int i = ST; i < N; i++) argv[0][i] = argv[0][i] - argv[0][i-ST];
30*0a6a1f1dSLionel Sambuc   #pragma omp simd safelen ((ST > 0) ? 1 + ST : 2)
31*0a6a1f1dSLionel Sambuc   for (int i = ST; i < N; i++) argv[0][i] = argv[0][i] - argv[0][i-ST];
32*0a6a1f1dSLionel Sambuc   // expected-error@+3 2 {{directive '#pragma omp simd' cannot contain more than one 'safelen' clause}}
33*0a6a1f1dSLionel Sambuc   // expected-error@+2 2 {{argument to 'safelen' clause must be a positive integer value}}
34*0a6a1f1dSLionel Sambuc   // expected-error@+1 2 {{expression is not an integral constant expression}}
35*0a6a1f1dSLionel Sambuc   #pragma omp simd safelen (foobool(argc)), safelen (true), safelen (-5)
36*0a6a1f1dSLionel Sambuc   for (int i = ST; i < N; i++) argv[0][i] = argv[0][i] - argv[0][i-ST];
37*0a6a1f1dSLionel Sambuc   #pragma omp simd safelen (S) // expected-error {{'S' does not refer to a value}}
38*0a6a1f1dSLionel Sambuc   for (int i = ST; i < N; i++) argv[0][i] = argv[0][i] - argv[0][i-ST];
39*0a6a1f1dSLionel Sambuc   // expected-error@+1 2 {{expression is not an integral constant expression}}
40*0a6a1f1dSLionel Sambuc   #pragma omp simd safelen (argv[1]=2) // expected-error {{expected ')'}} expected-note {{to match this '('}}
41*0a6a1f1dSLionel Sambuc   for (int i = ST; i < N; i++) argv[0][i] = argv[0][i] - argv[0][i-ST];
42*0a6a1f1dSLionel Sambuc   #pragma omp simd safelen (4)
43*0a6a1f1dSLionel Sambuc   for (int i = ST; i < N; i++) argv[0][i] = argv[0][i] - argv[0][i-ST];
44*0a6a1f1dSLionel Sambuc   #pragma omp simd safelen (N) // expected-error {{argument to 'safelen' clause must be a positive integer value}}
45*0a6a1f1dSLionel Sambuc   for (T i = ST; i < N; i++) argv[0][i] = argv[0][i] - argv[0][i-ST];
46*0a6a1f1dSLionel Sambuc   return argc;
47*0a6a1f1dSLionel Sambuc }
48*0a6a1f1dSLionel Sambuc 
main(int argc,char ** argv)49*0a6a1f1dSLionel Sambuc int main(int argc, char **argv) {
50*0a6a1f1dSLionel Sambuc   #pragma omp simd safelen // expected-error {{expected '(' after 'safelen'}}
51*0a6a1f1dSLionel Sambuc   for (int i = 4; i < 12; i++) argv[0][i] = argv[0][i] - argv[0][i-4];
52*0a6a1f1dSLionel Sambuc   #pragma omp simd safelen ( // expected-error {{expected expression}} expected-error {{expected ')'}} expected-note {{to match this '('}}
53*0a6a1f1dSLionel Sambuc   for (int i = 4; i < 12; i++) argv[0][i] = argv[0][i] - argv[0][i-4];
54*0a6a1f1dSLionel Sambuc   #pragma omp simd safelen () // expected-error {{expected expression}}
55*0a6a1f1dSLionel Sambuc   for (int i = 4; i < 12; i++) argv[0][i] = argv[0][i] - argv[0][i-4];
56*0a6a1f1dSLionel Sambuc   #pragma omp simd safelen (4 // expected-error {{expected ')'}} expected-note {{to match this '('}}
57*0a6a1f1dSLionel Sambuc   for (int i = 4; i < 12; i++) argv[0][i] = argv[0][i] - argv[0][i-4];
58*0a6a1f1dSLionel Sambuc   #pragma omp simd safelen (2+2)) // expected-warning {{extra tokens at the end of '#pragma omp simd' are ignored}}
59*0a6a1f1dSLionel Sambuc   for (int i = 4; i < 12; i++) argv[0][i] = argv[0][i] - argv[0][i-4];
60*0a6a1f1dSLionel Sambuc   #pragma omp simd safelen (foobool(1) > 0 ? 1 : 2) // expected-error {{expression is not an integral constant expression}}
61*0a6a1f1dSLionel Sambuc   for (int i = 4; i < 12; i++) argv[0][i] = argv[0][i] - argv[0][i-4];
62*0a6a1f1dSLionel Sambuc   // expected-error@+3 {{expression is not an integral constant expression}}
63*0a6a1f1dSLionel Sambuc   // expected-error@+2 2 {{directive '#pragma omp simd' cannot contain more than one 'safelen' clause}}
64*0a6a1f1dSLionel Sambuc   // expected-error@+1 2 {{argument to 'safelen' clause must be a positive integer value}}
65*0a6a1f1dSLionel Sambuc   #pragma omp simd safelen (foobool(argc)), safelen (true), safelen (-5)
66*0a6a1f1dSLionel Sambuc   for (int i = 4; i < 12; i++) argv[0][i] = argv[0][i] - argv[0][i-4];
67*0a6a1f1dSLionel Sambuc   #pragma omp simd safelen (S1) // expected-error {{'S1' does not refer to a value}}
68*0a6a1f1dSLionel Sambuc   for (int i = 4; i < 12; i++) argv[0][i] = argv[0][i] - argv[0][i-4];
69*0a6a1f1dSLionel Sambuc   // expected-error@+1 {{expression is not an integral constant expression}}
70*0a6a1f1dSLionel Sambuc   #pragma omp simd safelen (argv[1]=2) // expected-error {{expected ')'}} expected-note {{to match this '('}}
71*0a6a1f1dSLionel Sambuc   for (int i = 4; i < 12; i++) argv[0][i] = argv[0][i] - argv[0][i-4];
72*0a6a1f1dSLionel Sambuc   // expected-error@+3 {{statement after '#pragma omp simd' must be a for loop}}
73*0a6a1f1dSLionel Sambuc   // expected-note@+1 {{in instantiation of function template specialization 'tmain<int, char, -1, -2>' requested here}}
74*0a6a1f1dSLionel Sambuc   #pragma omp simd safelen(safelen(tmain<int, char, -1, -2>(argc, argv) // expected-error 2 {{expected ')'}} expected-note 2 {{to match this '('}}
75*0a6a1f1dSLionel Sambuc   foo();
76*0a6a1f1dSLionel Sambuc   // expected-note@+1 {{in instantiation of function template specialization 'tmain<int, char, 12, 4>' requested here}}
77*0a6a1f1dSLionel Sambuc   return tmain<int, char, 12, 4>(argc, argv);
78*0a6a1f1dSLionel Sambuc }
79*0a6a1f1dSLionel Sambuc 
80