blob: c5fe414f399a4fdcd642c11dc6b0a362ee825222 [file] [log] [blame]
Jim Cownie18d84732014-05-10 17:02:09 +00001<ompts:test>
2<ompts:testdescription>Test which checks the omp parallel sections private directive.</ompts:testdescription>
3<ompts:ompversion>2.0</ompts:ompversion>
4<ompts:directive>omp parallel sections private</ompts:directive>
5<ompts:dependences>omp critical</ompts:dependences>
6<ompts:testcode>
7#include <stdio.h>
8#include "omp_testsuite.h"
9
10int <ompts:testcode:functionname>omp_parallel_sections_private</ompts:testcode:functionname>(FILE * logFile){
11 <ompts:orphan:vars>
12 int sum;
13 int sum0;
14 int i;
15 </ompts:orphan:vars>
16 int known_sum;
17 sum = 7;
18 sum0=0;
19
20<ompts:orphan>
21#pragma omp parallel sections private(<ompts:check>sum0,</ompts:check> i)
22 {
23#pragma omp section
24 {
25 <ompts:check>
26 sum0=0;
27 </ompts:check>
28 for (i=1;i<400;i++)
29 sum0=sum0+i;
30#pragma omp critical
31 {
32 sum= sum+sum0;
33 } /*end of critical */
34 }
35#pragma omp section
36 {
37 <ompts:check>
38 sum0=0;
39 </ompts:check>
40 for(i=400;i<700;i++)
41 sum0=sum0+i;
42#pragma omp critical
43 {
44 sum= sum+sum0;
45 } /*end of critical */
46 }
47#pragma omp section
48 {
49 <ompts:check>
50 sum0=0;
51 </ompts:check>
52 for(i=700;i<1000;i++)
53 sum0=sum0+i;
54#pragma omp critical
55 {
56 sum= sum+sum0;
57 } /*end of critical */
58 }
Alp Tokerc2d5e612014-06-01 18:28:36 +000059 } /*end of parallel sections*/
Jim Cownie18d84732014-05-10 17:02:09 +000060</ompts:orphan>
61known_sum=(999*1000)/2+7;
62return (known_sum==sum);
63} /* end of check_section_private*/
64</ompts:testcode>
65</ompts:test>