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_paddsw_1
16 #include <emmintrin.h>
19 __attribute__((noinline
, unused
))
20 test (__m128i s1
, __m128i s2
)
22 __asm("" : "+v"(s1
), "+v"(s2
));
23 return _mm_adds_epi16 (s1
, s2
);
29 union128i_w u
, s1
, s2
;
33 s1
.x
= _mm_set_epi16 (10,20,30,90,-80,-40,-100,-15);
34 s2
.x
= _mm_set_epi16 (11, 98, 76, -100, -34, -78, -39, 14);
35 u
.x
= test (s1
.x
, s2
.x
);
37 for (i
= 0; i
< 8; i
++)
39 tmp
= s1
.a
[i
] + s2
.a
[i
];
49 if (check_union128i_w (u
, e
))
52 printf ("sse2_test_paddsw_1; check_union128i_w failed\n");
53 printf ("\tadds\t([%x,%x,%x,%x, %x,%x,%x,%x],\n", s1
.a
[0], s1
.a
[1],
54 s1
.a
[2], s1
.a
[3], s1
.a
[4], s1
.a
[5], s1
.a
[6], s1
.a
[7]);
55 printf ("\t\t [%x,%x,%x,%x, %x,%x,%x,%x])\n", s2
.a
[0], s2
.a
[1], s2
.a
[2],
56 s2
.a
[3], s2
.a
[4], s2
.a
[5], s2
.a
[6], s2
.a
[7]);
57 printf ("\t ->\t [%x,%x,%x,%x, %x,%x,%x,%x]\n", u
.a
[0], u
.a
[1], u
.a
[2],
58 u
.a
[3], u
.a
[4], u
.a
[5], u
.a
[6], u
.a
[7]);
59 printf ("\texpect\t [%x,%x,%x,%x, %x,%x,%x,%x]\n", e
[0], e
[1], e
[2],
60 e
[3], e
[4], e
[5], e
[6], e
[7]);