1 /* { dg-do run } */
2 /* { dg-options "-O3 -mpower8-vector" } */
3 /* { dg-require-effective-target p8vector_hw } */
4 
5 #define NO_WARN_X86_INTRINSICS 1
6 
7 #ifndef CHECK_H
8 #define CHECK_H "sse-check.h"
9 #endif
10 
11 #include CHECK_H
12 
13 #ifndef TEST
14 #define TEST sse_test_movlps_2
15 #endif
16 
17 #include <xmmintrin.h>
18 
19 static void
20 __attribute__((noinline, unused))
test(__m64 * p,__m128 a)21 test (__m64 *p, __m128 a)
22 {
23   __asm("" : "+v"(a));
24   return _mm_storel_pi (p, a);
25 }
26 
27 static void
TEST(void)28 TEST (void)
29 {
30   union128 s1;
31   float e[2];
32   float d[2];
33 
34   s1.x = _mm_set_ps (5.13, 6.12, 7.11, 8.9);
35 
36   test ((__m64 *)d, s1.x);
37 
38   e[0] = s1.a[0];
39   e[1] = s1.a[1];
40 
41   if (checkVf (d, e, 2))
42     abort ();
43 }
44