/* { dg-do compile } */ /* { dg-options "-fopenmp" } */ int i, j; void f1 (void) { #pragma omp for linear (i:1) /* { dg-error "iteration variable .i. should not be linear" } */ for (i = 0; i < 32; i++) ; } void f2 (void) { #pragma omp distribute parallel for linear (i:1) /* { dg-error ".linear. is not valid for .#pragma omp distribute parallel for." } */ for (i = 0; i < 32; i++) ; } void f3 (void) { #pragma omp parallel for linear (i:1) collapse(1) /* { dg-error "iteration variable .i. should not be linear" } */ for (i = 0; i < 32; i++) ; } void f4 (void) { #pragma omp for linear (i:1) linear (j:2) collapse(2) /* { dg-error "iteration variable .i. should not be linear" } */ for (i = 0; i < 32; i++) /* { dg-error "iteration variable .j. should not be linear" "" { target *-*-* } 33 } */ for (j = 0; j < 32; j+=2) ; } void f5 (void) { #pragma omp target teams distribute parallel for linear (i:1) linear (j:2) collapse(2) /* { dg-error ".linear. is not valid for .#pragma omp target teams distribute parallel for." } */ for (i = 0; i < 32; i++) for (j = 0; j < 32; j+=2) ; } void f6 (void) { #pragma omp parallel for linear (i:1) collapse(2) linear (j:2) /* { dg-error "iteration variable .i. should not be linear" } */ for (i = 0; i < 32; i++) /* { dg-error "iteration variable .j. should not be linear" "" { target *-*-* } 51 } */ for (j = 0; j < 32; j+=2) ; } #pragma omp declare target to (i, j, f2)