1  /* { dg-do compile } */
       2  /* { dg-additional-options "-foffload=disable -fdump-tree-gimple" } */
       3  /* { dg-additional-options "-mavx512bw" { target { i?86-*-* x86_64-*-* } } } */
       4  
       5  #undef i386
       6  void f01 (void);
       7  #pragma omp declare variant (f01) match (device={isa(avx512f,avx512bw)})
       8  void f02 (void);
       9  void f03 (void);
      10  #pragma omp declare variant (f03) match (device={kind("any"),arch(x86_64),isa(avx512f,avx512bw)})
      11  void f04 (void);
      12  void f05 (void);
      13  #pragma omp declare variant (f05) match (device={kind(gpu)})
      14  void f06 (void);
      15  void f07 (void);
      16  #pragma omp declare variant (f07) match (device={kind(cpu)})
      17  void f08 (void);
      18  void f09 (void);
      19  #pragma omp declare variant (f09) match (device={isa(sm_35)})
      20  void f10 (void);
      21  void f11 (void);
      22  #pragma omp declare variant (f11) match (device={arch("nvptx")})
      23  void f12 (void);
      24  void f13 (void);
      25  #pragma omp declare variant (f13) match (device={arch(i386),isa("sse4")})
      26  void f14 (void);
      27  void f15 (void);
      28  #pragma omp declare variant (f15) match (device={isa(sse4,ssse3),arch(i386)})
      29  void f16 (void);
      30  void f17 (void);
      31  #pragma omp declare variant (f17) match (device={kind(any,fpga)})
      32  void f18 (void);
      33  
      34  #pragma omp declare target
      35  void
      36  test1 (void)
      37  {
      38    int i;
      39    f02 ();	/* { dg-final { scan-tree-dump-times "f01 \\\(\\\);" 1 "gimple" { target i?86-*-* x86_64-*-* } } } */
      40  		/* { dg-final { scan-tree-dump-times "f02 \\\(\\\);" 1 "gimple" { target { ! { i?86-*-* x86_64-*-* } } } } } */
      41    f14 ();	/* { dg-final { scan-tree-dump-times "f13 \\\(\\\);" 1 "gimple" { target ia32 } } } */
      42  		/* { dg-final { scan-tree-dump-times "f14 \\\(\\\);" 1 "gimple" { target { ! ia32 } } } } */
      43    f18 ();	/* { dg-final { scan-tree-dump-times "f18 \\\(\\\);" 1 "gimple" } } */
      44  }
      45  #pragma omp end declare target
      46  
      47  #if defined(__i386__) || defined(__x86_64__)
      48  __attribute__((target ("avx512f,avx512bw")))
      49  #endif
      50  void
      51  test2 (void)
      52  {
      53    #pragma omp target
      54    f04 ();	/* { dg-final { scan-tree-dump-times "f03 \\\(\\\);" 1 "gimple" { target { { i?86-*-* x86_64-*-* } && lp64 } } } } */
      55  		/* { dg-final { scan-tree-dump-times "f04 \\\(\\\);" 1 "gimple" { target { { ! lp64 } || { ! { i?86-*-* x86_64-*-* } } } } } } */
      56    #pragma omp target
      57    f16 ();	/* { dg-final { scan-tree-dump-times "f15 \\\(\\\);" 1 "gimple" { target ia32 } } } */
      58  		/* { dg-final { scan-tree-dump-times "f16 \\\(\\\);" 1 "gimple" { target { ! ia32 } } } } */
      59  }
      60  
      61  void
      62  test3 (void)
      63  {
      64    f06 ();	/* { dg-final { scan-tree-dump-times "f06 \\\(\\\);" 1 "gimple" { target { ! { nvptx*-*-* amdgcn*-*-* } } } } } */
      65    f08 ();	/* { dg-final { scan-tree-dump-times "f07 \\\(\\\);" 1 "gimple" { target { ! { nvptx*-*-* amdgcn*-*-* } } } } } */
      66  }
      67  #pragma omp declare target to (test3)
      68  
      69  void
      70  test4 (void)
      71  {
      72    #pragma omp target
      73    f10 ();	/* { dg-final { scan-tree-dump-times "f10 \\\(\\\);" 1 "gimple" { target { ! { nvptx*-*-* amdgcn*-*-* } } } } } */
      74    #pragma omp target
      75    f12 ();	/* { dg-final { scan-tree-dump-times "f12 \\\(\\\);" 1 "gimple" { target { ! { nvptx*-*-* } } } } } */
      76  		/* { dg-final { scan-tree-dump-times "f11 \\\(\\\);" 1 "gimple" { target { nvptx*-*-* } } } } */
      77  }