KUNPCKBW/KUNPCKWD/KUNPCKDQ—Unpack for Mask Registers Instruction Operand EncodingDescriptionUnpacks the lower 8/16/32 bits of the second and third operands (source operands) into the low part of the first operand (destination operand), starting from the low bytes. The result is zero-extended in the destination.OperationKUNPCKBWDEST[7:0] := SRC2[7:0]DEST[15:8] := SRC1[7:0]DEST[MAX_KL-1:16] := 0KUNPCKWDDEST[15:0] := SRC2[15:0]DEST[31:16] := SRC1[15:0]DEST[MAX_KL-1:32] := 0KUNPCKDQDEST[31:0] := SRC2[31:0]DEST[63:32] := SRC1[31:0]DEST[MAX_KL-1:64] := 0Intel C/C++ Compiler Intrinsic EquivalentKUNPCKBW __mmask16 _mm512_kunpackb(__mmask16 a, __mmask16 b);KUNPCKDQ __mmask64 _mm512_kunpackd(__mmask64 a, __mmask64 b);KUNPCKWD __mmask32 _mm512_kunpackw(__mmask32 a, __mmask32 b);Flags AffectedNoneSIMD Floating-Point ExceptionsNoneOther ExceptionsSee Table2-63, “TYPE K20 Exception Definition (VEX-Encoded OpMask Instructions w/o Memory Arg)”.Opcode/InstructionOp/En64/32 bit Mode SupportCPUID Feature FlagDescriptionVEX.L1.66.0F.W0 4B /rKUNPCKBW k1, k2, k3RVRV/VAVX512FUnpack 8-bit masks in k2 and k3 and write word result in k1.VEX.L1.0F.W0 4B /r KUNPCKWD k1, k2, k3RVRV/VAVX512BWUnpack 16-bit masks in k2 and k3 and write doubleword result in k1.VEX.L1.0F.W1 4B /r KUNPCKDQ k1, k2, k3RVRV/VAVX512BWUnpack 32-bit masks in k2 and k3 and write quadword result in k1.Op/EnOperand 1Operand 2Operand 3RVRModRM:reg (w)VEX.1vvv (r)ModRM:r/m (r, ModRM:[7:6] must be 11b)
This UNOFFICIAL reference was generated from the official Intel® 64 and IA-32 Architectures Software Developer’s Manual by a dumb script. There is no guarantee that some parts aren't mangled or broken and is distributed WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.