2 /* { dg-require-effective-target sse4 } */
3 /* { dg-options "-O2 -msse4.2" } */
5 #include "sse4_2-check.h"
6 #include "sse4_2-pcmpstr.h"
11 (SIDD_SBYTE_OPS | SIDD_CMP_RANGES | SIDD_MASKED_POSITIVE_POLARITY)
13 (SIDD_UBYTE_OPS | SIDD_CMP_EQUAL_EACH | SIDD_NEGATIVE_POLARITY \
16 (SIDD_UWORD_OPS | SIDD_CMP_EQUAL_ANY | SIDD_NEGATIVE_POLARITY)
18 (SIDD_SWORD_OPS | SIDD_CMP_EQUAL_ORDERED \
19 | SIDD_MASKED_NEGATIVE_POLARITY | SIDD_UNIT_MASK)
30 int correct_flags
, l1
, l2
;
31 int flags
, cf
, zf
, sf
, of
, af
;
34 for (i
= 0; i
< NUM
*16; i
++)
40 for (i
= 0; i
< NUM
; i
++)
45 switch ((rand () % 4))
48 res
= _mm_cmpestrm (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL0
);
49 cf
= _mm_cmpestrc (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL0
);
50 zf
= _mm_cmpestrz (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL0
);
51 sf
= _mm_cmpestrs (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL0
);
52 of
= _mm_cmpestro (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL0
);
53 af
= _mm_cmpestra (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL0
);
54 correct
= cmp_em (&src1
.x
[i
], l1
, &src2
.x
[i
], l2
, IMM_VAL0
,
59 res
= _mm_cmpestrm (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL1
);
60 cf
= _mm_cmpestrc (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL1
);
61 zf
= _mm_cmpestrz (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL1
);
62 sf
= _mm_cmpestrs (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL1
);
63 of
= _mm_cmpestro (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL1
);
64 af
= _mm_cmpestra (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL1
);
65 correct
= cmp_em (&src1
.x
[i
], l1
, &src2
.x
[i
], l2
, IMM_VAL1
,
70 res
= _mm_cmpestrm (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL2
);
71 cf
= _mm_cmpestrc (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL2
);
72 zf
= _mm_cmpestrz (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL2
);
73 sf
= _mm_cmpestrs (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL2
);
74 of
= _mm_cmpestro (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL2
);
75 af
= _mm_cmpestra (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL2
);
76 correct
= cmp_em (&src1
.x
[i
], l1
, &src2
.x
[i
], l2
, IMM_VAL2
,
81 res
= _mm_cmpestrm (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL3
);
82 cf
= _mm_cmpestrc (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL3
);
83 zf
= _mm_cmpestrz (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL3
);
84 sf
= _mm_cmpestrs (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL3
);
85 of
= _mm_cmpestro (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL3
);
86 af
= _mm_cmpestra (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL3
);
87 correct
= cmp_em (&src1
.x
[i
], l1
, &src2
.x
[i
], l2
, IMM_VAL3
,
92 if (memcmp (&correct
, &res
, sizeof (res
)))
105 if (flags
!= correct_flags
106 || (af
&& (cf
|| zf
))
107 || (!af
&& !(cf
|| zf
)))