68 lines
795 B
C++
68 lines
795 B
C++
|
// { dg-do run }
|
||
|
|
||
|
#include <omp.h>
|
||
|
#include <assert.h>
|
||
|
|
||
|
#define N 10
|
||
|
|
||
|
struct B
|
||
|
{
|
||
|
static int icount;
|
||
|
static int dcount;
|
||
|
static int xcount;
|
||
|
|
||
|
B();
|
||
|
B(const B &);
|
||
|
~B();
|
||
|
B& operator=(const B &);
|
||
|
void doit();
|
||
|
};
|
||
|
|
||
|
int B::icount;
|
||
|
int B::dcount;
|
||
|
int B::xcount;
|
||
|
|
||
|
B::B()
|
||
|
{
|
||
|
#pragma omp atomic
|
||
|
icount++;
|
||
|
}
|
||
|
|
||
|
B::~B()
|
||
|
{
|
||
|
#pragma omp atomic
|
||
|
dcount++;
|
||
|
}
|
||
|
|
||
|
void B::doit()
|
||
|
{
|
||
|
#pragma omp atomic
|
||
|
xcount++;
|
||
|
}
|
||
|
|
||
|
static int nthreads;
|
||
|
|
||
|
void foo()
|
||
|
{
|
||
|
B b[N];
|
||
|
#pragma omp parallel private(b)
|
||
|
{
|
||
|
#pragma omp master
|
||
|
nthreads = omp_get_num_threads ();
|
||
|
b[0].doit();
|
||
|
}
|
||
|
}
|
||
|
|
||
|
int main()
|
||
|
{
|
||
|
omp_set_dynamic (0);
|
||
|
omp_set_num_threads (4);
|
||
|
foo();
|
||
|
|
||
|
assert (B::xcount == nthreads);
|
||
|
assert (B::icount == (nthreads+1)*N);
|
||
|
assert (B::dcount == (nthreads+1)*N);
|
||
|
|
||
|
return 0;
|
||
|
}
|