| /* { dg-do run } */ |
| /* { dg-set-target-env-var OMP_CANCELLATION "true" } */ |
| |
| #include <stdlib.h> |
| #include <unistd.h> |
| #include <omp.h> |
| |
| int |
| main () |
| { |
| int i; |
| #pragma omp parallel |
| { |
| int c = 0; |
| #pragma omp barrier |
| #pragma omp master taskloop num_tasks (25) firstprivate (c) |
| for (i = 0; i < 50; i++) |
| { |
| if (c && omp_get_cancellation ()) |
| abort (); |
| #pragma omp cancellation point taskgroup |
| usleep (30); |
| if (i > 10) |
| c = 1; |
| #pragma omp cancel taskgroup if (i > 10) |
| if (i > 10 && omp_get_cancellation ()) |
| abort (); |
| } |
| usleep (10); |
| } |
| return 0; |
| } |