Mercurial > hg > CbC > CbC_gcc
diff gcc/testsuite/c-c++-common/gomp/declare-variant-10.c @ 145:1830386684a0
gcc-9.2.0
author | anatofuz |
---|---|
date | Thu, 13 Feb 2020 11:34:05 +0900 |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/gcc/testsuite/c-c++-common/gomp/declare-variant-10.c Thu Feb 13 11:34:05 2020 +0900 @@ -0,0 +1,77 @@ +/* { dg-do compile } */ +/* { dg-additional-options "-foffload=disable -fdump-tree-gimple" } */ +/* { dg-additional-options "-mavx512bw" { target { i?86-*-* x86_64-*-* } } } */ + +#undef i386 +void f01 (void); +#pragma omp declare variant (f01) match (device={isa(avx512f,avx512bw)}) +void f02 (void); +void f03 (void); +#pragma omp declare variant (f03) match (device={kind("any"),arch(x86_64),isa(avx512f,avx512bw)}) +void f04 (void); +void f05 (void); +#pragma omp declare variant (f05) match (device={kind(gpu)}) +void f06 (void); +void f07 (void); +#pragma omp declare variant (f07) match (device={kind(cpu)}) +void f08 (void); +void f09 (void); +#pragma omp declare variant (f09) match (device={isa(sm_35)}) +void f10 (void); +void f11 (void); +#pragma omp declare variant (f11) match (device={arch("nvptx")}) +void f12 (void); +void f13 (void); +#pragma omp declare variant (f13) match (device={arch(i386),isa("sse4")}) +void f14 (void); +void f15 (void); +#pragma omp declare variant (f15) match (device={isa(sse4,ssse3),arch(i386)}) +void f16 (void); +void f17 (void); +#pragma omp declare variant (f17) match (device={kind(any,fpga)}) +void f18 (void); + +#pragma omp declare target +void +test1 (void) +{ + int i; + f02 (); /* { dg-final { scan-tree-dump-times "f01 \\\(\\\);" 1 "gimple" { target i?86-*-* x86_64-*-* } } } */ + /* { dg-final { scan-tree-dump-times "f02 \\\(\\\);" 1 "gimple" { target { ! { i?86-*-* x86_64-*-* } } } } } */ + f14 (); /* { dg-final { scan-tree-dump-times "f13 \\\(\\\);" 1 "gimple" { target ia32 } } } */ + /* { dg-final { scan-tree-dump-times "f14 \\\(\\\);" 1 "gimple" { target { ! ia32 } } } } */ + f18 (); /* { dg-final { scan-tree-dump-times "f18 \\\(\\\);" 1 "gimple" } } */ +} +#pragma omp end declare target + +#if defined(__i386__) || defined(__x86_64__) +__attribute__((target ("avx512f,avx512bw"))) +#endif +void +test2 (void) +{ + #pragma omp target + f04 (); /* { dg-final { scan-tree-dump-times "f03 \\\(\\\);" 1 "gimple" { target { { i?86-*-* x86_64-*-* } && lp64 } } } } */ + /* { dg-final { scan-tree-dump-times "f04 \\\(\\\);" 1 "gimple" { target { { ! lp64 } || { ! { i?86-*-* x86_64-*-* } } } } } } */ + #pragma omp target + f16 (); /* { dg-final { scan-tree-dump-times "f15 \\\(\\\);" 1 "gimple" { target ia32 } } } */ + /* { dg-final { scan-tree-dump-times "f16 \\\(\\\);" 1 "gimple" { target { ! ia32 } } } } */ +} + +void +test3 (void) +{ + f06 (); /* { dg-final { scan-tree-dump-times "f06 \\\(\\\);" 1 "gimple" { target { ! { nvptx*-*-* amdgcn*-*-* } } } } } */ + f08 (); /* { dg-final { scan-tree-dump-times "f07 \\\(\\\);" 1 "gimple" { target { ! { nvptx*-*-* amdgcn*-*-* } } } } } */ +} +#pragma omp declare target to (test3) + +void +test4 (void) +{ + #pragma omp target + f10 (); /* { dg-final { scan-tree-dump-times "f10 \\\(\\\);" 1 "gimple" { target { ! { nvptx*-*-* amdgcn*-*-* } } } } } */ + #pragma omp target + f12 (); /* { dg-final { scan-tree-dump-times "f12 \\\(\\\);" 1 "gimple" { target { ! { nvptx*-*-* } } } } } */ + /* { dg-final { scan-tree-dump-times "f11 \\\(\\\);" 1 "gimple" { target { nvptx*-*-* } } } } */ +}