mirror of
https://github.com/OpenMP/Examples.git
synced 2025-04-07 23:22:11 +01:00
35 lines
678 B
C
35 lines
678 B
C
/*
|
|
* @@name: target_task_reduction.2b.c
|
|
* @@type: C
|
|
* @@compilable: yes
|
|
* @@linkable: yes
|
|
* @@expect: success
|
|
* @@version: omp_5.1
|
|
*/
|
|
#if _OPENMP < 202011
|
|
#define masked master
|
|
#endif
|
|
|
|
#include <stdio.h>
|
|
#pragma omp declare target to(device_compute)
|
|
extern void device_compute(int *);
|
|
extern void host_compute(int *);
|
|
int main()
|
|
{
|
|
int sum = 0;
|
|
|
|
#pragma omp parallel masked reduction(task, +:sum)
|
|
{
|
|
#pragma omp target in_reduction(+:sum) nowait
|
|
device_compute(&sum);
|
|
|
|
host_compute(&sum);
|
|
}
|
|
printf( "sum = %d\n", sum);
|
|
//OUTPUT: sum = 2
|
|
return 0;
|
|
}
|
|
|
|
void device_compute(int *sum){ *sum = 1; }
|
|
void host_compute(int *sum){ *sum = 1; }
|