/* { dg-do link { target { offload_target_amdgcn } } } */ /* { dg-additional-options "-foffload-options=-fdump-ipa-simdclone-details -foffload-options=-fno-openmp-target-simd-clone" } */ /* Test that simd clones for the offload processor are not generated for functions with "declare target" when explicitly disabled. */ #pragma omp declare target __attribute__ ((__noinline__)) int addit (int a, int b) { return a + b; } __attribute__ ((__noinline__)) void callit (int *a, int *b, int *c) { int i; #pragma omp for simd for (i = 0; i < 16; i++) c[i] = addit (a[i], b[i]); } #pragma omp end declare target int main (void) { int aa[16], bb[16], cc[16]; int i; for (i = 0; i < 16; i++) { aa[i] = i; bb[i] = -i; } callit (aa, bb, cc); for (i = 0; i < 16; i++) if (cc[i] != 0) return 1; return 0; } /* { dg-final { scan-offload-ipa-dump-not "Generated .* clone" "simdclone" } } */