03.03.2013 Views

Intel® Architecture Instruction Set Extensions Programming Reference

Intel® Architecture Instruction Set Extensions Programming Reference

Intel® Architecture Instruction Set Extensions Programming Reference

SHOW MORE
SHOW LESS

Create successful ePaper yourself

Turn your PDF publications into a flip-book with our unique Google optimized e-Paper software.

INSTRUCTION SET REFERENCE<br />

PBLENDVB — Variable Blend Packed Bytes<br />

Opcode/<br />

<strong>Instruction</strong><br />

Description<br />

<strong>Instruction</strong> Operand Encoding<br />

Conditionally copy byte elements from the second source operand and the first source operand depending on mask<br />

bits defined in the mask register operand. The mask bits are the most significant bit in each byte element of the<br />

mask register.<br />

Each byte element of the destination operand is copied from the corresponding byte element in the second source<br />

operand if a mask bit is "1", or the corresponding byte element in the first source operand if a mask bit is "0".<br />

The register assignment of the implicit third operand is defined to be the architectural register XMM0.<br />

128-bit Legacy SSE version: The first source operand and the destination operand is the same. Bits (255:128) of<br />

the corresponding YMM destination register remain unchanged. The mask register operand is implicitly defined to<br />

be the architectural register XMM0. An attempt to execute PBLENDVB with a VEX prefix will cause #UD.<br />

VEX.128 encoded version: The first source operand and the destination operand are XMM registers. The second<br />

source operand is an XMM register or 128-bit memory location. The mask operand is the third source register, and<br />

encoded in bits[7:4] of the immediate byte(imm8). The bits[3:0] of imm8 are ignored. In 32-bit mode, imm8[7] is<br />

ignored. The upper bits (255:128) of the corresponding YMM register (destination register) are zeroed.<br />

VEX.256 encoded version: The first source operand and the destination operand are YMM registers. The second<br />

source operand is an YMM register or 256-bit memory location. The third source register is an YMM register and<br />

encoded in bits[7:4] of the immediate byte(imm8). The bits[3:0] of imm8 are ignored. In 32-bit mode, imm8[7] is<br />

ignored.<br />

VPBLENDVB permits the mask to be any XMM or YMM register. In contrast, PBLENDVB treats XMM0 implicitly as the<br />

mask and do not support non-destructive destination operation. An attempt to execute PBLENDVB encoded with a<br />

VEX prefix will cause a #UD exception.<br />

Operation<br />

Op/<br />

En<br />

64/32<br />

-bit<br />

Mode<br />

VPBLENDVB (VEX.256 encoded version)<br />

MASK SRC3<br />

IF (MASK[7] == 1) THEN DEST[7:0] ? SRC2[7:0];<br />

ELSE DEST[7:0] SRC1[7:0];<br />

IF (MASK[15] == 1) THEN DEST[15:8] ? SRC2[15:8];<br />

ELSE DEST[15:8] SRC1[15:8];<br />

CPUID<br />

Feature<br />

Flag<br />

Description<br />

66 0F 38 10 /r A V/V SSE4_1 Select byte values from xmm1 and xmm2/m128 from mask<br />

PBLENDVB xmm1, xmm2/m128,<br />

<br />

specified in the high bit of each byte in XMM0 and store the values<br />

into xmm1.<br />

VEX.NDS.128.66.0F3A.W0 4C /r /is4 B V/V AVX Select byte values from xmm2 and xmm3/m128 from mask<br />

VPBLENDVB xmm1, xmm2,<br />

xmm3/m128, xmm4<br />

specified in the high bit of each byte in xmm4 and store the values<br />

into xmm1.<br />

VEX.NDS.256.66.0F3A.W0 4C /r /is4 B V/V AVX2 Select byte values from ymm2 and ymm3/m256 from mask<br />

VPBLENDVB ymm1, ymm2,<br />

ymm3/m256, ymm4<br />

specified in the high bit of each byte in ymm4 and store the values<br />

into ymm1.<br />

Op/En Operand 1 Operand 2 Operand 3 Operand 4<br />

A ModRM:reg (r, w) ModRM:r/m (r) NA NA<br />

B ModRM:reg (w) VEX.vvvv ModRM:r/m (r) imm[3:0](r)<br />

5-42 Ref. # 319433-014

Hooray! Your file is uploaded and ready to be published.

Saved successfully!

Ooh no, something went wrong!