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)))