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 "ssse3-check.h"
11 #define TEST ssse3_test
16 #include "ssse3-vals.h"
18 #include <tmmintrin.h>
21 /* Test the 64-bit form */
23 ssse3_test_pabsd (__m64
*i1
, __m64
*r
)
25 *r
= _mm_abs_pi32 (*i1
);
30 /* Test the 128-bit form */
32 ssse3_test_pabsd128 (__m128i
*i1
, __m128i
*r
)
34 /* Assumes incoming pointers are 16-byte aligned */
35 *r
= _mm_abs_epi32 (*i1
);
38 /* Routine to manually compute the results */
40 compute_correct_result (int *i1
, int *r
)
44 for (i
= 0; i
< 4; i
++)
55 union data r
__attribute__ ((aligned(16)));
59 for (i
= 0; i
< ARRAY_SIZE (vals
); i
++)
61 /* Manually compute the result */
62 compute_correct_result(&vals
[i
].w
[0], &ck
.w
[0]);
65 /* Run the 64-bit tests */
66 ssse3_test_pabsd (&vals
[i
].ll
[0], &r
.ll
[0]);
67 ssse3_test_pabsd (&vals
[i
].ll
[1], &r
.ll
[1]);
68 fail
+= chk_128 (ck
.m
[0], r
.m
[0]);
71 /* Run the 128-bit tests */
72 ssse3_test_pabsd128 (&vals
[i
].m
[0], &r
.m
[0]);
73 fail
+= chk_128(ck
.m
[0], r
.m
[0]);