MOVHPS - 移動高位壓縮單精度浮點值

操作碼

指令

說明

0F 16 /r

MOVHPS xmm, m64

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

0F 17 /r

MOVHPS m64, xmm

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

說明

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

操作

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

MOVHPD instruction for XMM to memory move:
DEST SRC[127-64] ;

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

MOVHPS __m128d _mm_loadh_pi ( __m128d a, __m64 *p) MOVHPS void _mm_storeh_pi (__m64 *p, __m128d 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 時進行未對齊的記憶體引用。