Difference between revisions of "Assembler:Commands:COMISS"

From Cheat Engine
Jump to navigation Jump to search
Line 23: Line 23:
 
=== Resulting Flag State ===
 
=== Resulting Flag State ===
 
{|width="85%" cellpadding="10%" cellpadding="5%" cellspacing="0" border="0"
 
{|width="85%" cellpadding="10%" cellpadding="5%" cellspacing="0" border="0"
 +
!align="left"|Parameters
 +
!style="width: 5%;background-color:white;" align="left"|ZF
 +
!style="width: 5%;background-color:white;" align="left"|CF
 +
!style="width: 70%;background-color:white;" align="left"|CF
 
|-
 
|-
 
|operand1 < operand2
 
|operand1 < operand2
|ZF = 0, PF = 0, CF = 1
+
|0
 +
|0
 +
|1
 
|-
 
|-
 
|operand1 = operand2
 
|operand1 = operand2
|ZF = 1, PF = 0, CF = 0
+
|1
 +
|0
 +
|0
 
|-
 
|-
 
|operand1 > operand2
 
|operand1 > operand2
|ZF = 0, PF = 0, CF = 0
+
|0
 +
|0
 +
|0
 
|-
 
|-
 
|unordered
 
|unordered
|ZF = 1, PF = 1, CF = 1
+
|1
 +
|1
 +
|1
 
|}
 
|}
  

Revision as of 15:53, 25 March 2022

command comiss operand1, operand2

Compares the single-precision floating-point (single-fp) value in the low doubleword of the first operand with the single-fp value in the low doubleword of the second operand and sets the status flags in the (E)FLAGS register.

The CF, ZF and PF flags are set according to the result (unordered, greater than, less than, or equal). The OF, SF and AF flags are set to 0. The unordered result is returned if either source operand is a NaN (QNaN or SNaN).


Command Parameters

Parameter Description
operand1 The first operand to compare. Must be a XMM register.
operand2 The second operand to compare. May be an XMM register or a 32 bit memory location

Resulting Flag State

Parameters ZF CF CF
operand1 < operand2 0 0 1
operand1 = operand2 1 0 0
operand1 > operand2 0 0 0
unordered 1 1 1

Examples

comiss xmm2,xmm5
comiss xmm2,[eax]
comiss xmm0,[00123ABC]

See also

External links