
This patch handles the strided update in the `#pragma omp target update
from(data[a🅱️c])` directive where 'c' represents the strided access
leading to non-contiguous update in the `data` array when the offloaded
execution returns the control back to host from device using the `from`
clause.
Issue: Clang CodeGen where info is generated for the particular
`MapType` (to, from, etc), it was failing to detect the strided access.
Because of this, the `MapType` bits were incorrect when passed to
runtime. This led to incorrect execution (contiguous) in the
libomptarget runtime code.
Added a minimal testcase that verifies the working of the patch.
38 lines
1.6 KiB
C
38 lines
1.6 KiB
C
// RUN: %clang_cc1 -verify -fopenmp -ferror-limit 100 %s -Wuninitialized
|
|
// RUN: %clang_cc1 -verify -fopenmp-simd -ferror-limit 100 %s -Wuninitialized
|
|
|
|
void foo(void) {}
|
|
|
|
int main(int argc, char **argv) {
|
|
int len = 8;
|
|
double data[len];
|
|
|
|
// Valid strided array sections
|
|
#pragma omp target update from(data[0:4:2]) // OK
|
|
{}
|
|
|
|
#pragma omp target update to(data[0:len/2:2]) // OK
|
|
{}
|
|
|
|
#pragma omp target update from(data[1:3:2]) // OK
|
|
{}
|
|
|
|
// Missing stride (default = 1)
|
|
#pragma omp target update from(data[0:4]) // OK
|
|
{}
|
|
|
|
// Invalid stride expressions
|
|
#pragma omp target update from(data[0:4:0]) // expected-error {{section stride is evaluated to a non-positive value 0}} expected-error {{expected at least one 'to' clause or 'from' clause specified to '#pragma omp target update'}}
|
|
|
|
#pragma omp target update from(data[0:4:-1]) // expected-error {{section stride is evaluated to a non-positive value -1}} expected-error {{expected at least one 'to' clause or 'from' clause specified to '#pragma omp target update'}}
|
|
|
|
// Missing colon
|
|
#pragma omp target update from(data[0:4 2]) // expected-error {{expected ']'}} expected-note {{to match this '['}} expected-error {{expected at least one 'to' clause or 'from' clause specified to '#pragma omp target update'}}
|
|
{}
|
|
|
|
// Too many colons
|
|
#pragma omp target update from(data[0:4:2:1]) // expected-error {{expected ']'}} expected-note {{to match this '['}} expected-error {{expected at least one 'to' clause or 'from' clause specified to '#pragma omp target update'}}
|
|
{}
|
|
|
|
return 0;
|
|
} |