2014-09-21 19:33:12 +02:00

50 lines
972 B
C

// { dg-do run }
extern "C" void abort ();
struct S
{
void foo ()
{
S s;
int j = 0;
#pragma omp declare reduction (bar : int : omp_out += omp_in)
#pragma omp parallel reduction (bar : s) reduction(S::operator+ : j)
s.a = 4, j = 1;
if (s.a != 4 * j) abort ();
}
#pragma omp declare reduction (bar : S : baz (omp_out, omp_in))
static void baz (S &x, S &y) { x.a += y.a; }
S () : a (0) {}
int a;
};
template <int N>
struct T
{
void foo ()
{
S s;
T t;
int j = 0;
#pragma omp declare reduction (bar : int : omp_out += omp_in)
#pragma omp parallel reduction (bar : t) reduction (S::bar : s) \
reduction(T<N>::operator+ : j)
s.a = 4, t.a = 5, j = 1;
if (s.a != 4 * j || t.a != 5 * j) abort ();
}
#pragma omp declare reduction (bar : T<N> : baz (omp_out, omp_in))
static void baz (T &x, T &y) { x.a += y.a; }
T () : a (N) {}
int a;
};
int
main ()
{
S s;
s.foo ();
T<0> t;
t.foo ();
}