/* { dg-do compile } */ /* { dg-options "-fopenmp-simd" } */ #pragma omp declare simd linear(a:1 + b) uniform(b) /* { dg-error ".linear. clause step .b \\+ 1. is neither constant nor a parameter" } */ int f1 (int a, int b); #pragma omp declare simd linear(a:b + 1) uniform(b) /* { dg-error ".linear. clause step .b \\+ 1. is neither constant nor a parameter" } */ int f2 (int a, int b); #pragma omp declare simd linear(a:2 * b) uniform(b) /* { dg-error ".linear. clause step .b \\* 2. is neither constant nor a parameter" } */ int f3 (int a, int b); #pragma omp declare simd linear(a:b) /* { dg-error ".linear. clause step is a parameter .b. not specified in .uniform. clause" } */ int f4 (int a, int b); #pragma omp declare simd linear(a:b) linear(b:1) /* { dg-error ".linear. clause step is a parameter .b. not specified in .uniform. clause" } */ int f5 (int a, int b); #pragma omp declare simd linear(a:5 + 2 * 3) int f6 (int a, int b); const int c = 5; #pragma omp declare simd linear(a:c) /* { dg-error ".linear. clause step .c. is neither constant nor a parameter" } */ int f7 (int a, int b); #pragma omp declare simd linear(a:2 * c + 1) /* { dg-error ".linear. clause step .\[^\n\r]*. is neither constant nor a parameter" } */ int f8 (int a, int b); #pragma omp declare simd linear(a:0.5) /* { dg-error ".linear. clause step expression must be integral" } */ int f9 (int a, int b);