FCMOV
FCMOV is a floating point conditional move opcode of the Intel x86 architecture, first introduced in Pentium Pro processors. It copies the contents of one of the floating point stack register, depending on the contents of EFLAGS integer flag register, to the ST(0) (top of stack) register. There are 8 variants of the instruction selected by the condition codes that need be set for the instruction to perform the move.
Similar to the CMOV instruction, FCMOV allows some conditional operations to be performed without the usual branching overhead.[1] However, it has a higher latency than conditional branch instructions.[2] Therefore, it is most useful for simple yet unpredictable comparison or conditional operations, where it can provide substantial performance gains.
The instruction is usually used with the FCOMI instruction or the FCOM-FSTSW-SAHF idiom to set the relevant condition codes based on the result of a floating point comparison.
Variants
This table shows the variants of the FCMOV instructions.[1] The first operand is always the ST(0) register (equivalently, the top of the floating point stack). The Opcode column indicates a two-byte sequence where the second byte is a base value indicating the number of the floating point stack register to use for the second operand. Add the desired number to complete the corresponding opcode value.
| Opcode | Mnemonic | Meaning | Condition |
|---|---|---|---|
| DA C0+i | FCMOVB | Move if below | Carry flag set |
| DA C8+i | FCMOVE | Move if equal | Zero flag set |
| DA D0+i | FCMOVBE | Move if below or equal | Carry flag or Zero flag set |
| DA D8+i | FCMOVU | Move if unordered | Parity flag set |
| DB C0+i | FCMOVNB | Move if not below | Carry flag cleared |
| DB C8+i | FCMOVNE | Move if not equal | Zero flag cleared |
| DB D0+i | FCMOVNBE | Move if not below or equal | Carry flag and Zero flag cleared |
| DB D8+i | FCMOVNU | Move if not unordered | Parity flag cleared |
References
External links
Content Disclaimer
Informasi ini disarikan dari Wikipedia dan disajikan kembali untuk tujuan edukasi. Konten tersedia di bawah lisensi CC BY-SA 3.0. Kami tidak bertanggung jawab atas ketidakakuratan data yang bersumber dari kontribusi publik tersebut.
- The information displayed on this website is sourced in part or in whole from Wikipedia and has been adapted for the purpose of restating it. We strive to provide accurate and relevant information, however:
- There is no guarantee of absolute accuracy. Wikipedia is an open, collaborative project that can be edited by anyone, so information is subject to change.
- It is not intended to constitute professional advice. The content displayed is for informational and educational purposes only. For important decisions (e.g., medical, legal, or financial), please consult a professional.
- Content copyright. Wikipedia is licensed under the Creative Commons Attribution-ShareAlike License (CC BY-SA). This means that content may be reused with appropriate attribution and shared under a similar license.
- Responsible use. Any risk arising from the use of information from this website is entirely the responsibility of the user.