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 } */
7 #define CHECK_H "sse2-check.h"
13 #define TEST sse2_test_pmulhuw_1
16 #include <emmintrin.h>
19 __attribute__((noinline
, unused
))
20 test (__m128i s1
, __m128i s2
)
22 return _mm_mulhi_epu16 (s1
, s2
);
28 union128i_uw u
, s1
, s2
;
32 s1
.x
= _mm_set_epi16 (10,2067,3033,90,80,40,1000,15);
33 s2
.x
= _mm_set_epi16 (11, 9834, 7444, 10222, 34, 7833, 39, 14);
34 u
.x
= test (s1
.x
, s2
.x
);
36 for (i
= 0; i
< 8; i
++)
38 tmp
= s1
.a
[i
] * s2
.a
[i
];
40 e
[i
] = (tmp
& 0xffff0000)>>16;
43 if (check_union128i_uw (u
, e
))