1 /* { dg-do run } */
2 /* { dg-options "-O3 -mpower8-vector -Wno-psabi" } */
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_movlhps_1
15 #endif
16
17 #include <xmmintrin.h>
18
19 static __m128
20 __attribute__((noinline, unused))
21 test (__m128 a, __m128 b)
22 {
23 __asm("" : "+v"(a), "+v"(a));
24 return _mm_movelh_ps (a, b);
25 }
26
27 static void
28 TEST (void)
29 {
30 union128 u, s1, s2;
31 float e[4];
32
33 s1.x = _mm_set_ps (24.43, 68.346, 43.35, 546.46);
34 s2.x = _mm_set_ps (1.17, 2.16, 3.15, 4.14);
35 u.x = _mm_set1_ps (0.0);
36
37 u.x = test (s1.x, s2.x);
38
39 e[0] = s1.a[0];
40 e[1] = s1.a[1];
41 e[2] = s2.a[0];
42 e[3] = s2.a[1];
43
44 if (check_union128 (u, e))
45 abort ();
46 }