// expected-note@+1 {{defined as threadprivate or thread local}}
#pragma omp threadprivate(sii)
staticintglobalii;
inttest_iteration_spaces(){
constintN=100;
floata[N],b[N],c[N];
intii,jj,kk;
floatfii;
doubledii;
#pragma omp target simd
for(inti=0;i<10;i+=1){
c[i]=a[i]+b[i];
}
#pragma omp target simd
for(chari=0;i<10;i++){
c[i]=a[i]+b[i];
}
#pragma omp target simd
for(chari=0;i<10;i+='\1'){
c[i]=a[i]+b[i];
}
#pragma omp target simd
for(longlongi=0;i<10;i++){
c[i]=a[i]+b[i];
}
// expected-error@+2 {{expression must have integral or unscoped enumeration type, not 'double'}}
#pragma omp target simd
for(longlongi=0;i<10;i+=1.5){
c[i]=a[i]+b[i];
}
#pragma omp target simd
for(longlongi=0;i<'z';i+=1u){
c[i]=a[i]+b[i];
}
// expected-error@+2 {{variable must be of integer or random access iterator type}}
#pragma omp target simd
for(floatfi=0;fi<10.0;fi++){
c[(int)fi]=a[(int)fi]+b[(int)fi];
}
// expected-error@+2 {{variable must be of integer or random access iterator type}}
#pragma omp target simd
for(doublefi=0;fi<10.0;fi++){
c[(int)fi]=a[(int)fi]+b[(int)fi];
}
// expected-error@+2 {{initialization clause of OpenMP for loop is not in canonical form ('var = init' or 'T var = init')}}
#pragma omp target simd
for(int&ref=ii;ref<10;ref++){
}
// expected-error@+2 {{initialization clause of OpenMP for loop is not in canonical form ('var = init' or 'T var = init')}}
#pragma omp target simd
for(inti;i<10;i++)
c[i]=a[i];
// expected-error@+2 {{initialization clause of OpenMP for loop is not in canonical form ('var = init' or 'T var = init')}}
#pragma omp target simd
for(inti=0,j=0;i<10;++i)
c[i]=a[i];
// expected-error@+2 {{initialization clause of OpenMP for loop is not in canonical form ('var = init' or 'T var = init')}}
#pragma omp target simd
for(;ii<10;++ii)
c[ii]=a[ii];
// expected-warning@+3 {{expression result unused}}
// expected-error@+2 {{initialization clause of OpenMP for loop is not in canonical form ('var = init' or 'T var = init')}}
#pragma omp target simd
for(ii+1;ii<10;++ii)
c[ii]=a[ii];
// expected-error@+2 {{initialization clause of OpenMP for loop is not in canonical form ('var = init' or 'T var = init')}}
#pragma omp target simd
for(c[ii]=0;ii<10;++ii)
c[ii]=a[ii];
// Ok to skip parenthesises.
#pragma omp target simd
for(((ii))=0;ii<10;++ii)
c[ii]=a[ii];
// expected-error@+2 {{condition of OpenMP for loop must be a relational comparison ('<', '<=', '>', or '>=') of loop variable 'i'}}
#pragma omp target simd
for(inti=0;i;i++)
c[i]=a[i];
// expected-error@+3 {{condition of OpenMP for loop must be a relational comparison ('<', '<=', '>', or '>=') of loop variable 'i'}}
// expected-error@+2 {{increment clause of OpenMP for loop must perform simple addition or subtraction on loop variable 'i'}}
#pragma omp target simd
for(inti=0;jj<kk;ii++)
c[i]=a[i];
// expected-error@+2 {{condition of OpenMP for loop must be a relational comparison ('<', '<=', '>', or '>=') of loop variable 'i'}}
#pragma omp target simd
for(inti=0;!!i;i++)
c[i]=a[i];
// expected-error@+2 {{condition of OpenMP for loop must be a relational comparison ('<', '<=', '>', or '>=') of loop variable 'i'}}
#pragma omp target simd
for(inti=0;i!=1;i++)
c[i]=a[i];
// expected-error@+2 {{condition of OpenMP for loop must be a relational comparison ('<', '<=', '>', or '>=') of loop variable 'i'}}
#pragma omp target simd
for(inti=0;;i++)
c[i]=a[i];
// Ok.
#pragma omp target simd
for(inti=11;i>10;i--)
c[i]=a[i];
// Ok.
#pragma omp target simd
for(inti=0;i<10;++i)
c[i]=a[i];
// Ok.
#pragma omp target simd
for(ii=0;ii<10;++ii)
c[ii]=a[ii];
// expected-error@+2 {{increment clause of OpenMP for loop must perform simple addition or subtraction on loop variable 'ii'}}
#pragma omp target simd
for(ii=0;ii<10;++jj)
c[ii]=a[jj];
// expected-error@+2 {{increment clause of OpenMP for loop must perform simple addition or subtraction on loop variable 'ii'}}
#pragma omp target simd
for(ii=0;ii<10;++++ii)
c[ii]=a[ii];
// Ok but undefined behavior (in general, cannot check that incr
// is really loop-invariant).
#pragma omp target simd
for(ii=0;ii<10;ii=ii+ii)
c[ii]=a[ii];
// expected-error@+2 {{expression must have integral or unscoped enumeration type, not 'float'}}
#pragma omp target simd
for(ii=0;ii<10;ii=ii+1.0f)
c[ii]=a[ii];
// Ok - step was converted to integer type.
#pragma omp target simd
for(ii=0;ii<10;ii=ii+(int)1.1f)
c[ii]=a[ii];
// expected-error@+2 {{increment clause of OpenMP for loop must perform simple addition or subtraction on loop variable 'ii'}}
#pragma omp target simd
for(ii=0;ii<10;jj=ii+2)
c[ii]=a[ii];
// expected-warning@+3 {{relational comparison result unused}}
// expected-error@+2 {{increment clause of OpenMP for loop must perform simple addition or subtraction on loop variable 'ii'}}
#pragma omp target simd
for(ii=0;ii<10;jj>kk+2)
c[ii]=a[ii];
// expected-error@+2 {{increment clause of OpenMP for loop must perform simple addition or subtraction on loop variable 'ii'}}
#pragma omp target simd
for(ii=0;ii<10;)
c[ii]=a[ii];
// expected-warning@+3 {{expression result unused}}
// expected-error@+2 {{increment clause of OpenMP for loop must perform simple addition or subtraction on loop variable 'ii'}}
#pragma omp target simd
for(ii=0;ii<10;!ii)
c[ii]=a[ii];
// expected-error@+2 {{increment clause of OpenMP for loop must perform simple addition or subtraction on loop variable 'ii'}}
#pragma omp target simd
for(ii=0;ii<10;ii?++ii:++jj)
c[ii]=a[ii];
// expected-error@+2 {{increment clause of OpenMP for loop must perform simple addition or subtraction on loop variable 'ii'}}
#pragma omp target simd
for(ii=0;ii<10;ii=ii<10)
c[ii]=a[ii];
// expected-note@+3 {{loop step is expected to be positive due to this condition}}
// expected-error@+2 {{increment expression must cause 'ii' to increase on each iteration of OpenMP for loop}}
#pragma omp target simd
for(ii=0;ii<10;ii=ii+0)
c[ii]=a[ii];
// expected-note@+3 {{loop step is expected to be positive due to this condition}}
// expected-error@+2 {{increment expression must cause 'ii' to increase on each iteration of OpenMP for loop}}
#pragma omp target simd
for(ii=0;ii<10;ii=ii+(int)(0.8-0.45))
c[ii]=a[ii];
// expected-note@+3 {{loop step is expected to be positive due to this condition}}
// expected-error@+2 {{increment expression must cause 'ii' to increase on each iteration of OpenMP for loop}}
#pragma omp target simd
for(ii=0;(ii)<10;ii-=25)
c[ii]=a[ii];
// expected-note@+3 {{loop step is expected to be positive due to this condition}}
// expected-error@+2 {{increment expression must cause 'ii' to increase on each iteration of OpenMP for loop}}
#pragma omp target simd
for(ii=0;(ii<10);ii-=0)
c[ii]=a[ii];
// expected-note@+3 {{loop step is expected to be negative due to this condition}}
// expected-error@+2 {{increment expression must cause 'ii' to decrease on each iteration of OpenMP for loop}}
#pragma omp target simd
for(ii=0;ii>10;(ii+=0))
c[ii]=a[ii];
// expected-note@+3 {{loop step is expected to be positive due to this condition}}
// expected-error@+2 {{increment expression must cause 'ii' to increase on each iteration of OpenMP for loop}}
#pragma omp target simd
for(ii=0;ii<10;(ii)=(1-1)+(ii))
c[ii]=a[ii];
// expected-note@+3 {{loop step is expected to be negative due to this condition}}
// expected-error@+2 {{increment expression must cause 'ii' to decrease on each iteration of OpenMP for loop}}
#pragma omp target simd
for((ii=0);ii>10;(ii-=0))
c[ii]=a[ii];
// expected-note@+3 {{loop step is expected to be positive due to this condition}}
// expected-error@+2 {{increment expression must cause 'ii' to increase on each iteration of OpenMP for loop}}
#pragma omp target simd
for(ii=0;(ii<10);(ii-=0))
c[ii]=a[ii];
// expected-note@+2 {{defined as firstprivate}}
// expected-error@+2 {{loop iteration variable in the associated loop of 'omp target simd' directive may not be firstprivate, predetermined as linear}}
#pragma omp target simd firstprivate(ii)
for(ii=0;ii<10;ii++)
c[ii]=a[ii];
#pragma omp target simd linear(ii)
for(ii=0;ii<10;ii++)
c[ii]=a[ii];
// expected-note@+2 {{defined as private}}
// expected-error@+2 {{loop iteration variable in the associated loop of 'omp target simd' directive may not be private, predetermined as linear}}
#pragma omp target simd private(ii)
for(ii=0;ii<10;ii++)
c[ii]=a[ii];
// expected-note@+2 {{defined as lastprivate}}
// expected-error@+2 {{loop iteration variable in the associated loop of 'omp target simd' directive may not be lastprivate, predetermined as linear}}
#pragma omp target simd lastprivate(ii)
for(ii=0;ii<10;ii++)
c[ii]=a[ii];
{
// expected-error@+2 {{loop iteration variable in the associated loop of 'omp target simd' directive may not be threadprivate or thread local, predetermined as linear}}
#pragma omp target simd
for(sii=0;sii<10;sii+=1)
c[sii]=a[sii];
}
{
#pragma omp target simd
for(globalii=0;globalii<10;globalii+=1)
c[globalii]=a[globalii];
}
{
#pragma omp target simd collapse(2)
for(ii=0;ii<10;ii+=1)
for(globalii=0;globalii<10;globalii+=1)
c[globalii]+=a[globalii]+ii;
}
// expected-error@+2 {{statement after '#pragma omp target simd' must be a for loop}}
#pragma omp target simd
for(auto&item:a){
item=item+1;
}
// expected-note@+3 {{loop step is expected to be positive due to this condition}}
// expected-error@+2 {{increment expression must cause 'i' to increase on each iteration of OpenMP for loop}}
#pragma omp target simd
for(unsignedi=9;i<10;i--){
c[i]=a[i]+b[i];
}
int(*lb)[4]=nullptr;
#pragma omp target simd
for(int(*p)[4]=lb;p<lb+8;++p){
}
// expected-warning@+2 {{initialization clause of OpenMP for loop is not in canonical form ('var = init' or 'T var = init')}}