1  /* { dg-options "-O2 -ftree-vectorize" } */
       2  
       3  #include <stdint.h>
       4  
       5  #define TEST_PAIR(TYPE1, TYPE2)					\
       6    void								\
       7    f_##TYPE1##_##TYPE2 (TYPE1 *restrict x, TYPE1 y, TYPE1 z,	\
       8  		       TYPE2 *restrict g, TYPE2 h, int n)	\
       9    {								\
      10      for (int i = 0; i < n; ++i)					\
      11        x[i] = g[i] < h ? y : z;					\
      12    }
      13  
      14  #define TEST_SINGLE(TYPE)			\
      15    TEST_PAIR (TYPE, int8_t)			\
      16    TEST_PAIR (TYPE, uint8_t)			\
      17    TEST_PAIR (TYPE, int16_t)			\
      18    TEST_PAIR (TYPE, uint16_t)			\
      19    TEST_PAIR (TYPE, int32_t)			\
      20    TEST_PAIR (TYPE, uint32_t)			\
      21    TEST_PAIR (TYPE, int64_t)			\
      22    TEST_PAIR (TYPE, uint64_t)
      23  
      24  TEST_SINGLE (int8_t)
      25  TEST_SINGLE (uint8_t)
      26  TEST_SINGLE (int16_t)
      27  TEST_SINGLE (uint16_t)
      28  TEST_SINGLE (int32_t)
      29  TEST_SINGLE (uint32_t)
      30  TEST_SINGLE (float)
      31  TEST_SINGLE (int64_t)
      32  TEST_SINGLE (uint64_t)
      33  TEST_SINGLE (double)
      34  
      35  /* { dg-final { scan-assembler-times {\tld1b\tz[0-9]+\.b,} 4 } } */
      36  /* { dg-final { scan-assembler-times {\tld1b\tz[0-9]+\.h,} 4 } } */
      37  /* { dg-final { scan-assembler-times {\tld1b\tz[0-9]+\.s,} 6 } } */
      38  /* { dg-final { scan-assembler-times {\tld1b\tz[0-9]+\.d,} 6 } } */
      39  
      40  /* { dg-final { scan-assembler-times {\tld1h\tz[0-9]+\.h,} 8 } } */
      41  /* { dg-final { scan-assembler-times {\tld1h\tz[0-9]+\.s,} 6 } } */
      42  /* { dg-final { scan-assembler-times {\tld1h\tz[0-9]+\.d,} 6 } } */
      43  
      44  /* { dg-final { scan-assembler-times {\tld1w\tz[0-9]+\.s,} 14 } } */
      45  /* { dg-final { scan-assembler-times {\tld1w\tz[0-9]+\.d,} 6 } } */
      46  
      47  /* { dg-final { scan-assembler-times {\tld1d\tz[0-9]+\.d,} 20 } } */
      48  
      49  /* { dg-final { scan-assembler-times {\tst1b\tz[0-9]+\.b,} 4 } } */
      50  /* { dg-final { scan-assembler-times {\tst1b\tz[0-9]+\.h,} 4 } } */
      51  /* { dg-final { scan-assembler-times {\tst1b\tz[0-9]+\.s,} 4 } } */
      52  /* { dg-final { scan-assembler-times {\tst1b\tz[0-9]+\.d,} 4 } } */
      53  
      54  /* { dg-final { scan-assembler-times {\tst1h\tz[0-9]+\.h,} 8 } } */
      55  /* { dg-final { scan-assembler-times {\tst1h\tz[0-9]+\.s,} 4 } } */
      56  /* { dg-final { scan-assembler-times {\tst1h\tz[0-9]+\.d,} 4 } } */
      57  
      58  /* { dg-final { scan-assembler-times {\tst1w\tz[0-9]+\.s,} 18 } } */
      59  /* { dg-final { scan-assembler-times {\tst1w\tz[0-9]+\.d,} 6 } } */
      60  
      61  /* { dg-final { scan-assembler-times {\tst1d\tz[0-9]+\.d,} 24 } } */
      62  
      63  /* { dg-final { scan-assembler-times {\tcmp(?:h[is]|l[os])\tp[0-9]+\.b,} 10 } } */
      64  /* { dg-final { scan-assembler-times {\tcmp[lg][et]\tp[0-9]+\.b,} 10 } } */
      65  /* { dg-final { scan-assembler-times {\tcmp(?:h[is]|l[os])\tp[0-9]+\.h,} 10 } } */
      66  /* { dg-final { scan-assembler-times {\tcmp[lg][et]\tp[0-9]+\.h,} 10 } } */
      67  /* { dg-final { scan-assembler-times {\tcmp(?:h[is]|l[os])\tp[0-9]+\.s,} 10 } } */
      68  /* { dg-final { scan-assembler-times {\tcmp[lg][et]\tp[0-9]+\.s,} 10 } } */
      69  /* { dg-final { scan-assembler-times {\tcmp(?:h[is]|l[os])\tp[0-9]+\.d,} 10 } } */
      70  /* { dg-final { scan-assembler-times {\tcmp[lg][et]\tp[0-9]+\.d,} 10 } } */
      71  
      72  /* { dg-final { scan-assembler-not {\tpunpk} } } */