loop-26.c 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196
  1. /* { dg-do run } */
  2. extern void abort (void);
  3. signed char v[5][7][9][21][4][42][3];
  4. int a[84];
  5. int *volatile zero = &a[42];
  6. int *volatile two = &a[42 + 2];
  7. int *volatile three = &a[42 + 3];
  8. int *volatile five = &a[42 + 5];
  9. int *volatile seven = &a[42 + 7];
  10. int *volatile nine = &a[42 + 9];
  11. int *volatile eleven = &a[42 + 11];
  12. int *volatile minusone = &a[42 - 1];
  13. volatile int zeroi = 0, onei = 1, twoi = 2, threei = 3, fivei = 5;
  14. int
  15. main ()
  16. {
  17. for (int i = 0; i < 5; i++)
  18. for (int j = 0; j < 7; j++)
  19. for (int k = 0; k < 9; k++)
  20. for (int l = j; l < 5 + j; l++)
  21. for (int m = 7; m < 11; m++)
  22. for (int n = 0; n < l - 2; n++)
  23. for (int o = 0; o < 3; o++)
  24. v[i][j][k][l][m - 7][n][o] = 1;
  25. int niters = 0;
  26. #pragma omp parallel
  27. #pragma omp for collapse(7) reduction(+:niters)
  28. for (int i = 0; i < 5; i++)
  29. for (int *j = &a[42]; j < &a[42 + 7]; j++)
  30. for (int *k = &a[42]; k < &a[42 + 9]; k++)
  31. for (int *l = j; l < 5 + j; l++)
  32. for (int *m = &a[42 + 7]; m < &a[42 + 11]; m++)
  33. for (int *n = &a[42]; n < l - 2; n++)
  34. for (int *o = &a[42]; o < &a[42 + 3]; o++)
  35. {
  36. niters++;
  37. if (i < 0 || i >= 5
  38. || j - &a[42] < 0 || j - &a[42] >= 7
  39. || k - &a[42] < 0 || k - &a[42] >= 9
  40. || l - &a[42] < 0 || l >= j + 5
  41. || m - &a[42] < 7 || m - &a[42] >= 11
  42. || n - &a[42] < 0 || n >= l - 2
  43. || o - &a[42] < 0 || o - &a[42] >= 3)
  44. abort ();
  45. if (v[i][j - &a[42]][k - &a[42]][l - &a[42]][m - &a[42 + 7]][n - &a[42]][o - &a[42]] != 1)
  46. abort ();
  47. v[i][j - &a[42]][k - &a[42]][l - &a[42]][m - &a[42 + 7]][n - &a[42]][o - &a[42]]++;
  48. }
  49. if (niters != 58860)
  50. abort ();
  51. int niters2 = 0;
  52. #pragma omp parallel
  53. #pragma omp for collapse(7) reduction(+:niters2)
  54. for (int *i = zero; i < five; i += onei)
  55. for (int *j = seven - onei; j >= zero; j -= onei)
  56. for (int *k = nine - onei; k >= zero; k += -onei)
  57. for (int *l = j + zeroi; l < fivei + j; l += onei)
  58. for (int *m = eleven - onei; m >= seven; m -= onei)
  59. for (int *n = l - threei; n >= zero; n -= onei)
  60. for (int *o = zero; o < three; o += onei)
  61. {
  62. niters2++;
  63. if (i - &a[42] < 0 || i - &a[42] >= 5
  64. || j - &a[42] < 0 || j - &a[42] >= 7
  65. || k - &a[42] < 0 || k - &a[42] >= 9
  66. || l < j || l >= j + 5
  67. || m - &a[42] < 7 || m - &a[42] >= 11
  68. || n - &a[42] < 0 || n >= l - 2
  69. || o - &a[42] < 0 || o - &a[42] >= 3)
  70. abort ();
  71. if (v[i - &a[42]][j - &a[42]][k - &a[42]][l - &a[42]][m - &a[42 + 7]][n - &a[42]][o - &a[42]] != 2)
  72. abort ();
  73. v[i - &a[42]][j - &a[42]][k - &a[42]][l - &a[42]][m - &a[42 + 7]][n - &a[42]][o - &a[42]]++;
  74. }
  75. if (niters2 != 58860)
  76. abort ();
  77. for (int i = 0; i < 5; i++)
  78. for (int j = 0; j < 7; j++)
  79. for (int k = 0; k < 9; k++)
  80. for (int l = j; l < 5 + j; l++)
  81. for (int m = 7; m < 11; m++)
  82. for (int n = 0; n < l - 2; n++)
  83. for (int o = 0; o < 3; o++)
  84. if (v[i][j][k][l][m - 7][n][o] != 3)
  85. abort ();
  86. int niters3 = 0;
  87. #pragma omp parallel
  88. #pragma omp for collapse(5) reduction(+:niters3)
  89. for (int *i = &a[42 + 4]; i >= &a[42 + 0]; i--)
  90. for (int *j = &a[42 + 6]; j >= &a[42 + 0]; --j)
  91. for (int *l = j + 4; l >= j; l--)
  92. for (int *n = l - 3; n >= &a[42]; --n)
  93. for (int *o = &a[42 + 2]; o >= &a[42 + 0]; o--)
  94. {
  95. niters3++;
  96. if (i - &a[42] < 0 || i - &a[42] >= 5
  97. || j - &a[42] < 0 || j - &a[42] >= 7
  98. || l < j || l >= j + 5
  99. || n - &a[42] < 0 || n >= l - 2
  100. || o - &a[42] < 0 || o - &a[42] >= 3)
  101. abort ();
  102. if (v[i - &a[42]][j - &a[42]][0][l - &a[42]][0][n - &a[42]][o - &a[42]] != 3)
  103. abort ();
  104. v[i - &a[42]][j - &a[42]][0][l - &a[42]][0][n - &a[42]][o - &a[42]]++;
  105. }
  106. if (niters3 != 1635)
  107. abort ();
  108. int niters4 = 0;
  109. #pragma omp parallel
  110. #pragma omp for collapse(5) reduction(+:niters4)
  111. for (int *i = zero; i < five; i += onei)
  112. for (int *j = zero; j <= seven - onei; j += onei)
  113. for (int *l = zeroi + j; l < j + fivei; l += onei)
  114. for (int *n = zero; n <= l - threei; n += onei)
  115. for (int o = zeroi; o < threei; o += onei)
  116. {
  117. niters4++;
  118. if (i - &a[42] < 0 || i - &a[42] >= 5
  119. || j - &a[42] < 0 || j - &a[42] >= 7
  120. || l < j || l >= j + 5
  121. || n - &a[42] < 0 || n >= l - 2
  122. || o < 0 || o >= 3)
  123. abort ();
  124. if (v[i - &a[42]][j - &a[42]][0][l - &a[42]][0][n - &a[42]][o] != 4)
  125. abort ();
  126. v[i - &a[42]][j - &a[42]][0][l - &a[42]][0][n - &a[42]][o]++;
  127. }
  128. if (niters4 != 1635)
  129. abort ();
  130. for (int i = 0; i < 5; i++)
  131. for (int j = 0; j < 7; j++)
  132. for (int l = j; l < j + 5; l++)
  133. for (int n = 0; n < l - 2; n++)
  134. for (int o = 0; o < 3; o++)
  135. if (v[i][j][0][l][0][n][o] != 5)
  136. abort ();
  137. int niters5 = 0;
  138. #pragma omp parallel
  139. #pragma omp for collapse(3) reduction(+:niters5)
  140. for (int *j = &a[42 + 6]; j >= &a[42]; --j)
  141. for (int *l = j + 0; l <= j + 4; l++)
  142. for (int *n = l - 3; n > &a[42 - 1]; --n)
  143. {
  144. niters5++;
  145. if (j - &a[42] < 0 || j - &a[42] >= 7
  146. || l < j || l >= j + 5
  147. || n < &a[42] || n >= l - 2)
  148. abort ();
  149. if (v[0][j - &a[42]][0][l - &a[42]][0][n - &a[42]][0] != 5)
  150. abort ();
  151. v[0][j - &a[42]][0][l - &a[42]][0][n - &a[42]][0]++;
  152. }
  153. if (niters5 != 109)
  154. abort ();
  155. int niters6 = 0;
  156. #pragma omp parallel
  157. #pragma omp for collapse(3) reduction(+:niters6)
  158. for (int *j = seven - onei; j > minusone; j -= onei)
  159. for (int *l = j + threei + onei; l >= j; l += -onei)
  160. for (int *n = l - threei; n > minusone; n -= onei)
  161. {
  162. niters6++;
  163. if (j - &a[42] < 0 || j - &a[42] >= 7
  164. || l < j || l >= j + 5
  165. || n < &a[42] || n >= l - 2)
  166. abort ();
  167. if (v[0][j - &a[42]][0][l - &a[42]][0][n - &a[42]][0] != 6)
  168. abort ();
  169. v[0][j - &a[42]][0][l - &a[42]][0][n - &a[42]][0]++;
  170. }
  171. if (niters6 != 109)
  172. abort ();
  173. for (int j = 0; j < 7; j++)
  174. for (int l = j; l < j + 5; l++)
  175. for (int n = 0; n < l - 2; n++)
  176. if (v[0][j][0][l][0][n][0] != 7)
  177. abort ();
  178. return 0;
  179. }