beautypg.com

Table 3-11 – Intel 253666-024US User Manual

Page 193

background image

Vol. 2A 3-147

INSTRUCTION SET REFERENCE, A-M

CMPSS—Compare Scalar Single-Precision Floating-Point Values

The greater-than relations not implemented in the processor require more than one
instruction to emulate in software and therefore should not be implemented as
pseudo-ops. (For these, the programmer should reverse the operands of the corre-
sponding less than relations and use move instructions to ensure that the mask is
moved to the correct destination register and that the source operand is left intact.)
In 64-bit mode, use of the REX.R prefix permits this instruction to access additional
registers (XMM8-XMM15).

Operation

CASE (COMPARISON PREDICATE) OF

0: OP

← EQ;

1: OP

← LT;

2: OP

← LE;

3: OP

← UNORD;

4: OP

← NEQ;

5: OP

← NLT;

6: OP

← NLE;

7: OP

← ORD;

DEFAULT: Reserved;

CMP0 ← DEST[31:0] OP SRC[31:0];

IF CMP0

=

TRUE

THEN DEST[31:0] ← FFFFFFFFH;

ELSE DEST[31:0] ← 00000000H; FI;

(* DEST[127:32] unchanged *)

Intel C/C++ Compiler Intrinsic Equivalents

CMPSS for equality

__m128 _mm_cmpeq_ss(__m128 a, __m128 b)

Table 3-11. Pseudo-Ops and CMPSS

Pseudo-Op

CMPSS Implementation

CMPEQSS xmm1, xmm2

CMPSS xmm1, xmm2, 0

CMPLTSS xmm1, xmm2

CMPSS xmm1, xmm2, 1

CMPLESS xmm1, xmm2

CMPSS xmm1, xmm2, 2

CMPUNORDSS xmm1, xmm2

CMPSS xmm1, xmm2, 3

CMPNEQSS xmm1, xmm2

CMPSS xmm1, xmm2, 4

CMPNLTSS xmm1, xmm2

CMPSS xmm1, xmm2, 5

CMPNLESS xmm1, xmm2

CMPSS xmm1, xmm2, 6

CMPORDSS xmm1, xmm2

CMPSS xmm1, xmm2, 7