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_MASKED_NEGATIVE_POLARITY)
18 (SIDD_SWORD_OPS | SIDD_CMP_EQUAL_ORDERED \
19 | SIDD_POSITIVE_POLARITY | SIDD_UNIT_MASK)
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_cmpistrm (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_im (&src1.x[i], &src2.x[i], IMM_VAL0,
56 res = _mm_cmpistrm (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_im (&src1.x[i], &src2.x[i], IMM_VAL1,
67 res = _mm_cmpistrm (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_im (&src1.x[i], &src2.x[i], IMM_VAL2,
78 res = _mm_cmpistrm (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_im (&src1.x[i], &src2.x[i], IMM_VAL3,
89 if (memcmp (&correct, &res, sizeof (res)))
102 if (flags != correct_flags
103 || (af && (cf || zf))
104 || (!af && !(cf || zf)))