Opcode/ Instruction |
Op/En |
64/32 bit Mode Support |
CPUID Feature Flag |
Description |
VEX.L0.66.0F3A.W1 32 /r KSHIFTLW k1, k2, imm8 |
RRI |
V/V |
AVX512F |
Shift left 16 bits in k2 by immediate and write result in k1. |
VEX.L0.66.0F3A.W0 32 /r KSHIFTLB k1, k2, imm8 |
RRI |
V/V |
AVX512DQ |
Shift left 8 bits in k2 by immediate and write result in k1. |
VEX.L0.66.0F3A.W1 33 /r KSHIFTLQ k1, k2, imm8 |
RRI |
V/V |
AVX512BW |
Shift left 64 bits in k2 by immediate and write result in k1. |
VEX.L0.66.0F3A.W0 33 /r KSHIFTLD k1, k2, imm8 |
RRI |
V/V |
AVX512BW |
Shift left 32 bits in k2 by immediate and write result in k1. |
Op/En |
Operand 1 |
Operand 2 |
Operand 3 |
RRI |
ModRM:reg (w) |
ModRM:r/m (r, ModRM:[7:6] must be 11b) |
imm8 |
Shifts 8/16/32/64 bits in the second operand (source operand) left by the count specified in immediate byte and place the least significant 8/16/32/64 bits of the result in the destination operand. The higher bits of the destina- tion are zero-extended. The destination is set to zero if the count value is greater than 7 (for byte shift), 15 (for word shift), 31 (for doubleword shift) or 63 (for quadword shift).
COUNT := imm8[7:0] DEST[MAX_KL-1:0] := 0 IF COUNT <=15 THEN DEST[15:0] := SRC1[15:0] << COUNT; FI;
COUNT := imm8[7:0] DEST[MAX_KL-1:0] := 0 IF COUNT <=7 THEN DEST[7:0] := SRC1[7:0] << COUNT; FI;
COUNT := imm8[7:0] DEST[MAX_KL-1:0] := 0 IF COUNT <=63 DEST[63:0] := SRC1[63:0] << COUNT;THEN FI;
COUNT := imm8[7:0] DEST[MAX_KL-1:0] := 0 IF COUNT <=31 DEST[31:0] := SRC1[31:0] << COUNT;THEN FI;
Compiler auto generates KSHIFTLW when needed.
None.
None.
See Table 2-63, "TYPE K20 Exception Definition (VEX-Encoded OpMask Instructions w/o Memory Arg)."