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 \
14 | SIDD_MOST_SIGNIFICANT)
16 (SIDD_UWORD_OPS | SIDD_CMP_EQUAL_ANY | SIDD_MASKED_NEGATIVE_POLARITY)
18 (SIDD_SWORD_OPS | SIDD_CMP_EQUAL_ORDERED \
19 | SIDD_MASKED_NEGATIVE_POLARITY | SIDD_MOST_SIGNIFICANT)
30 int res
, correct
, correct_flags
;
31 int flags
, cf
, zf
, sf
, of
, af
;
34 for (i
= 0; i
< NUM
*16; i
++)
40 for (i
= 0; i
< NUM
; i
++)
42 switch ((rand () % 4))
45 res
= _mm_cmpistri (src1
.x
[i
], src2
.x
[i
], IMM_VAL0
);
46 cf
= _mm_cmpistrc (src1
.x
[i
], src2
.x
[i
], IMM_VAL0
);
47 zf
= _mm_cmpistrz (src1
.x
[i
], src2
.x
[i
], IMM_VAL0
);
48 sf
= _mm_cmpistrs (src1
.x
[i
], src2
.x
[i
], IMM_VAL0
);
49 of
= _mm_cmpistro (src1
.x
[i
], src2
.x
[i
], IMM_VAL0
);
50 af
= _mm_cmpistra (src1
.x
[i
], src2
.x
[i
], IMM_VAL0
);
51 correct
= cmp_ii (&src1
.x
[i
], &src2
.x
[i
], IMM_VAL0
,
56 res
= _mm_cmpistri (src1
.x
[i
], src2
.x
[i
], IMM_VAL1
);
57 cf
= _mm_cmpistrc (src1
.x
[i
], src2
.x
[i
], IMM_VAL1
);
58 zf
= _mm_cmpistrz (src1
.x
[i
], src2
.x
[i
], IMM_VAL1
);
59 sf
= _mm_cmpistrs (src1
.x
[i
], src2
.x
[i
], IMM_VAL1
);
60 of
= _mm_cmpistro (src1
.x
[i
], src2
.x
[i
], IMM_VAL1
);
61 af
= _mm_cmpistra (src1
.x
[i
], src2
.x
[i
], IMM_VAL1
);
62 correct
= cmp_ii (&src1
.x
[i
], &src2
.x
[i
], IMM_VAL1
,
67 res
= _mm_cmpistri (src1
.x
[i
], src2
.x
[i
], IMM_VAL2
);
68 cf
= _mm_cmpistrc (src1
.x
[i
], src2
.x
[i
], IMM_VAL2
);
69 zf
= _mm_cmpistrz (src1
.x
[i
], src2
.x
[i
], IMM_VAL2
);
70 sf
= _mm_cmpistrs (src1
.x
[i
], src2
.x
[i
], IMM_VAL2
);
71 of
= _mm_cmpistro (src1
.x
[i
], src2
.x
[i
], IMM_VAL2
);
72 af
= _mm_cmpistra (src1
.x
[i
], src2
.x
[i
], IMM_VAL2
);
73 correct
= cmp_ii (&src1
.x
[i
], &src2
.x
[i
], IMM_VAL2
,
78 res
= _mm_cmpistri (src1
.x
[i
], src2
.x
[i
], IMM_VAL3
);
79 cf
= _mm_cmpistrc (src1
.x
[i
], src2
.x
[i
], IMM_VAL3
);
80 zf
= _mm_cmpistrz (src1
.x
[i
], src2
.x
[i
], IMM_VAL3
);
81 sf
= _mm_cmpistrs (src1
.x
[i
], src2
.x
[i
], IMM_VAL3
);
82 of
= _mm_cmpistro (src1
.x
[i
], src2
.x
[i
], IMM_VAL3
);
83 af
= _mm_cmpistra (src1
.x
[i
], src2
.x
[i
], IMM_VAL3
);
84 correct
= cmp_ii (&src1
.x
[i
], &src2
.x
[i
], IMM_VAL3
,
102 if (flags
!= correct_flags
103 || (af
&& (cf
|| zf
))
104 || (!af
&& !(cf
|| zf
)))