66 lines
1.1 KiB
C
66 lines
1.1 KiB
C
/* PR middle-end/25261 */
|
|
/* { dg-do run } */
|
|
|
|
#include <omp.h>
|
|
|
|
extern void abort (void);
|
|
|
|
int
|
|
main (void)
|
|
{
|
|
int i = 5, j, l = 0;
|
|
int foo (void)
|
|
{
|
|
return i == 6;
|
|
}
|
|
int bar (void)
|
|
{
|
|
return i - 3;
|
|
}
|
|
|
|
omp_set_dynamic (0);
|
|
|
|
#pragma omp parallel if (foo ()) num_threads (2)
|
|
if (omp_get_num_threads () != 1)
|
|
#pragma omp atomic
|
|
l++;
|
|
|
|
#pragma omp parallel for schedule (static, bar ()) num_threads (2) \
|
|
reduction (|:l)
|
|
for (j = 0; j < 4; j++)
|
|
if (omp_get_thread_num () != (j >= 2))
|
|
#pragma omp atomic
|
|
l++;
|
|
|
|
i++;
|
|
|
|
#pragma omp parallel if (foo ()) num_threads (2)
|
|
if (omp_get_num_threads () != 2)
|
|
#pragma omp atomic
|
|
l++;
|
|
|
|
#pragma omp parallel for schedule (static, bar ()) num_threads (2) \
|
|
reduction (|:l)
|
|
for (j = 0; j < 6; j++)
|
|
if (omp_get_thread_num () != (j >= 3))
|
|
#pragma omp atomic
|
|
l++;
|
|
|
|
#pragma omp parallel num_threads (4) reduction (|:l)
|
|
if (!foo () || bar () != 3)
|
|
#pragma omp atomic
|
|
l++;
|
|
|
|
i++;
|
|
|
|
#pragma omp parallel num_threads (4) reduction (|:l)
|
|
if (foo () || bar () != 4)
|
|
#pragma omp atomic
|
|
l++;
|
|
|
|
if (l)
|
|
abort ();
|
|
|
|
return 0;
|
|
}
|