MOVLPS - 移動低位壓縮單精度浮點值

操作碼

指令

說明

0F 12 /r

MOVLPS xmm, m64

將兩個壓縮單精度浮點值從 m64 移到 xmm 的低位四字。

0F 13 /r

MOVLPS m64, xmm

將兩個壓縮單精度浮點值從 xmm 的低位四字移到 m64

說明

將兩個壓縮單精度浮點值從源運算元(第二個運算元)移到目標運算元(第一個運算元)。源運算元與目標運算元可以是 XMM 暫存器或 64 位記憶體位置。此指令可用於在 XMM 暫存器的低位四字與記憶體之間移動兩個單精度浮點值。它不能用於暫存器之間或記憶體之間的移動。目標運算元是 XMM 暫存器時,暫存器的高位四字保持不變。

操作

MOVLPD instruction for memory to XMM move:
DEST[63-0] SRC ;
* DEST[127-64] unchanged *;

MOVLPD instruction for XMM to memory move:
DEST SRC[63-0] ;

英特爾(R) C++ 編譯器等價內部函式

MOVLPS __m128 _mm_loadl_pi ( __m128 a, __m64 *p) MOVLPS void _mm_storel_pi (__m64 *p, __m128 a)

SIMD 浮點異常

無。

保護模式異常

#GP(0) - CS、DS、ES、FS 或 GS 段中的記憶體運算元有效地址非法。

#SS(0) - SS 段中的地址非法。

#PF(錯誤程式碼) - 頁錯誤。

#NM - 如果 CR0 中的 TS 設定為 1。

#UD - 如果 CR0 中的 EM 設定為 1。如果 CR4 中的 OSFXSR 是 0。如果 CPUID 功能標誌 SSE 是 0。#AC - 未對齊的記憶體引用。要啟用 #AC 異常,必須滿足三個條件(CR0.AM 設定為 1;EFLAGS.AC 設定為 1;目前的 CPL 是 3)。

實地址模式異常

中斷 13 - 如果運算元的任何部分出現在從 0 到 0FFFFH 的有效地址空間之外。

#NM - 如果 CR0 中的 TS 設定為 1。

#UD - 如果 CR0 中的 EM 設定為 1。如果 CR4 中的 OSFXSR 是 0。如果 CPUID 功能標誌 SSE 是 0。

虛 8086 模式異常

與“實地址模式”中的異常相同。

#PF(錯誤程式碼) - 頁錯誤。

#AC - 如果在目前特權級別為 3 時進行未對齊的記憶體引用。