c++: normalizing ttp constraints [PR115656]
[official-gcc.git] / gcc / testsuite / gcc.target / powerpc / sse-movhlps-1.c
blob3d8a325d70a15a6d4367089d53921568ae1197eb
1 /* { dg-do run } */
2 /* { dg-options "-O3 -mvsx -Wno-psabi" } */
3 /* { dg-additional-options "-mdejagnu-cpu=power8" { target { ! has_arch_pwr8 } } } */
4 /* { dg-require-effective-target p8vector_hw } */
6 #define NO_WARN_X86_INTRINSICS 1
8 #ifndef CHECK_H
9 #define CHECK_H "sse-check.h"
10 #endif
12 #include CHECK_H
14 #ifndef TEST
15 #define TEST sse_test_movhlps_1
16 #endif
18 #include <xmmintrin.h>
20 static __m128
21 __attribute__((noinline, unused))
22 test (__m128 s1, __m128 s2)
24 __asm("" : "+v"(s1), "+v"(s2));
25 return _mm_movehl_ps (s1, s2);
28 static void
29 TEST (void)
31 union128 u, s1, s2;
32 float e[4];
34 s1.x = _mm_set_ps (24.43, 68.346, 43.35, 546.46);
35 s2.x = _mm_set_ps (1.17, 2.16, 3.15, 4.14);
36 u.x = test (s1.x, s2.x);
38 e[0] = s2.a[2];
39 e[1] = s2.a[3];
40 e[2] = s1.a[2];
41 e[3] = s1.a[3];
43 if (check_union128 (u, e))
44 abort ();