pr30494.c 1.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. /* PR middle-end/30494 */
  2. /* { dg-do run } */
  3. #include <omp.h>
  4. int errors;
  5. int
  6. check (int m, int i, int *v, int *w)
  7. {
  8. int j;
  9. int n = omp_get_thread_num ();
  10. for (j = 0; j < m; j++)
  11. if (v[j] != j + n)
  12. #pragma omp atomic
  13. errors += 1;
  14. for (j = 0; j < m * 3 + i; j++)
  15. if (w[j] != j + 10 + n)
  16. #pragma omp atomic
  17. errors += 1;
  18. }
  19. int
  20. foo (int n, int m)
  21. {
  22. int i;
  23. #pragma omp for
  24. for (i = 0; i < 6; i++)
  25. {
  26. int v[n], w[n * 3 + i], j;
  27. for (j = 0; j < n; j++)
  28. v[j] = j + omp_get_thread_num ();
  29. for (j = 0; j < n * 3 + i; j++)
  30. w[j] = j + 10 + omp_get_thread_num ();
  31. check (m, i, v, w);
  32. }
  33. return 0;
  34. }
  35. int
  36. bar (int n, int m)
  37. {
  38. int i;
  39. #pragma omp parallel for num_threads (4)
  40. for (i = 0; i < 6; i++)
  41. {
  42. int v[n], w[n * 3 + i], j;
  43. for (j = 0; j < n; j++)
  44. v[j] = j + omp_get_thread_num ();
  45. for (j = 0; j < n * 3 + i; j++)
  46. w[j] = j + 10 + omp_get_thread_num ();
  47. check (m, i, v, w);
  48. }
  49. return 0;
  50. }
  51. int
  52. main (void)
  53. {
  54. #pragma omp parallel num_threads (3)
  55. foo (128, 128);
  56. bar (256, 256);
  57. return 0;
  58. }