a.36.1.c 493 B

12345678910111213141516171819202122232425262728293031
  1. /* { dg-do run } */
  2. #include <omp.h>
  3. #include <stdlib.h>
  4. void
  5. do_by_16 (float *x, int iam, int ipoints)
  6. {
  7. }
  8. void
  9. a36 (float *x, int npoints)
  10. {
  11. int iam, ipoints;
  12. omp_set_dynamic (0);
  13. omp_set_num_threads (16);
  14. #pragma omp parallel shared(x, npoints) private(iam, ipoints)
  15. {
  16. if (omp_get_num_threads () != 16)
  17. abort ();
  18. iam = omp_get_thread_num ();
  19. ipoints = npoints / 16;
  20. do_by_16 (x, iam, ipoints);
  21. }
  22. }
  23. int main()
  24. {
  25. float a[10];
  26. a36 (a, 10);
  27. return 0;
  28. }