(root)/
gcc-13.2.0/
gcc/
testsuite/
gcc.target/
powerpc/
sse2-psrld-2.c
       1  /* { dg-do run } */
       2  /* { dg-options "-O3 -mpower8-vector -Wno-psabi" } */
       3  /* { dg-require-effective-target p8vector_hw } */
       4  
       5  #ifndef CHECK_H
       6  #define CHECK_H "sse2-check.h"
       7  #endif
       8  
       9  #include CHECK_H
      10  
      11  #ifndef TEST
      12  #define TEST sse2_test_psrld_2
      13  #endif
      14  
      15  #include <emmintrin.h>
      16  
      17  static __m128i
      18  __attribute__((noinline, unused))
      19  test (__m128i s1, __m128i c)
      20  {
      21    return _mm_srl_epi32 (s1, c); 
      22  }
      23  
      24  static void
      25  TEST (void)
      26  {
      27    union128i_d u, s;
      28    union128i_q c;
      29    int e[4] = { 0 };
      30    unsigned int tmp;
      31    int i;
      32   
      33    s.x = _mm_set_epi32 (2, -3, 0x7000, 0x9000);
      34    c.x = _mm_set_epi64x (12, 23);
      35  
      36    __asm("" : "+v"(s.x), "+v"(c.x));
      37    u.x = test (s.x, c.x);
      38  
      39    if (c.a[0] < 32)
      40      for (i = 0; i < 4; i++)
      41        {
      42          tmp = s.a[i];
      43          e[i] = tmp >> c.a[0];
      44        } 
      45  
      46    if (check_union128i_d (u, e))
      47      {
      48  #if DEBUG
      49        printf ("sse2_test_psrld_2; check_union128i_d failed\n");
      50        printf ("\tsrld\t([%x,%x,%x,%x], [%llx,%llx]\n", s.a[0], s.a[1], s.a[2],
      51  	      s.a[3], c.a[0], c.a[1]);
      52        printf ("\t ->\t [%x,%x,%x,%x]\n", u.a[0], u.a[1], u.a[2], u.a[3]);
      53        printf ("\texpect\t [%x,%x,%x,%x]\n", e[0], e[1], e[2], e[3]);
      54  #endif
      55        abort ();
      56      }
      57  }