(root)/
gcc-13.2.0/
gcc/
testsuite/
gcc.target/
i386/
avx512vl-broadcast-pr87767-1.c
       1  /* PR target/87767 */
       2  /* { dg-do compile } */
       3  /* { dg-options "-O2 -mavx512f -mavx512vl -mavx512dq" } */
       4  /* { dg-additional-options "-fno-PIE" { target ia32 } } */
       5  /* { dg-additional-options "-mdynamic-no-pic" { target { *-*-darwin* && ia32 } } }
       6  /* { dg-final { scan-assembler-times "\[^\n\]*\\\{1to2\\\}" 2 { target { ! ia32 } } } }  */
       7  /* { dg-final { scan-assembler-times "\[^\n\]*\\\{1to4\\\}" 4 { target { ! ia32 } } } }  */
       8  /* { dg-final { scan-assembler-times "\[^\n\]*\\\{1to2\\\}" 5 { target ia32 } } } */
       9  /* { dg-final { scan-assembler-times "\[^\n\]*\\\{1to4\\\}" 7 { target ia32 } } } */
      10  /* { dg-final { scan-assembler-times "\[^\n\]*\\\{1to8\\\}" 2 } }  */
      11  /* { dg-final { scan-assembler-times "vpbroadcastd\[\\t \]+%(?:r|e)\[^\n\]*, %xmm\[0-9\]+" 3 } } */
      12  /* { dg-final { scan-assembler-times "vpbroadcastd\[\\t \]+%(?:r|e)\[^\n\]*, %ymm\[0-9\]+" 3 } } */
      13  /* { dg-final { scan-assembler-times "vpbroadcastq\[\\t \]+%r\[^\n\]*, %xmm\[0-9\]+" 3 { target { ! ia32 } } } } */
      14  /* { dg-final { scan-assembler-times "vpbroadcastq\[\\t \]+%r\[^\n\]*, %ymm\[0-9\]+" 3 { target { ! ia32 } } } } */
      15  
      16  typedef int v4si  __attribute__ ((vector_size (16)));
      17  typedef int v8si  __attribute__ ((vector_size (32)));
      18  typedef long long v2di  __attribute__ ((vector_size (16)));
      19  typedef long long v4di  __attribute__ ((vector_size (32)));
      20  typedef float v4sf  __attribute__ ((vector_size (16)));
      21  typedef float v8sf  __attribute__ ((vector_size (32)));
      22  typedef double v2df  __attribute__ ((vector_size (16)));
      23  typedef double v4df  __attribute__ ((vector_size (32)));
      24  
      25  #define CONSTANT 101;
      26  #define FOO(VTYPE, OP_NAME, OP)			\
      27  VTYPE						\
      28   __attribute__ ((noipa))			\
      29  foo_##OP_NAME##_##VTYPE (VTYPE a)		\
      30  {						\
      31    return a OP CONSTANT;				\
      32  }						\
      33  
      34  FOO (v4si, add, +);
      35  FOO (v8si, add, +);
      36  FOO (v2di, add, +);
      37  FOO (v4di, add, +);
      38  FOO (v4si, sub, -);
      39  FOO (v8si, sub, -);
      40  FOO (v2di, sub, -);
      41  FOO (v4di, sub, -);
      42  FOO (v4sf, add, +);
      43  FOO (v8sf, add, +);
      44  FOO (v2df, add, +);
      45  FOO (v4df, add, +);
      46  FOO (v4si, mul, *);
      47  FOO (v8si, mul, *);
      48  FOO (v2di, mul, *);
      49  FOO (v4di, mul, *);
      50  FOO (v4sf, mul, *);
      51  FOO (v8sf, mul, *);
      52  FOO (v2df, mul, *);
      53  FOO (v4df, mul, *);