Skip to content

KTESTW_KTESTB_KTESTQ_KTESTD

Henk-Jan Lebbink edited this page Jun 5, 2018 · 12 revisions

KTESTW / KTESTB / KTESTQ / KTESTD — Packed Bit Test Masks and Set Flags

Opcode/ Instruction Op En 64/32 bit Mode Support CPUID Feature Flag Description
VEX.L0.0F.W0 99 /r KTESTW k1, k2 RR V/V AVX512DQ Set ZF and CF depending on sign bit AND and ANDN of 16 bits mask register sources.
VEX.L0.66.0F.W0 99 /r KTESTB k1, k2 RR V/V AVX512DQ Set ZF and CF depending on sign bit AND and ANDN of 8 bits mask register sources.
VEX.L0.0F.W1 99 /r KTESTQ k1, k2 RR V/V AVX512BW Set ZF and CF depending on sign bit AND and ANDN of 64 bits mask register sources.
VEX.L0.66.0F.W1 99 /r KTESTD k1, k2 RR V/V AVX512BW Set ZF and CF depending on sign bit AND and ANDN of 32 bits mask register sources.

Instruction Operand Encoding

Op/En Operand 1 Operand2
RR ModRM:reg (r) ModRM:r/m (r, ModRM:[7:6] must be 11b)

Description

Performs a bitwise comparison of the bits of the first source operand and corresponding bits in the second source operand. If the AND operation produces all zeros, the ZF is set else the ZF is clear. If the bitwise AND operation of the inverted first source operand with the second source operand produces all zeros the CF is set else the CF is clear. Only the EFLAGS register is updated.

Note: In VEX-encoded versions, VEX.vvvv is reserved and must be 1111b, otherwise instructions will #UD.

Operation

KTESTW

TEMP[15:0] ← SRC2[15:0] AND SRC1[15:0]
IF (TEMP[15:0] = = 0)
    THEN ZF1;
    ELSE ZF0;
FI;
TEMP[15:0] ← SRC2[15:0] AND NOT SRC1[15:0]
IF (TEMP[15:0] = = 0)
    THEN CF1;
    ELSE CF0;
FI;
AFOFPFSF0;

KTESTB

TEMP[7:0] ← SRC2[7:0] AND SRC1[7:0]
IF (TEMP[7:0] = = 0)
    THEN ZF1;
    ELSE ZF0;
FI;
TEMP[7:0] ← SRC2[7:0] AND NOT SRC1[7:0]
IF (TEMP[7:0] = = 0)
    THEN CF1;
    ELSE CF0;
FI;
AFOFPFSF0;

KTESTQ

TEMP[63:0] ← SRC2[63:0] AND SRC1[63:0]
IF (TEMP[63:0] = = 0)
    THEN ZF1;
    ELSE ZF0;
FI;
TEMP[63:0] ← SRC2[63:0] AND NOT SRC1[63:0]
IF (TEMP[63:0] = = 0)
    THEN CF1;
    ELSE CF0;
FI;
AFOFPFSF0;

KTESTD

TEMP[31:0] ← SRC2[31:0] AND SRC1[31:0]
IF (TEMP[31:0] = = 0)
    THEN ZF1;
    ELSE ZF0;
FI;
TEMP[31:0] ← SRC2[31:0] AND NOT SRC1[31:0]
IF (TEMP[31:0] = = 0)
    THEN CF1;
    ELSE CF0;
FI;
AFOFPFSF0;

Intel C/C++ Compiler Intrinsic Equivalent

SIMD Floating-Point Exceptions

None

Other Exceptions

See Exceptions Type K20.


Source: Intel® Architecture Software Developer's Manual (May 2018)
Generated: 5-6-2018

Clone this wiki locally