Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Лаб2012 / 25366617.pdf
Скачиваний:
30
Добавлен:
02.02.2015
Размер:
2.7 Mб
Скачать

INSTRUCTION SET REFERENCE, A-M

HSUBPD: Packed Double-FP Horizontal Subtract

 

 

64-Bit

Compat/

 

Opcode

Instruction

Mode

Leg Mode

Description

66 0F 7D /r HSUBPD xmm1,

Valid

Valid

Horizontal subtract packed double-

 

xmm2/m128

 

 

precision floating-point values from

 

 

 

 

xmm2/m128 to xmm1.

 

 

 

 

 

Description

The HSUBPD instruction subtracts horizontally the packed DP FP numbers of both operands.

Subtracts the double-precision floating-point value in the high quadword of the destination operand from the low quadword of the destination operand and stores the result in the low quadword of the destination operand.

Subtracts the double-precision floating-point value in the high quadword of the source operand from the low quadword of the source operand and stores the result in the high quadword of the destination operand. See Figure 3-12.

+68%3' [PP [PP P

 

 

 

[PP

> @

> @

 

 

 

P

> @

> @

[PP

[PP P > @

 

5HVXOW

 

[PP > @ [PP > @

 

[PP P > @

 

[PP

> @

> @

 

 

 

20

Figure 3-12. HSUBPD: Packed Double-FP Horizontal Subtract

In 64-bit mode, use of the REX.R prefix permits this instruction to access additional registers (XMM8-XMM15).

3-432 Vol. 2A

HSUBPD: Packed Double-FP Horizontal Subtract

INSTRUCTION SET REFERENCE, A-M

Operation

xmm1[63:0] = xmm1[63:0] xmm1[127:64]; xmm1[127:64] = xmm2/m128[63:0] xmm2/m128[127:64];

Intel C/C++ Compiler Intrinsic Equivalent

HSUBPD __m128d _mm_hsub_pd(__m128d a, __m128d b)

Exceptions

When the source operand is a memory operand, the operand must be aligned on a 16-byte boundary or a general-protection exception (#GP) will be generated.

Numeric Exceptions

Overflow, Underflow, Invalid, Precision, Denormal.

Protected Mode Exceptions

#GP(0)

For an illegal memory operand effective address in the CS, DS, ES, FS or

 

GS segments.

 

If a memory operand is not aligned on a 16-byte boundary, regardless of

 

segment.

#SS(0)

For an illegal address in the SS segment.

#PF(fault-code)

For a page fault.

#NM

If CR0.TS[bit 3] = 1.

#XM

For an unmasked Streaming SIMD Extensions numeric exception

 

(CR4.OSXMMEXCPT[bit 10] = 1).

#UD

If CR0.EM[bit 2] = 1.

 

For an unmasked Streaming SIMD Extensions numeric exception

 

(CR4.OSXMMEXCPT[bit 10] = 0).

 

If CR4.OSFXSR[bit 9] = 0.

 

If CPUID.01H:ECX.SSE3[bit 0] = 0.

Real Address Mode Exceptions

GP(0)

If any part of the operand would lie outside of the effective address space

 

from 0 to 0FFFFH.

 

If a memory operand is not aligned on a 16-byte boundary, regardless of

 

segment.

#NM

If CR0.TS[bit 3] = 1.

HSUBPD: Packed Double-FP Horizontal Subtract

Vol. 2A 3-433

INSTRUCTION SET REFERENCE, A-M

#XM

For an unmasked Streaming SIMD Extensions numeric exception

 

(CR4.OSXMMEXCPT[bit 10] = 1).

#UD

If CR0.EM[bit 2] = 1.

 

For an unmasked Streaming SIMD Extensions numeric exception

 

(CR4.OSXMMEXCPT[bit 10] = 0).

 

If CR4.OSFXSR[bit 9] = 0.

 

If CPUID.01H:ECX.SSE3[bit 0] = 0.

Virtual 8086 Mode Exceptions

GP(0)

If any part of the operand would lie outside of the effective address space

 

from 0 to 0FFFFH.

 

If a memory operand is not aligned on a 16-byte boundary, regardless of

 

segment.

#NM

If CR0.TS[bit 3] = 1.

#XM

For an unmasked Streaming SIMD Extensions numeric exception

 

(CR4.OSXMMEXCPT[bit 10] = 1).

#UD

If CR0.EM[bit 2] = 1.

 

For an unmasked Streaming SIMD Extensions numeric exception

 

(CR4.OSXMMEXCPT[bit 10] = 0).

 

If CR4.OSFXSR[bit 9] = 0.

 

If CPUID.01H:ECX.SSE3[bit 0] = 0.

#PF(fault-code)

For a page fault.

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.

 

If memory operand is not aligned on a 16-byte boundary, regardless of

 

segment.

#PF(fault-code)

For a page fault.

#NM

If CR0.TS[bit 3] = 1.

#XM

If an unmasked SIMD floating-point exception and CR4.OSXM-

 

MEXCPT[bit 10] = 1.

3-434 Vol. 2A

HSUBPD: Packed Double-FP Horizontal Subtract

 

INSTRUCTION SET REFERENCE, A-M

#UD

If an unmasked SIMD floating-point exception and CR4.OSXM-

 

MEXCPT[bit 10] = 0.

 

If CR0.EM[bit 2] = 1.

 

If CR4.OSFXSR[bit 9] = 0.

 

If CPUID feature flag SSE3 is 0.

HSUBPD: Packed Double-FP Horizontal Subtract

Vol. 2A 3-435

Соседние файлы в папке Лаб2012