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_phsubsw (__m64
*i1
, __m64
*i2
, __m64
*r
)
25 *(__m64
*) r
= _mm_hsubs_pi16 (*i1
, *i2
);
30 /* Test the 128-bit form */
32 ssse3_test_phsubsw128 (__m128i
*i1
, __m128i
*i2
, __m128i
*r
)
34 /* Assumes incoming pointers are 16-byte aligned */
35 *r
= _mm_hsubs_epi16 (*i1
, *i2
);
39 signed_saturate_to_word (int x
)
44 if (x
< (int) 0xffff8000)
50 /* Routine to manually compute the results */
52 compute_correct_result (short *i1
, short *i2
, short *r
)
56 for (i
= 0; i
< 4; i
++)
57 r
[i
] = signed_saturate_to_word (i1
[2 * i
] - i1
[2 * i
+ 1]);
59 for (i
= 0; i
< 4; i
++)
60 r
[i
+ 4] = signed_saturate_to_word (i2
[2 * i
] - i2
[2 * i
+ 1]);
67 union data r
__attribute__ ((aligned(16)));
71 for (i
= 0; i
< ARRAY_SIZE (vals
) - 1; i
++)
73 /* Manually compute the result */
74 compute_correct_result (&vals
[i
+ 0].h
[0], &vals
[i
+ 1].h
[0], &ck
.h
[0]);
77 /* Run the 64-bit tests */
78 ssse3_test_phsubsw (&vals
[i
+ 0].ll
[0], &vals
[i
+ 0].ll
[1], &r
.ll
[0]);
79 ssse3_test_phsubsw (&vals
[i
+ 1].ll
[0], &vals
[i
+ 1].ll
[1], &r
.ll
[1]);
80 fail
+= chk_128 (ck
.m
[0], r
.m
[0]);
83 /* Run the 128-bit tests */
84 ssse3_test_phsubsw128 (&vals
[i
+ 0].m
[0], &vals
[i
+ 1].m
[0], &r
.m
[0]);
85 fail
+= chk_128 (ck
.m
[0], r
.m
[0]);