summaryrefslogtreecommitdiff
path: root/libgomp/testsuite/libgomp.c/pr42942.c
blob: 5d57852450ad329fc2e38b6ce9c3778129f24858 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
/* PR libgomp/42942 */
/* { dg-do run } */

#include <omp.h>
#include <stdlib.h>

int
main (void)
{
  int e = 0;
  omp_set_dynamic (0);
  omp_set_nested (1);
  omp_set_max_active_levels (1);
  if (omp_get_max_active_levels () != 1)
    abort ();
#pragma omp parallel num_threads(2) reduction(|:e)
  if (!omp_in_parallel ()
      || omp_get_num_threads () != 2)
    e = 1;
  else
#pragma omp parallel num_threads(2) reduction(|:e)
    if (!omp_in_parallel ()
	|| omp_get_num_threads () != 1)
      e = 1;
  if (e)
    abort ();
  omp_set_max_active_levels (0);
  if (omp_get_max_active_levels () != 0)
    abort ();
#pragma omp parallel num_threads(2) reduction(|:e)
  if (omp_in_parallel ()
      || omp_get_num_threads () != 1)
    e = 1;
  else
#pragma omp parallel num_threads(2) reduction(|:e)
    if (omp_in_parallel ()
	|| omp_get_num_threads () != 1)
      e = 1;
  if (e)
    abort ();
  omp_set_max_active_levels (2);
  if (omp_get_max_active_levels () != 2)
    abort ();
#pragma omp parallel num_threads(2) reduction(|:e)
  if (!omp_in_parallel ()
      || omp_get_num_threads () != 2)
    e = 1;
  else
#pragma omp parallel num_threads(2) reduction(|:e)
    if (!omp_in_parallel ()
	|| omp_get_num_threads () != 2)
      e = 1;
    else
#pragma omp parallel num_threads(2) reduction(|:e)
      if (!omp_in_parallel ()
	  || omp_get_num_threads () != 1)
	e = 1;
  if (e)
    abort ();
  return 0;
}