1  /* PR target/87767 */
       2  /* { dg-do compile } */
       3  /* { dg-options "-O2 -mavx512f -mavx512vl" } */
       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\\\}" 4 { target ia32 } } } */
       7  /* { dg-final { scan-assembler-times "\[^\n\]*\\\{1to4\\\}" 4 { target ia32 } } } */
       8  /* { dg-final { scan-assembler-times "vpbroadcastd\[\\t \]+%(?:r|e)\[^\n\]*, %xmm\[0-9\]+" 4 } } */
       9  /* { dg-final { scan-assembler-times "vpbroadcastd\[\\t \]+%(?:r|e)\[^\n\]*, %ymm\[0-9\]+" 4 } } */
      10  /* { dg-final { scan-assembler-times "vpbroadcastq\[\\t \]+%r\[^\n\]*, %xmm\[0-9\]+" 4 { target { ! ia32 } } } } */
      11  /* { dg-final { scan-assembler-times "vpbroadcastq\[\\t \]+%r\[^\n\]*, %ymm\[0-9\]+" 4 { target { ! ia32 } } } } */
      12  
      13  typedef int v4si  __attribute__ ((vector_size (16)));
      14  typedef int v8si  __attribute__ ((vector_size (32)));
      15  typedef long long v2di  __attribute__ ((vector_size (16)));
      16  typedef long long v4di  __attribute__ ((vector_size (32)));
      17  
      18  #define CONSTANT 101;
      19  #define FOO(VTYPE, OP_NAME, OP1, OP2)		\
      20  VTYPE						\
      21   __attribute__ ((noipa))			\
      22   foo_##OP_NAME##_##VTYPE (VTYPE a)		\
      23  {						\
      24    return (OP1 a) OP2 CONSTANT;			\
      25  }						\
      26  
      27  FOO (v4si, andnot, ~, &);
      28  FOO (v8si, andnot, ~, &);
      29  FOO (v2di, andnot, ~, &);
      30  FOO (v4di, andnot, ~, &);
      31  FOO (v4si, and,, &);
      32  FOO (v8si, and,, &);
      33  FOO (v2di, and,, &);
      34  FOO (v4di, and,, &);
      35  FOO (v4si, or,, |);
      36  FOO (v8si, or,, |);
      37  FOO (v2di, or,, |);
      38  FOO (v4di, or,, |);
      39  FOO (v4si, xor,, ^);
      40  FOO (v8si, xor,, ^);
      41  FOO (v2di, xor,, ^);
      42  FOO (v4di, xor,, ^);