FILD—Load Integer
Opcode |
Instruction |
64-Bit Mode |
Compat/Leg Mode |
Description |
DF /0 |
FILD m16int |
Valid |
Valid |
Push m16int onto the FPU register stack. |
DB /0 |
FILD m32int |
Valid |
Valid |
Push m32int onto the FPU register stack. |
DF /5 |
FILD m64int |
Valid |
Valid |
Push m64int onto the FPU register stack. |
Description
Converts the signed-integer source operand into double extended-precision floating-point format and pushes the value onto the FPU register stack. The source operand can be a word, doubleword, or quadword integer. It is loaded without rounding errors. The sign of the source operand is preserved.
This instruction’s operation is the same in non-64-bit modes and 64-bit mode.
Operation
TOP ← TOP − 1;
ST(0) ← ConvertToDoubleExtendedPrecisionFP(SRC);
FPU Flags Affected
C1 |
Set to 1 if stack overflow occurred; set to 0 otherwise. |
C0, C2, C3 |
Undefined. |
Floating-Point Exceptions
#IS |
Stack overflow occurred. |
Protected Mode Exceptions
#GP(0) |
If a memory operand effective address is outside the CS, DS, ES, FS, or GS segment limit. If the DS, ES, FS, or GS register contains a NULL segment selector. |
#SS(0) |
If a memory operand effective address is outside the SS segment limit. |
#NM |
CR0.EM[bit 2] or CR0.TS[bit 3] = 1. |
#PF(fault-code) |
If a page fault occurs. |
#AC(0) |
If alignment checking is enabled and an unaligned memory reference is made while the current privilege level is 3. |
#UD |
If the LOCK prefix is used. |
Real-Address Mode Exceptions
#GP |
If a memory operand effective address is outside the CS, DS, ES, FS, or GS segment limit. |
#SS |
If a memory operand effective address is outside the SS segment limit. |
#NM |
CR0.EM[bit 2] or CR0.TS[bit 3] = 1. |
#UD |
If the LOCK prefix is used. |
Virtual-8086 Mode Exceptions
#GP(0) |
If a memory operand effective address is outside the CS, DS, ES, FS, or GS segment limit. |
#SS(0) |
If a memory operand effective address is outside the SS segment limit. |
#NM |
CR0.EM[bit 2] or CR0.TS[bit 3] = 1. |
#PF(fault-code) |
If a page fault occurs. |
#AC(0) |
If alignment checking is enabled and an unaligned memory reference is made. |
#UD |
If the LOCK prefix is used. |
Compatibility Mode Exceptions
Same exceptions as in protected mode.
64-Bit Mode Exceptions
#SS(0) |
If a memory address referencing the SS segment is in a non-canonical form. |
#GP(0) |
If the memory address is in a non-canonical form. |
#NM |
CR0.EM[bit 2] or CR0.TS[bit 3] = 1. |
#MF |
If there is a pending x87 FPU exception. |
#PF(fault-code) |
If a page fault occurs. |
#AC(0) |
If alignment checking is enabled and an unaligned memory reference is made while the current privilege level is 3. |
#UD |
If the LOCK prefix is used. |