操作碼 |
指令 |
說明 |
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] ;
MOVHPS __m128d _mm_loadh_pi ( __m128d a, __m64 *p) MOVHPS void _mm_storeh_pi (__m64 *p, __m128d a)
無。
#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。
與“實地址模式”中的異常相同。
#PF(錯誤程式碼) - 頁錯誤。
#AC - 如果在目前特權級別為 3 時進行未對齊的記憶體引用。