| /* PR middle-end/49640 */ |
| /* { dg-do compile } */ |
| /* { dg-options "-O2 -std=gnu99 -fopenmp" } */ |
| |
| void |
| foo (int N, int M, int K, int P, int Q, int R, int i, int j, int k, |
| unsigned char x[P][Q][R], int y[N][M][K]) |
| { |
| int ii, jj, kk; |
| |
| #pragma omp parallel for private(ii,jj,kk) |
| for (ii = 0; ii < P; ++ii) |
| for (jj = 0; jj < Q; ++jj) |
| for (kk = 0; kk < R; ++kk) |
| y[i + ii][j + jj][k + kk] = x[ii][jj][kk]; |
| } |
| |
| void |
| bar (int N, int M, int K, int P, int Q, int R, int i, int j, int k, |
| unsigned char x[P][Q][R], float y[N][M][K], float factor, float zero) |
| { |
| int ii, jj, kk; |
| |
| #pragma omp parallel for private(ii,jj,kk) |
| for (ii = 0; ii < P; ++ii) |
| for (jj = 0; jj < Q; ++jj) |
| for (kk = 0; kk < R; ++kk) |
| y[i + ii][j + jj][k + kk] = factor * x[ii][jj][kk] + zero; |
| } |