2018-01-22 Sebastian Perta <sebastian.perta@renesas.com>
[official-gcc.git] / libgomp / testsuite / libgomp.c++ / for-7.C
blob256a1312e4f7dbf867792cc2fd2b3503e1280a69
1 // PR c++/
2 // { dg-do run }
3 // { dg-additional-options "-std=c++0x" }
5 extern "C" void abort ();
6 int cnt;
8 template <typename T>
9 void
10 f0 (T, int)
12   abort ();
15 template <>
16 void
17 f0<int> (int, int type)
19   if (type != 0)
20     abort ();
21 #pragma omp atomic
22   cnt++;
25 template <>
26 void
27 f0<const char *> (const char *, int type)
29   if (type != 1)
30     abort ();
31 #pragma omp atomic
32   cnt++;
35 template <typename T>
36 void
37 f1 ()
39 #pragma omp parallel for
40   for (auto i = 0; i < 10; i++)
41     f0 (i, 0);
44 template <typename T>
45 void
46 f2 ()
48 #pragma omp parallel for
49   for (auto i = T (0); i < T (10); i += T (1))
50     f0 (i, 0);
53 void
54 f3 ()
56 #pragma omp parallel for
57   for (auto i = 0; i < 10; i++)
58     f0 (i, 0);
61 const char *p = "abcdefghij";
63 template <typename T>
64 void
65 f4 ()
67 #pragma omp parallel for
68   for (auto i = p; i < p + 10; i++)
69     f0 (i, 1);
72 template <typename T>
73 void
74 f5 ()
76 #pragma omp parallel for
77   for (auto i = T (p); i < T (p + 10); i++)
78     f0 (i, 1);
81 void
82 f6 ()
84 #pragma omp parallel for
85   for (auto i = p; i < p + 10; i++)
86     f0 (i, 1);
89 int
90 main ()
92   f1<int> ();
93   if (cnt != 10)
94     abort ();
95   f2<int> ();
96   if (cnt != 20)
97     abort ();
98   f3 ();
99   if (cnt != 30)
100     abort ();
101   f4<int> ();
102   if (cnt != 40)
103     abort ();
104   f5<const char *> ();
105   if (cnt != 50)
106     abort ();
107   f6 ();
108   if (cnt != 60)
109     abort ();