Opcode |
Instruction |
64-Bit Mode |
Compat/ Leg Mode |
Description |
|
D9 E0 |
FCHS |
Valid |
Valid |
Complements sign of ST(0). |
Complements the sign bit of ST(0). This operation changes a positive value into a negative value of equal magni- tude or vice versa. The following table shows the results obtained when changing the sign of various classes of numbers.
ST(0) SRC |
ST(0) DEST |
|
- inf |
+ inf |
|
- F |
+ F |
|
- 0 |
+ 0 |
|
+ 0 |
- 0 |
|
+ F |
- F |
|
+ inf |
- inf |
|
NaN |
NaN |
*
F means finite floating-point value.
This instruction's operation is the same in non-64-bit modes and 64-bit mode.
SignBit(ST(0)) := NOT (SignBit(ST(0)));
|
C1 |
Set to 0. |
|
C0, C2, C3 |
Undefined. |
|
#IS |
Stack underflow occurred. |
|
#NM |
CR0.EM[bit 2] or CR0.TS[bit 3] = 1. |
|
#UD |
If the LOCK prefix is used. |
Same exceptions as in protected mode.
Same exceptions as in protected mode.
Same exceptions as in protected mode.
Same exceptions as in protected mode.