Opcode/Instruction | Op/En | 64/32-bit Mode | CPUID Feature Flag | Description |
---|---|---|---|---|
F2 0F 2C /r CVTTSD2SI r32, xmm/m64 |
RM | V/V | SSE2 | Convert one double-precision floating-point value from xmm/m64 to one signed doubleword integer in r32 using truncation. |
F2 REX.W 0F 2C /r CVTTSD2SI r64, xmm/m64 |
RM | V/N.E. | SSE2 | Convert one double precision floating-point value from xmm/m64 to one signedquadword integer in r64 using truncation. |
VEX.LIG.F2.0F.W0 2C /r VCVTTSD2SI r32, xmm1/m64 |
RM | V/V | AVX | Convert one double-precision floating-point value from xmm1/m64 to one signed doubleword integer in r32 using truncation. |
VEX.LIG.F2.0F.W1 2C /r VCVTTSD2SI r64, xmm1/m64 |
RM | V/N.E.1 | AVX | Convert one double precision floating-point value from xmm1/m64 to one signed quadword integer in r64 using truncation. |
NOTES:
1. Encoding the VEX prefix with VEX.W=1 in non-64-bit mode is ignored.
Op/En | Operand 1 | Operand 2 | Operand 3 | Operand 4 |
RM | ModRM:reg (w) | ModRM:r/m (r) | NA | NA |
Converts a double-precision floating-point value in the source operand (second operand) to a signed doubleword integer (or signed quadword integer if operand size is 64 bits) in the destination operand (first operand). The source operand can be an XMM register or a 64-bit memory location. The destination operand is a general purpose register. When the source operand is an XMM register, the double-precision floating-point value is contained in the low quadword of the register.
When a conversion is inexact, a truncated (round toward zero) result is returned. If a converted result is larger than the maximum signed doubleword integer, the floating point invalid exception is raised. If this exception is masked, the indefinite integer value (80000000H) is returned.
Legacy SSE instructions: In 64-bit mode, Use of the REX.W prefix promotes the instruction to 64-bit operation. See the summary chart at the beginning of this section for encoding data and limits.
Note: In VEX-encoded versions, VEX.vvvv is reserved and must be 1111b, otherwise instructions will #UD.
IF 64-Bit Mode and OperandSize = 64 THEN DEST[63:0] ← Convert_Double_Precision_Floating_Point_To_ Integer64_Truncate(SRC[63:0]); ELSE DEST[31:0] ← Convert_Double_Precision_Floating_Point_To_ Integer32_Truncate(SRC[63:0]); FI;
int _mm_cvttsd_si32(__m128d a)
__int64 _mm_cvttsd_si64(__m128d a)
Invalid, Precision.
See Exceptions Type 3; additionally
#UD | If VEX.vvvv ≠ 1111B. |