1  /* { dg-do run { target { aarch64_sve_hw } } } */
       2  /* { dg-options "-O2 -ftree-vectorize" } */
       3  
       4  #include "cond_shift_3.c"
       5  
       6  #define N 99
       7  
       8  #define TEST_LOOP(TYPE, NAME, OP)				\
       9    {								\
      10      TYPE r[N], a[N], b[N];					\
      11      for (int i = 0; i < N; ++i)					\
      12        {								\
      13  	a[i] = (i & 1 ? i : 3 * i);				\
      14  	b[i] = (i >> 4) << (i & 15);				\
      15  	asm volatile ("" ::: "memory");				\
      16        }								\
      17      test_##TYPE##_##NAME (r, a, b, N);				\
      18      for (int i = 0; i < N; ++i)					\
      19        if (r[i] != (TYPE) (a[i] > 20 ? b[i] OP 3 : 72))		\
      20  	__builtin_abort ();					\
      21    }
      22  
      23  int main ()
      24  {
      25    TEST_ALL (TEST_LOOP)
      26    return 0;
      27  }