source: CIVL/examples/library/omp/reduction.cvl@ 8dfcbb9

1.23 2.0 main test-branch
Last change on this file since 8dfcbb9 was 0f05a20a, checked in by Ziqing Luo <ziqing@…>, 9 years ago

merged from the CIVLworking

git-svn-id: svn://vsl.cis.udel.edu/civl/trunk@4377 fb995dde-84ed-4084-dfe6-e5aef3e2452c

  • Property mode set to 100644
File size: 945 bytes
Line 
1#include<civlc.cvh>
2#include<civl-omp.cvh>
3#include<stdio.h>
4
5void main(){
6 int sum = 0;
7 $omp_gteam gteam = $omp_gteam_create($here, 3);
8 $omp_gshared gshared = $omp_gshared_create(gteam, &sum);
9
10 void thread(int tid) {
11 int sum_local;
12 int sum_status;
13 int private;
14 int _sum = 0;
15
16 $omp_team team = $omp_team_create($here, gteam, tid);
17 $omp_shared shared = $omp_shared_create(team, gshared, &sum_local, &sum_status);
18 printf("Hello from thread %d\n", tid);
19 //(reduction) sum = sum + tid;
20 _sum = _sum + tid+1;
21 $omp_apply_assoc(shared, _SUM, &_sum);
22 $omp_barrier_and_flush(team);
23 $omp_read(shared, &private, &sum_local);
24 $omp_barrier_and_flush(team);
25 $assert(private == 6);
26 $omp_shared_destroy(shared);
27 $omp_team_destroy(team);
28 }
29
30 $parfor (int i: ($domain){ 0 .. 2 }) {
31 thread(i);
32 }
33 $assert(sum == 6);
34 $omp_gshared_destroy(gshared);
35 $omp_gteam_destroy(gteam);
36}
Note: See TracBrowser for help on using the repository browser.