1 /* { dg-do run { target i?86-*-* x86_64-*-* } } */
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_MASKED_NEGATIVE_POLARITY | SIDD_UNIT_MASK)
34 for (i
= 0; i
< NUM
*16; i
++)
40 for (i
= 0; i
< NUM
; i
++)
48 res
= _mm_cmpestrm (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL0
);
49 correct
= cmp_em (&src1
.x
[i
], l1
, &src2
.x
[i
], l2
, IMM_VAL0
,
54 res
= _mm_cmpestrm (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL1
);
55 correct
= cmp_em (&src1
.x
[i
], l1
, &src2
.x
[i
], l2
, IMM_VAL1
,
60 res
= _mm_cmpestrm (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL2
);
61 correct
= cmp_em (&src1
.x
[i
], l1
, &src2
.x
[i
], l2
, IMM_VAL2
,
66 res
= _mm_cmpestrm (src1
.x
[i
], l1
, src2
.x
[i
], l2
, IMM_VAL3
);
67 correct
= cmp_em (&src1
.x
[i
], l1
, &src2
.x
[i
], l2
, IMM_VAL3
,
72 if (memcmp (&correct
, &res
, sizeof (res
)))