|  | /* { dg-do compile } */ | 
|  |  | 
|  | /* This test case is expected to fail due to errors.  */ | 
|  |  | 
|  | int f1 (int depth, int iter); | 
|  | int f2 (int depth, int iter); | 
|  | void do_something (void); | 
|  |  | 
|  | void s1 (int a1, int a2, int a3) | 
|  | { | 
|  | int i, j, k; | 
|  |  | 
|  | #pragma omp for collapse(3) | 
|  | for (i = 0; i < a1; i++) | 
|  | { | 
|  | f1 (0, i); | 
|  | if (a1 < a2) | 
|  | { | 
|  | int z = 0; | 
|  | while (z < i)	/* { dg-error "loop not permitted in intervening code " } */ | 
|  | { | 
|  | do_something (); | 
|  | z++; | 
|  | } | 
|  | do		/* { dg-error "loop not permitted in intervening code " } */ | 
|  | { | 
|  | do_something (); | 
|  | z--; | 
|  | } while (z >= 0); | 
|  | } | 
|  | for (j = 0; j < a2; j++) | 
|  | { | 
|  | for (k = 0; k < a3; k++) | 
|  | { | 
|  | f1 (2, k); | 
|  | f2 (2, k); | 
|  | } | 
|  | f2 (1, j); | 
|  | } | 
|  | if (a1 < a3) | 
|  | { | 
|  | int z; | 
|  | for (z = 0; z < i; z++)	/* { dg-error "loop not permitted in intervening code " } */ | 
|  | { | 
|  | do_something (); | 
|  | } | 
|  | } | 
|  | f2 (0, i); | 
|  | } | 
|  | } |