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 #ifndef CHECK_H 7 #define CHECK_H "mmx-check.h" 8 #endif 9 10 #ifndef TEST 11 #define TEST mmx_test 12 #endif 13 14 #include CHECK_H 15 16 #include <mmintrin.h> 17 18 static __m64 19 __attribute__((noinline, unused)) test(__m64 s1,__m64 s2)20test (__m64 s1, __m64 s2) 21 { 22 return _mm_unpackhi_pi32 (s1, s2); 23 } 24 25 static void TEST(void)26TEST (void) 27 { 28 __m64_union u, s1, s2, e; 29 30 s1.as_m64 = 0x0706050403020100UL; 31 s2.as_m64 = 0x1716151413121110UL; 32 u.as_m64 = test (s1.as_m64, s2.as_m64); 33 34 e.as_int[0] = s1.as_int[1]; 35 e.as_int[1] = s2.as_int[1]; 36 37 if (u.as_m64 != e.as_m64) 38 abort (); 39 } 40