2 /* { dg-require-effective-target p8vector_hw } */
3 /* { dg-options "-O2 -mvsx -Wno-psabi" } */
4 /* { dg-additional-options "-mdejagnu-cpu=power8" { target { ! has_arch_pwr8 } } } */
7 #define CHECK_H "sse4_1-check.h"
11 #define TEST sse4_1_test
16 #include <smmintrin.h>
27 init_blendps (float *src1
, float *src2
)
31 for (i
= 0; i
< NUM
* 4; i
++)
33 src1
[i
] = i
* i
* sign
;
34 src2
[i
] = (i
+ 20) * sign
;
40 check_blendps (__m128
*dst
, float *src1
, float *src2
)
45 memcpy (&tmp
[0], src1
, sizeof (tmp
));
46 for (j
= 0; j
< 4; j
++)
47 if ((MASK
& (1 << j
)))
50 return memcmp (dst
, &tmp
[0], sizeof (tmp
));
69 init_blendps (src1
.f
, src2
.f
);
71 for (i
= 0; i
< 4; i
++)
72 src3
.f
[i
] = (int) rand ();
74 /* Check blendps imm8, m128, xmm */
75 for (i
= 0; i
< NUM
; i
++)
77 dst
.x
[i
] = _mm_blend_ps (src1
.x
[i
], src2
.x
[i
], MASK
);
78 if (check_blendps (&dst
.x
[i
], &src1
.f
[i
* 4], &src2
.f
[i
* 4]))
82 /* Check blendps imm8, xmm, xmm */
83 x
= _mm_blend_ps (dst
.x
[2], src3
.x
, MASK
);
84 y
= _mm_blend_ps (src3
.x
, dst
.x
[2], MASK
);
86 if (check_blendps (&x
, &dst
.f
[8], &src3
.f
[0]))
89 if (check_blendps (&y
, &src3
.f
[0], &dst
.f
[8]))