mirror of
https://github.com/OpenMP/Examples.git
synced 2025-04-07 23:22:11 +01:00
30 lines
706 B
C
30 lines
706 B
C
/*
|
|
* @@name: target_update.1c
|
|
* @@type: C
|
|
* @@compilable: yes
|
|
* @@linkable: no
|
|
* @@expect: success
|
|
*/
|
|
extern void init(float *, float *, int);
|
|
extern void init_again(float *, float *, int);
|
|
extern void output(float *, int);
|
|
void vec_mult(float *p, float *v1, float *v2, int N)
|
|
{
|
|
int i;
|
|
init(v1, v2, N);
|
|
#pragma omp target data map(to: v1[:N], v2[:N]) map(from: p[0:N])
|
|
{
|
|
#pragma omp target
|
|
#pragma omp parallel for
|
|
for (i=0; i<N; i++)
|
|
p[i] = v1[i] * v2[i];
|
|
init_again(v1, v2, N);
|
|
#pragma omp target update to(v1[:N], v2[:N])
|
|
#pragma omp target
|
|
#pragma omp parallel for
|
|
for (i=0; i<N; i++)
|
|
p[i] = p[i] + (v1[i] * v2[i]);
|
|
}
|
|
output(p, N);
|
|
}
|