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