2 /* { dg-options "-O3 -mpower8-vector -Wno-psabi" } */
3 /* { dg-require-effective-target p8vector_hw } */
6 #define CHECK_H "ssse3-check.h"
10 #define TEST ssse3_test
15 #include "ssse3-vals.h"
17 #include <tmmintrin.h>
20 /* Test the 64-bit form */
22 ssse3_test_phaddsw (__m64
*i1
, __m64
*i2
, __m64
*r
)
24 *r
= _mm_hadds_pi16 (*i1
, *i2
);
29 /* Test the 128-bit form */
31 ssse3_test_phaddsw128 (__m128i
*i1
, __m128i
*i2
, __m128i
*r
)
33 /* Assumes incoming pointers are 16-byte aligned */
34 *(__m128i
*) r
= _mm_hadds_epi16 (*i1
, *i2
);
38 signed_saturate_to_word (int x
)
43 if (x
< (int) 0xffff8000)
49 /* Routine to manually compute the results */
51 compute_correct_result (short *i1
, short *i2
, short *r
)
55 for (i
= 0; i
< 4; i
++)
56 r
[i
+ 0] = signed_saturate_to_word(i1
[2 * i
] + i1
[2 * i
+ 1]);
57 for (i
= 0; i
< 4; i
++)
58 r
[i
+ 4] = signed_saturate_to_word(i2
[2 * i
] + i2
[2 * i
+ 1]);
65 union data r
__attribute__ ((aligned(16)));
69 for (i
= 0; i
< ARRAY_SIZE (vals
) - 1; i
++)
71 /* Manually compute the result */
72 compute_correct_result (&vals
[i
+ 0].h
[0], &vals
[i
+ 1].h
[0], &ck
.h
[0]);
75 /* Run the 64-bit tests */
76 ssse3_test_phaddsw (&vals
[i
+ 0].ll
[0], &vals
[i
+ 0].ll
[1], &r
.ll
[0]);
77 ssse3_test_phaddsw (&vals
[i
+ 1].ll
[0], &vals
[i
+ 1].ll
[1], &r
.ll
[1]);
78 fail
+= chk_128 (ck
.m
[0], r
.m
[0]);
81 /* Run the 128-bit tests */
82 ssse3_test_phaddsw128 (&vals
[i
+ 0].m
[0], &vals
[i
+ 1].m
[0], &r
.m
[0]);
83 fail
+= chk_128 (ck
.m
[0], r
.m
[0]);