2 /* { dg-require-effective-target sse4 } */
3 /* { dg-options "-O2 -msse4.2" } */
6 #define CHECK_H "sse4_2-check.h"
10 #define TEST sse4_2_test
15 #include "sse4_2-pcmpstr.h"
20 (_SIDD_SBYTE_OPS | _SIDD_CMP_RANGES | _SIDD_MASKED_POSITIVE_POLARITY)
22 (_SIDD_UBYTE_OPS | _SIDD_CMP_EQUAL_EACH | _SIDD_NEGATIVE_POLARITY \
25 (_SIDD_UWORD_OPS | _SIDD_CMP_EQUAL_ANY | _SIDD_NEGATIVE_POLARITY)
27 (_SIDD_SWORD_OPS | _SIDD_CMP_EQUAL_ORDERED \
28 | _SIDD_MASKED_NEGATIVE_POLARITY | _SIDD_UNIT_MASK)
39 int correct_flags
, l1
, l2
;
40 int flags
, cf
, zf
, sf
, of
, af
;
43 for (i
= 0; i
< NUM
*16; i
++)
49 for (i
= 0; i
< NUM
; i
++)
54 switch ((rand () % 4))
57 res
= _mm_cmpestrm (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL0
);
58 cf
= _mm_cmpestrc (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL0
);
59 zf
= _mm_cmpestrz (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL0
);
60 sf
= _mm_cmpestrs (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL0
);
61 of
= _mm_cmpestro (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL0
);
62 af
= _mm_cmpestra (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL0
);
63 correct
= cmp_em (&src1
.x
[i
], l1
, &src2
.x
[i
], l2
, IMM_VAL0
,
68 res
= _mm_cmpestrm (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL1
);
69 cf
= _mm_cmpestrc (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL1
);
70 zf
= _mm_cmpestrz (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL1
);
71 sf
= _mm_cmpestrs (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL1
);
72 of
= _mm_cmpestro (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL1
);
73 af
= _mm_cmpestra (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL1
);
74 correct
= cmp_em (&src1
.x
[i
], l1
, &src2
.x
[i
], l2
, IMM_VAL1
,
79 res
= _mm_cmpestrm (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL2
);
80 cf
= _mm_cmpestrc (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL2
);
81 zf
= _mm_cmpestrz (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL2
);
82 sf
= _mm_cmpestrs (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL2
);
83 of
= _mm_cmpestro (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL2
);
84 af
= _mm_cmpestra (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL2
);
85 correct
= cmp_em (&src1
.x
[i
], l1
, &src2
.x
[i
], l2
, IMM_VAL2
,
90 res
= _mm_cmpestrm (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL3
);
91 cf
= _mm_cmpestrc (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL3
);
92 zf
= _mm_cmpestrz (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL3
);
93 sf
= _mm_cmpestrs (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL3
);
94 of
= _mm_cmpestro (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL3
);
95 af
= _mm_cmpestra (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL3
);
96 correct
= cmp_em (&src1
.x
[i
], l1
, &src2
.x
[i
], l2
, IMM_VAL3
,
101 if (memcmp (&correct
, &res
, sizeof (res
)))
114 if (flags
!= correct_flags
115 || (af
&& (cf
|| zf
))
116 || (!af
&& !(cf
|| zf
)))