OSDN Git Service

* gcse.c (gcse_main): Do jump bypassing in CPROP2.
[pf3gnuchains/gcc-fork.git] / libgomp / testsuite / libgomp.c++ / ctor-4.C
1 // { dg-do run }
2
3 #include <omp.h>
4 #include <assert.h>
5
6 struct B
7 {
8   static int ccount;
9   static int dcount;
10   static int ecount;
11   static B *e_inner;
12   static B *e_outer;
13
14   B();
15   B(int);
16   B(const B &);
17   ~B();
18   B& operator=(const B &);
19   void doit();
20 };
21
22 int B::ccount;
23 int B::dcount;
24 int B::ecount;
25 B * B::e_inner;
26 B * B::e_outer;
27
28 B::B(int)
29 {
30   e_outer = this;
31 }
32
33 B::B(const B &b)
34 {
35   assert (&b == e_outer);
36   #pragma omp atomic 
37     ccount++;
38 }
39
40 B::~B()
41 {
42   #pragma omp atomic
43     dcount++;
44 }
45
46 B& B::operator= (const B &b)
47 {
48   assert (&b == e_inner);
49   assert (this == e_outer);
50   #pragma omp atomic
51     ecount++;
52   return *this;
53 }
54
55 void B::doit()
56 {
57   #pragma omp critical
58     {
59       assert (e_inner == 0);
60       e_inner = this;
61     }
62 }
63
64 static int nthreads;
65
66 void foo()
67 {
68   B b(0);
69
70   #pragma omp parallel sections firstprivate(b) lastprivate(b)
71     {
72     #pragma omp section
73       nthreads = omp_get_num_threads ();
74     #pragma omp section
75       b.doit ();
76     }
77 }
78
79 int main()
80 {
81   omp_set_dynamic (0);
82   omp_set_num_threads (4);
83   foo();
84
85   assert (B::ecount == 1);
86   assert (B::ccount == nthreads);
87   assert (B::dcount == nthreads+1);
88
89   return 0;
90 }