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 }