16 bit Assembly
ADC - Add with Carry
ADD - Add
AND - Bitwise AND
CALL - Call Routine
CLC - Clear Carry Flag
CLD - Clear Direction
CLI - Clear Interupt Flag
CMPS - Compare
CMP - Compare
DEC - Decrement
DIV - Divide
HLT - Halt
IDIV - Divide Signed
IMUL - Multiply Signed
INC - Increment
INS - Input
INT - Interupt
IN - Input
IRET - Interupt Return
JMP - Jump
J - Jump Conditional
LAHF - Load Flags
LDS - Load Far Pointer
LEA - Store Address
LES - Load Far Pointer
LFS - Load Far Pointer
LGS - Load Far Pointer
LODSB - LODSW - Load
LODS - Load
LOOP - Loop
LSS - Load Far Pointer
MOVSB - Move Far
MOVSW - Move Far
MOVS - Move
MOV - Move
MUL - Multiply
NEG - Negate
NOP - No Operation
NOT - Bitwise NOT
OR - Bitwise OR
OUTS - Output
OUT - Output
POP - Stack Retrieval
PUSH - Stack Store
RCL - Roll Left
RCR - Roll Right
REP - Repeat
RET - Return
ROL - Roll Left
ROR - Roll Right
SAHF - Save Flags
SAL - Shift Left
SAR - Shift Right
SBB - Subtract with Borrow
SCAS - Compare
SET - Set Condition
SHL - Shift Left
SHR - Shift Right
STC - Set Carry Flag
STD - Set Direction
STI - Set Interupt Flag
STOSB - STOSW - Store
STOS - Store
SUB - Subtract
TEST - Compare
XADD - Exchange and And
XCHG - Swap
XOR - Bitwise XOR
The TEST instruction AND's the operands, and discards the result.
The effect of the AND operation sets the Parity (PF), Sign (SF) and Zero (ZF) flags.
This command has 3 parts, Instruction, Register or memory address, then either a Register, Immediate value or a memory address.
Assembly
SampleDescription 16 bit Machine
CodeTEST AL, 0x30 ; 8 bit immediate to AL Register A8 30 TEST CL, 0x30 ; 8 bit immediate to 8 bit Register F6 C1 30 TEST AX, 0x3030 ; 16 bit immediate to AX Register A9 30 30 TEST CX, 0x3030 ; 16 bit immediate to a Register F7 C1 30 30 TEST [BX], 0x3030 ; 16 bit immediate to memory address F7 47 30 30 TEST [BX+2], 0x3030 ; 16 bit immediate to memory address
; with offsetF7 47 02 30 30 TEST [BX], AX ; 16 bit Register to memory address 85 47 TEST [BX+2], AX ; 16 bit Register to memory address
; with offset85 47 02 TEST AX, CX ; 16 bit Register to a Register 85 C1