

## MNEMONIC INDEX

| <u>Mnemonic</u> | <u>Page</u> | <u>Mnemonic</u> | <u>Page</u> | <u>Mnemonic</u> | <u>Page</u> |
|-----------------|-------------|-----------------|-------------|-----------------|-------------|
| AAA             | 6           | JG              | 15          | MOV             | 3           |
| AAD             | 8           | JGE             | 14          | MOVS            | 12          |
| AAM             | 8           | JL              | 14          | MUL             | 8           |
| AAS             | 8           | JLE             | 14          | NEG             | 7           |
| ADC             | 6           | JMP             | 13          | NOP             | 17          |
| ADD             | 5           | JNA             | 14          | NOT             | 9           |
| AND             | 10          | JNAE            | 14          | OR              | 11          |
| CALL            | 12          | JNB             | 15          | OUT             | 4           |
| CBW             | 9           | JNBE            | 15          | POP             | 4           |
| CLC             | 17          | JNE             | 14          | POPF            | 5           |
| CLD             | 17          | JNG             | 14          | PUSH            | 3           |
| CLI             | 17          | JNGE            | 14          | PUSHF           | 5           |
| CMC             | 17          | JNL             | 14          | RCL             | 10          |
| CMP             | 7           | JNLE            | 16          | RCR             | 10          |
| CMPS            | 12          | JNO             | 15          | REP             | 11          |
| CWD             | 9           | JNP             | 15          | RET             | 13          |
| DAA             | 6           | JNS             | 15          | ROL             | 9           |
| DAS             | 8           | JNZ             | 14          | ROR             | 10          |
| DEC             | 7           | JO              | 14          | SAHF            | 5           |
| DIV             | 8           | JP              | 14          | SAL             | 9           |
| ESC             | 17          | JPE             | 14          | SAR             | 9           |
| HLT             | 17          | JPO             | 15          | SBB             | 7           |
| IDIV            | 8           | JS              | 14          | SCAS            | 12          |
| IMUL            | 8           | JZ              | 13          | SHL             | 9           |
| IN              | 4           | LAHF            | 5           | SHR             | 9           |
| INC             | 6           | LDS             | 5           | STC             | 17          |
| INT             | 16          | LEA             | 5           | STD             | 17          |
| INTO            | 16          | LES             | 5           | STI             | 17          |
| IRET            | 16          | LOCK            | 17          | STOS            | 12          |
| JA              | 15          | LODS            | 12          | SUB             | 6           |
| JAE             | 15          | LOOP            | 15          | TEST            | 10          |
| JB              | 14          | LOOPE           | 15          | WAIT            | 17          |
| JBE             | 14          | LOOPNE          | 15          | XCHG            | 4           |
| JCXZ            | 16          | LOOPNZ          | 15          | XLAT            | 5           |
| JE              | 13          | LOOPZ           | 15          | XOR             | 11          |



## MCS-86™ ASSEMBLY LANGUAGE REFERENCE GUIDE

Mnemonics © Intel, 1978.  
PROGRAMMING LANGUAGE SOFTWARE  
Printed in U.S.A.  
1084/2K/0386/PTW/AD

October 1978

©Intel Corporation 1978  
9800749-1

# 8086 REGISTER MODEL



Instructions which reference the flag register file as a 16-bit object use the symbol FLAGS to represent the file:



X = Don't Care

AF: AUXILIARY CARRY — BCD  
 CF: CARRY FLAG  
 PF: PARITY FLAG  
 SF: SIGN FLAG  
 ZF: ZERO FLAG

DF: DIRECTION FLAG (STRINGS)  
 IF: INTERRUPT ENABLE FLAG  
 OF: OVERFLOW FLAG ( $CF \oplus SF$ )  
 TF: TRAP — SINGLE STEP FLAG

## OPERAND SUMMARY

"reg" field Bit Assignments:

| 16-Bit (w = 1) | 8-Bit (w = 0) | Segment |
|----------------|---------------|---------|
| 000 AX         | 000 AL        | 00 ES   |
| 001 CX         | 001 CL        | 01 CS   |
| 010 DX         | 010 DL        | 10 SS   |
| 011 BX         | 011 BL        | 11 DS   |
| 100 SP         | 100 AH        |         |
| 101 BP         | 101 CH        |         |
| 110 SI         | 110 DH        |         |
| 111 DI         | 111 BH        |         |

## SECOND INSTRUCTION BYTE SUMMARY

|     |                                                               |     |
|-----|---------------------------------------------------------------|-----|
| mod | xxx                                                           | r/m |
| mod | Displacement                                                  |     |
| 00  | DISP = 0°, disp-low and disp-high are absent                  |     |
| 01  | DISP = disp-low sign-extended to 16-bits, disp-high is absent |     |
| 10  | DISP = disp-high: disp-low                                    |     |
| 11  | r/m is treated as a "reg" field                               |     |
| r/m | Operand Address                                               |     |
| 000 | (BX) + (SI) + DISP                                            |     |
| 001 | (BX) + (DI) + DISP                                            |     |
| 010 | (BP) + (SI) + DISP                                            |     |
| 011 | (BP) + (DI) + DISP                                            |     |
| 100 | (SI) + DISP                                                   |     |
| 101 | (DI) + DISP                                                   |     |
| 110 | (BP) + DISP*                                                  |     |
| 111 | (BX) + DISP                                                   |     |

DISP follows 2nd byte of instruction (before data if required).

\*except if mod = 00 and r/m = 110 then EA = disp-high: disp-low.

### Operand Address (EA) Timing (clocks):

Add 4 clocks for word operands at ODD ADDRESSES.

Immed Offset = 6

Base (BX, BP, SI, DI) = 5

Base + DISP = 9

Base + Index (BP + DI, BX + SI) = 7

Base + Index (BP + SI, BX + DI) = 8

Base + Index (BP + DI, BX + SI) + DISP = 11

Base + Index (BP + SI, BX + DI) + DISP = 12

## ASSEMBLER DIRECTIVES

Symbol Definition:

EQU  
LABEL  
PURGE

Memory Reservation and Data Definition:

DB  
DW  
DD  
RECORD

Location Counter and Segmentation Control:

SEGMENT/ENDS  
ORG  
GROUP  
ASSUME  
PROC/ENDP  
CODEMACRO/ENDM

Program Linkage:

NAME  
PUBLIC  
EXTRN  
END

## PROCESSOR RESET REGISTER INITIALIZATION

Flags = OOOOH [ (to disable interrupts and single-stepping)

CS = FFFFH ] IP = OOOOH [ (to begin execution at FFFFOH)

DS = OOOOH  
SS = OOOOH  
ES = OOOOH

No other registers are acted upon during reset.

## MCS-86™ RESERVED LOCATIONS

### Reserved Memory Locations

Intel Corporation reserves the use of memory locations FFFFOH through FFFFFH (with the exception of FFFFOH - FFFF5H for JMP instr.) for Intel hardware and software products. If you use these locations for some other purpose, you may preclude compatibility of your system with certain of these products.

### Reserved Input/Output Locations

Intel Corporation reserves the use of input/output locations F8H through FFH for Intel hardware and software products. Users who wish to maintain compatibility with present and future Intel products should not use these locations.

### Reserved Interrupt Locations

Intel Corporation reserves the use of interrupts 0-31 (locations 00H through 7FH) for Intel hardware and software products. Users who wish to maintain compatibility with present and future Intel products should not use these locations.

Interrupts 0 through 4 (00H-13H) currently have dedicated hardware functions as defined below.

| Interrupt | Location | Function                       |
|-----------|----------|--------------------------------|
| 0         | 00H-03H  | Divide by zero                 |
| 1         | 04H-07H  | Single step                    |
| 2         | 08H-0BH  | Non-maskable interrupt         |
| 3         | 0CH-0FH  | One-byte interrupt instruction |
| 4         | 10H-13H  | Interrupt on overflow          |

### INTERRUPT POINTER TABLE



# 8086 INSTRUCTION

|   | Hi                | Lo              | 0              | 1               | 2              | 3              | 4              | 5              | 6           | 7           |
|---|-------------------|-----------------|----------------|-----------------|----------------|----------------|----------------|----------------|-------------|-------------|
| 0 |                   |                 | ADD<br>b,f,r/m | ADD<br>w,f,r/m  | ADD<br>b,t,r/m | ADD<br>w,t,r/m | ADD<br>b,ia    | ADD<br>w,ia    | PUSH<br>ES  | POP<br>ES   |
| 1 |                   |                 | ADC<br>b,f,r/m | ADC<br>w,f,r/m  | ADC<br>b,t,r/m | ADC<br>w,t,r/m | ADC<br>b,i     | ADC<br>w,i     | PUSH<br>SS  | POP<br>SS   |
| 2 |                   |                 | AND<br>b,f,r/m | AND<br>w,f,r/m  | AND<br>b,t,r/m | AND<br>w,t,r/m | AND<br>b,i     | AND<br>w,i     | SEG<br>=ES  | DAA         |
| 3 |                   |                 | XOR<br>b,f,r/m | XOR<br>w,f,r/m  | XOR<br>b,t,r/m | XOR<br>w,t,r/m | XOR<br>b,i     | XOR<br>w,i     | SEG<br>=SS  | AAA         |
| 4 |                   |                 | INC<br>AX      | INC<br>CX       | INC<br>DX      | INC<br>BX      | INC<br>SP      | INC<br>BP      | INC<br>SI   | INC<br>DI   |
| 5 |                   |                 | PUSH<br>AX     | PUSH<br>CX      | PUSH<br>DX     | PUSH<br>BX     | PUSH<br>SP     | PUSH<br>BP     | PUSH<br>SI  | PUSH<br>DI  |
| 6 |                   |                 |                |                 |                |                |                |                |             |             |
| 7 |                   |                 | JO             | JNO             | JB/<br>JNAE    | JNB/<br>JAE    | JE/<br>JZ      | JNE/<br>JNZ    | JBE/<br>JNA | JNBE/<br>JA |
| 8 | Immed<br>b,r/m    | Immed<br>w,r/m  | Immed<br>b,r/m | Immed<br>is,r/m | TEST<br>b,r/m  | TEST<br>w,r/m  | XCHG<br>b,r/m  | XCHG<br>w,r/m  |             |             |
| 9 | NOP               | XCHG<br>CX      | XCHG<br>DX     | XCHG<br>BX      | XCHG<br>SP     | XCHG<br>BP     | XCHG<br>SI     | XCHG<br>DI     |             |             |
| A | MOV<br>m → AL     | MOV<br>m → AX   | MOV<br>AL → m  | MOV<br>AX → m   | MOVS<br>b      | MOVS<br>w      | CMPS<br>b      | CMPS<br>w      |             |             |
| B | MOV<br>i → AL     | MOV<br>i → CL   | MOV<br>i → DL  | MOV<br>i → AH   | MOV<br>i → CH  | MOV<br>i → DH  | MOV<br>i → BH  |                |             |             |
| C |                   |                 | RET<br>(i+SP)  | RET             | LES            | LDS            | MOV<br>b,i/r/m | MOV<br>w,i/r/m |             |             |
| D | Shift<br>b        | Shift<br>w      | Shift<br>b,v   | Shift<br>w,v    | AAM            | AAD            |                |                | XLAT        |             |
| E | LOOPNZ/<br>LOOPNE | LOOPZ/<br>LOOPE | LOOP           | JCXZ            | IN<br>b        | IN<br>w        | OUT<br>b       | OUT<br>w       |             |             |
| F | LOCK              |                 | REP<br>z       | HLT             | CMC            | Grp 1<br>b,r/m | Grp 1<br>w,r/m |                |             |             |

b = byte operation  
d = direct  
f = from CPU reg  
i = immediate  
ia = immmed. to accum.  
id = indirect  
is = immmed. byte, sign ext.  
l = long ie. intersegment

m = memory  
r/m = EA is second byte  
si = short intrasegment  
sr = segment register  
t = to CPU reg  
v = variable  
w = word operation  
z = zero

## SET MATRIX

|   | Hi | Lo | 8              | 9              | A               | B              | C               | D             | E               | F              |
|---|----|----|----------------|----------------|-----------------|----------------|-----------------|---------------|-----------------|----------------|
| 0 |    |    | OR<br>b,f,r/m  | OR<br>w,f,r/m  | OR<br>b,t,r/m   | OR<br>w,t,r/m  | OR<br>b,i       | OR<br>w,i     | PUSH<br>CS      |                |
| 1 |    |    | SBB<br>b,f,r/m | SBB<br>w,f,r/m | SBB<br>b,t,r/m  | SBB<br>w,t,r/m | SBB<br>b,i      | SBB<br>w,i    | PUSH<br>DS      | POP<br>DS      |
| 2 |    |    | SUB<br>b,f,r/m | SUB<br>w,f,r/m | SUB<br>b,t,r/m  | SUB<br>w,t,r/m | SUB<br>b,i      | SUB<br>w,i    | SEG<br>CS       | DAS            |
| 3 |    |    | CMP<br>b,f,r/m | CMP<br>w,f,r/m | CMP<br>b,t,r/m  | CMP<br>w,t,r/m | CMP<br>b,i      | CMP<br>w,i    | SEG<br>DS       | AAS            |
| 4 |    |    | DEC<br>AX      | DEC<br>CX      | DEC<br>DX       | DEC<br>BX      | DEC<br>SP       | DEC<br>BP     | DEC<br>SI       | DEC<br>DI      |
| 5 |    |    | POP<br>AX      | POP<br>CX      | POP<br>DX       | POP<br>BX      | POP<br>SP       | POP<br>BP     | POP<br>SI       | POP<br>DI      |
| 6 |    |    |                |                |                 |                |                 |               |                 |                |
| 7 |    |    | JS             | JNS            | JP/<br>JPE      | JNP/<br>JPO    | JL/<br>JNGE     | JNL/<br>JGE   | JLE/<br>JNG     | JNLE/<br>JG    |
| 8 |    |    | MOV<br>b,f,r/m | MOV<br>w,f,r/m | MOV<br>b,t,r/m  | MOV<br>w,t,r/m | MOV<br>sr,t,r/m | LEA           | MOV<br>sr,f,r/m | POP<br>r/m     |
| 9 |    |    | CBW            | CWD            | CALL<br>I,d     | WAIT           | PUSHF           | POPF          | SAHF            | LAHF           |
| A |    |    | TEST<br>b,i    | TEST<br>w,i    | STOS<br>b       | STOS<br>w      | LODS<br>b       | LODS<br>w     | SCAS<br>b       | SCAS<br>w      |
| B |    |    | MOV<br>i → AX  | MOV<br>i → CX  | MOV<br>i → DX   | MOV<br>i → BX  | MOV<br>i → SP   | MOV<br>i → BP | MOV<br>i → SI   | MOV<br>i → DI  |
| C |    |    |                |                | RET<br>I,(i+SP) | RET<br>I       | INT<br>Type 3   | INT<br>(Any)  | INTO            | IRET           |
| D |    |    | ESC<br>0       | ESC<br>1       | ESC<br>2        | ESC<br>3       | ESC<br>4        | ESC<br>5      | ESC<br>6        | ESC<br>7       |
| E |    |    | CALL<br>d      | JMP<br>d       | JMP<br>I,d      | JMP<br>si,d    | IN<br>v,b       | IN<br>v,w     | OUT<br>v,b      | OUT<br>v,w     |
| F |    |    | CLC            | STC            | CLI             | STI            | CLD             | STD           | Grp 2<br>b,r/m  | Grp 2<br>w,r/m |

where ████

|           |      |     |             |              |            |             |      |      |
|-----------|------|-----|-------------|--------------|------------|-------------|------|------|
| mod █ r/m | 000  | 001 | 010         | 011          | 100        | 101         | 110  | 111  |
| Immed     | ADD  | OR  | ADC         | SBB          | AND        | SUB         | XOR  | CMP  |
| Shift     | ROL  | ROR | RCL         | RCR          | SHL/SAL    | SHR         | —    | SAR  |
| Grp 1     | TEST | —   | NOT         | NEG          | MUL        | IMUL        | DIV  | IDIV |
| Grp 2     | INC  | DEC | CALL<br>I,d | CALL<br>I,id | JMP<br>I,d | JMP<br>I,id | PUSH | —    |

## MEMORY SEGMENTATION MODEL



## SEGMENT OVERRIDE PREFIX

**0 0 1 reg 1 1 0**

Timing: 2 clocks

## USE OF SEGMENT OVERRIDE

| Operand Register                      | Default | With Override Prefix |
|---------------------------------------|---------|----------------------|
| IP (code address)                     | CS      | Never                |
| SP (stack address)                    | SS      | Never                |
| BP (stack address or stack marker)    | SS      | BP + DS or ES, or CS |
| SI or DI (not incl. strings)          | DS      | ES, SS, or CS        |
| SI (implicit source addr for strings) | DS      | ES, SS, or CS        |
| DI (implicit dest addr for strings)   | ES      | Never                |

## DATA TRANSFER

**MOV = Move**

Register/memory to/from register

|                 |     |     |     |
|-----------------|-----|-----|-----|
| 1 0 0 0 1 0 d w | mod | reg | r/m |
|-----------------|-----|-----|-----|

Timing (clocks): register to register  
memory to register  
register to memory 2  
8+EA  
9+EA

Immediate to register/memory

|                 |     |       |     |      |             |
|-----------------|-----|-------|-----|------|-------------|
| 1 1 0 0 0 1 1 w | mod | 0 0 0 | r/m | data | data if w=1 |
|-----------------|-----|-------|-----|------|-------------|

Timing: 10+EA clocks

Immediate to register

|           |     |      |             |
|-----------|-----|------|-------------|
| 1 0 1 1 w | reg | data | data if w=1 |
|-----------|-----|------|-------------|

Timing: 4 clocks

Memory to accumulator

|               |          |           |
|---------------|----------|-----------|
| 1 0 1 0 0 0 w | addr-low | addr-high |
|---------------|----------|-----------|

Timing: 10 clocks

Accumulator to memory

|               |          |           |
|---------------|----------|-----------|
| 1 0 1 0 0 1 w | addr-low | addr-high |
|---------------|----------|-----------|

Timing: 10 clocks

Register/memory to segment register

|                 |       |     |     |
|-----------------|-------|-----|-----|
| 1 0 0 0 1 1 1 0 | mod 0 | reg | r/m |
|-----------------|-------|-----|-----|

Timing (clocks): register to register  
memory to register 2  
8+EA

Segment register to register/memory

|                 |       |     |     |
|-----------------|-------|-----|-----|
| 1 0 0 0 1 1 0 0 | mod 0 | reg | r/m |
|-----------------|-------|-----|-----|

Timing (clocks): register to register  
register to memory 2  
9+EA

**PUSH = Push**

Register/memory

|                 |           |     |
|-----------------|-----------|-----|
| 1 1 1 1 1 1 1 1 | mod 1 1 0 | r/m |
|-----------------|-----------|-----|

Timing (clocks): register  
memory 10  
16+EA

Register

|           |     |
|-----------|-----|
| 0 1 0 1 0 | reg |
|-----------|-----|

Timing: 10 clocks

(Continued on following page)

Segment register

0 0 0 reg 1 1 0

Timing: 10 clocks

**POP** = Pop

Register/memory

1 0 0 0 1 1 1 1 mod 0 0 0 r/m

Timing (clocks): register  
memory

8  
17+EA

Register

0 1 0 1 1 reg

Timing: 8 clocks

Segment register

0 0 0 reg 1 1 1

Timing: 8 clocks

**XCHG** = Exchange

Register/memory with register

1 0 0 0 0 1 1 w mod reg r/m

Timing (clocks): register with register  
memory with register

4  
17+EA

Register with accumulator

1 0 0 1 0 reg

Timing: 3 clocks

**IN** = Input to AL/AX from

Fixed port

1 1 1 0 0 1 0 w port

Timing: 10 clocks

Variable port (DX)

1 1 1 0 1 1 0 w

Timing: 8 clocks

**OUT** = Output from AL/AX to

Fixed port

1 1 1 0 0 1 1 w port

Timing: 10 clocks

Variable port (DX)

1 1 1 0 1 1 1 w

Timing: 8 clocks

**XLAT** = Translate byte to AL

1 1 0 1 0 1 1 1

Timing: 11 clocks

**LEA** = Load EA to register

1 0 0 0 1 1 0 1 mod reg r/m

Timing: 2+EA clocks

**LDS** = Load pointer to DS

1 1 0 0 0 1 0 1 mod reg r/m

Timing: 16+EA clocks

**LES** = Load pointer to ES

1 1 0 0 0 1 0 0 mod reg r/m

Timing: 16+EA clocks

**LAHF** = Load AH with flags

1 0 0 1 1 1 1 1

Timing: 4 clocks

**SAHF** = Store AH into flags

1 0 0 1 1 1 1 0

Timing: 4 clocks

**PUSHF** = Push flags

1 0 0 1 1 1 0 0

Timing: 10 clocks

**POPF** = Pop flags

1 0 0 1 1 1 0 1

Timing: 8 clocks

## ARITHMETIC

**ADD** = Add

Reg./memory with register to either

0 0 0 0 0 d w mod reg r/m

Timing (clocks): register to register 3  
memory to register 9+EA  
register to memory 16+EA

Immediate to register/memory

1 0 0 0 0 s w mod 0 0 0 r/m data data if s:w=01

Timing (clocks): immediate to register 4  
immediate to memory 17+EA

### Immediate to accumulator

|                 |      |             |
|-----------------|------|-------------|
| 0 0 0 0 0 1 0 w | data | data if w=1 |
|-----------------|------|-------------|

Timing: 4 clocks

### ADC = Add with carry

Reg./memory with register to either

|                 |             |
|-----------------|-------------|
| 0 0 0 1 0 0 d w | mod reg r/m |
|-----------------|-------------|

Timing (clocks):    register to register                          3  
                        memory to register                              9+EA  
                        register to memory                              16+EA

### Immediate to register/memory

|                 |               |      |                |
|-----------------|---------------|------|----------------|
| 1 0 0 0 0 0 s w | mod 0 1 0 r/m | data | data if s:w=01 |
|-----------------|---------------|------|----------------|

Timing (clocks):    immediate to register                          4  
                        immediate to memory                              17+EA

### Immediate to accumulator

|                 |      |             |
|-----------------|------|-------------|
| 0 0 0 1 0 1 0 w | data | data if w=1 |
|-----------------|------|-------------|

Timing: 4 clocks

### INC = Increment

Register/memory

|                 |               |
|-----------------|---------------|
| 1 1 1 1 1 1 1 w | mod 0 0 0 r/m |
|-----------------|---------------|

Timing (clocks):    register                                          2  
                        memory                                              15+EA

### Register

|               |
|---------------|
| 0 1 0 0 0 reg |
|---------------|

Timing: 2 clocks

### AAA = ASCII adjust for add

|                 |
|-----------------|
| 0 0 1 1 0 1 1 1 |
|-----------------|

Timing: 4 clocks

### DAA = Decimal adjust for add

|                 |
|-----------------|
| 0 0 1 0 0 1 1 1 |
|-----------------|

Timing: 4 clocks

### SUB = Subtract

Reg./memory and register to either

|                 |             |
|-----------------|-------------|
| 0 0 1 0 1 0 d w | mod reg r/m |
|-----------------|-------------|

Timing (clocks):    register from register                          3  
                        memory from register                              9+EA  
                        register from memory                              16+EA

### Immediate from register/memory

|               |               |      |                |
|---------------|---------------|------|----------------|
| 1 0 0 0 0 s w | mod 1 0 1 r/m | data | data if s:w=01 |
|---------------|---------------|------|----------------|

Timing (clocks):    immediate from register                          4  
                        immediate from memory                            17+EA

### Immediate from accumulator

|                 |      |             |
|-----------------|------|-------------|
| 0 0 1 0 1 1 0 w | data | data if w=1 |
|-----------------|------|-------------|

Timing: 4 clocks

### SBB = Subtract with borrow

Reg./memory and register to either

|                 |             |
|-----------------|-------------|
| 0 0 0 1 1 0 d w | mod reg r/m |
|-----------------|-------------|

Timing (clocks):    register from register                          3  
                        memory from register                              9+EA  
                        register from memory                              16+EA

### Immediate from register/memory

|               |               |      |                |
|---------------|---------------|------|----------------|
| 1 0 0 0 0 s w | mod 0 1 1 r/m | data | data if s:w=01 |
|---------------|---------------|------|----------------|

Timing (clocks):    immediate from register                          4  
                        immediate from memory                            17+EA

### Immediate from accumulator

|                 |      |             |
|-----------------|------|-------------|
| 0 0 0 1 1 1 0 w | data | data if w=1 |
|-----------------|------|-------------|

Timing: 4 clocks

### DEC = Decrement

Register/memory

|                 |               |
|-----------------|---------------|
| 1 1 1 1 1 1 1 w | mod 0 0 1 r/m |
|-----------------|---------------|

Timing (clocks):    register                                          2  
                        memory                                              15+EA

### Register

|               |
|---------------|
| 0 1 0 0 1 reg |
|---------------|

Timing: 2 clocks

### NEG = Change sign

|                 |               |
|-----------------|---------------|
| 1 1 1 1 0 1 1 w | mod 0 1 1 r/m |
|-----------------|---------------|

Timing (clocks):    register                                          3  
                        memory                                              16+EA

### CMP = Compare

Register/memory and register

|                 |             |
|-----------------|-------------|
| 0 0 1 1 1 0 d w | mod reg r/m |
|-----------------|-------------|

Timing (clocks):    register with register                          3  
                        memory with register                              9+EA  
                        register with memory                              9+EA

**Immediate with register/memory**

|               |               |      |                |
|---------------|---------------|------|----------------|
| 1 0 0 0 0 s w | mod 1 1 1 r/m | data | data if s:w=01 |
|---------------|---------------|------|----------------|

Timing (clocks): immediate with register 4  
immediate with memory 17+EA

**Immediate with accumulator**

|                 |      |             |
|-----------------|------|-------------|
| 0 0 1 1 1 1 0 w | data | data if w=1 |
|-----------------|------|-------------|

Timing: 4 clocks

**AAS = ASCII adjust for subtract**

|               |
|---------------|
| 0 0 1 1 1 1 1 |
|---------------|

Timing: 4 clocks

**DAS = Decimal adjust for subtract**

|               |
|---------------|
| 0 0 1 0 1 1 1 |
|---------------|

Timing: 4 clocks

**MUL = Multiply (unsigned)**

|                 |               |
|-----------------|---------------|
| 1 1 1 1 0 1 1 w | mod 1 0 0 r/m |
|-----------------|---------------|

Timing (clocks): 8-bit 71+EA  
16-bit 124+EA

**IMUL = Integer multiply (signed)**

|                 |               |
|-----------------|---------------|
| 1 1 1 1 0 1 1 w | mod 1 0 1 r/m |
|-----------------|---------------|

Timing (clocks): 8-bit 90+EA  
16-bit 144+EA

**AAM = ASCII adjust for multiply**

|                 |                 |
|-----------------|-----------------|
| 1 1 0 1 0 1 0 0 | 0 0 0 0 1 0 1 0 |
|-----------------|-----------------|

Timing: 83 clocks

**DIV = Divide (unsigned)**

|                 |               |
|-----------------|---------------|
| 1 1 1 1 0 1 1 w | mod 1 1 0 r/m |
|-----------------|---------------|

Timing (clocks): 8-bit 90+EA  
16-bit 155+EA

**IDIV = Integer divide (signed)**

|                 |               |
|-----------------|---------------|
| 1 1 1 1 0 1 1 w | mod 1 1 1 r/m |
|-----------------|---------------|

Timing (clocks): 8-bit 112+EA  
16-bit 177+EA

**AAD = ASCII adjust for divide**

|                 |                 |
|-----------------|-----------------|
| 1 1 0 1 0 1 0 1 | 0 0 0 0 1 0 1 0 |
|-----------------|-----------------|

Timing: 60 clocks

**CBW = Convert byte to word**

|                 |
|-----------------|
| 1 0 0 1 1 0 0 0 |
|-----------------|

Timing: 2 clocks

**CWD = Convert word to double word**

|                 |
|-----------------|
| 1 0 0 1 1 0 0 1 |
|-----------------|

Timing: 5 clocks

**LOGIC****NOT = Invert**

|                 |               |
|-----------------|---------------|
| 1 1 1 1 0 1 1 w | mod 0 1 0 r/m |
|-----------------|---------------|

Timing (clocks): register 3  
memory 16+EA

**SHL/SAL = Shift logical/arithmetic left**

|                 |               |
|-----------------|---------------|
| 1 1 0 1 0 0 v w | mod 1 0 0 r/m |
|-----------------|---------------|

Timing (clocks): single-bit register 2  
single-bit memory 15+EA  
variable-bit register 8+4/bit  
variable-bit memory 20+EA+4/bit

**SHR = Shift logical right**

|                 |               |
|-----------------|---------------|
| 1 1 0 1 0 0 v w | mod 1 0 1 r/m |
|-----------------|---------------|

Timing (clocks): single-bit register 2  
single-bit memory 15+EA  
variable-bit register 8+4/bit  
variable-bit memory 20+EA+4/bit

**SAR = Shift arithmetic right**

|                 |               |
|-----------------|---------------|
| 1 1 0 1 0 0 v w | mod 1 1 1 r/m |
|-----------------|---------------|

Timing (clocks): single-bit register 2  
single-bit memory 15+EA  
variable-bit register 8+4/bit  
variable-bit memory 20+EA+4/bit

**ROL = Rotate left**

|                 |               |
|-----------------|---------------|
| 1 1 0 1 0 0 v w | mod 0 0 0 r/m |
|-----------------|---------------|

Timing (clocks): single-bit register 2  
single-bit memory 15+EA  
variable-bit register 8+4/bit  
variable-bit memory 20+EA+4/bit

**ROL = Rotate left**

|                 |               |
|-----------------|---------------|
| 1 1 0 1 0 0 v w | mod 0 0 1 r/m |
|-----------------|---------------|

Timing (clocks): single-bit register  
single-bit memory  
variable-bit register  
variable-bit memory

2  
15+EA  
8+4/bit  
20+EA+4/bit

**RCL = Rotate through carry left**

|                 |               |
|-----------------|---------------|
| 1 1 0 1 0 0 v w | mod 0 1 0 r/m |
|-----------------|---------------|

Timing (clocks): single-bit register  
single-bit memory  
variable-bit register  
variable-bit memory

2  
15+EA  
8+4/bit  
20+EA+4/bit

**RCR = Rotate through carry right**

|                 |               |
|-----------------|---------------|
| 1 1 0 1 0 0 v w | mod 0 1 1 r/m |
|-----------------|---------------|

Timing (clocks): single-bit register  
single-bit memory  
variable-bit register  
variable-bit memory

2  
15+EA  
8+4/bit  
20+EA+4/bit

**AND = And****Reg./memory and register to either**

|                 |             |
|-----------------|-------------|
| 0 0 1 0 0 0 d w | mod reg r/m |
|-----------------|-------------|

Timing (clocks): register to register  
memory to register  
register to memory

3  
9+EA  
16+EA

**Immediate to register/memory**

|                 |               |      |             |
|-----------------|---------------|------|-------------|
| 1 0 0 0 0 0 0 w | mod 1 0 0 r/m | data | data if w=1 |
|-----------------|---------------|------|-------------|

Timing (clocks): immediate to register  
immediate to memory

4  
17+EA

**Immediate to accumulator**

|                 |      |             |
|-----------------|------|-------------|
| 0 0 1 0 0 1 0 w | data | data if w=1 |
|-----------------|------|-------------|

Timing: 4 clocks

**TEST = And function to flags, no result****Register/memory and register**

|                 |             |
|-----------------|-------------|
| 1 0 0 0 0 1 0 w | mod reg r/m |
|-----------------|-------------|

Timing (clocks): register to register  
register with memory

3  
9+EA

(Continued on following page)

**Immediate data and register/memory**

|                 |               |      |             |
|-----------------|---------------|------|-------------|
| 1 1 1 1 0 1 1 w | mod 0 0 0 r/m | data | data if w=1 |
|-----------------|---------------|------|-------------|

Timing (clocks): immediate with register  
immediate with memory

4  
10+EA

**Immediate data and accumulator**

|                 |      |             |
|-----------------|------|-------------|
| 1 0 1 0 1 0 0 w | data | data if w=1 |
|-----------------|------|-------------|

Timing: 4 clocks

**OR = Or****Reg./memory and register to either**

|                 |             |
|-----------------|-------------|
| 0 0 0 0 1 0 d w | mod reg r/m |
|-----------------|-------------|

Timing (clocks): register to register  
memory to register  
register to memory

3  
9+EA  
16+EA

**Immediate to register/memory**

|                 |               |      |             |
|-----------------|---------------|------|-------------|
| 1 0 0 0 0 0 0 w | mod 0 0 1 r/m | data | data if w=1 |
|-----------------|---------------|------|-------------|

Timing (clocks): immediate to register  
immediate to memory

4  
17+EA

**Immediate to accumulator**

|                 |      |             |
|-----------------|------|-------------|
| 0 0 0 0 1 1 0 w | data | data if w=1 |
|-----------------|------|-------------|

Timing: 4 clocks

**XOR = Exclusive or****Reg./memory and register to either**

|                 |             |
|-----------------|-------------|
| 0 0 1 1 0 0 d w | mod reg r/m |
|-----------------|-------------|

Timing (clocks): register to register  
memory to register  
register to memory

3  
9+EA  
16+EA

**Immediate to register/memory**

|                 |               |      |             |
|-----------------|---------------|------|-------------|
| 1 0 0 0 0 0 0 w | mod 1 0 0 r/m | data | data if w=1 |
|-----------------|---------------|------|-------------|

Timing (clocks): immediate to register  
immediate to memory

4  
17+EA

**Immediate to accumulator**

|                 |      |             |
|-----------------|------|-------------|
| 0 0 1 1 0 1 0 w | data | data if w=1 |
|-----------------|------|-------------|

Timing: 4 clocks

**STRING MANIPULATION****REP = Repeat**

|                 |
|-----------------|
| 1 1 1 1 0 0 1 z |
|-----------------|

Timing: 6 clocks/loop

**MOVS = Move String**

|   |   |   |   |   |   |   |   |
|---|---|---|---|---|---|---|---|
| 1 | 0 | 1 | 0 | 0 | 1 | 0 | w |
|---|---|---|---|---|---|---|---|

Timing: 17 clocks

**CMPS = Compare String**

|   |   |   |   |   |   |   |   |
|---|---|---|---|---|---|---|---|
| 1 | 0 | 1 | 0 | 0 | 1 | 1 | w |
|---|---|---|---|---|---|---|---|

Timing: 22 clocks

**SCAS = Scan String**

|   |   |   |   |   |   |   |   |
|---|---|---|---|---|---|---|---|
| 1 | 0 | 1 | 0 | 1 | 1 | 1 | w |
|---|---|---|---|---|---|---|---|

Timing: 15 clocks

**LODS = Load String**

|   |   |   |   |   |   |   |   |
|---|---|---|---|---|---|---|---|
| 1 | 0 | 1 | 0 | 1 | 1 | 0 | w |
|---|---|---|---|---|---|---|---|

Timing: 12 clocks

**STOS = Store String**

|   |   |   |   |   |   |   |   |
|---|---|---|---|---|---|---|---|
| 1 | 0 | 1 | 0 | 1 | 0 | 1 | w |
|---|---|---|---|---|---|---|---|

Timing: 10 clocks

**CONTROL TRANSFER**

*NOTE: Queue reinitialization is not included in the timing information for transfer operations. To account for instruction loading, add 8 clocks to timing numbers.*

**CALL = Call**

## Direct within segment

|   |   |   |   |          |           |   |   |
|---|---|---|---|----------|-----------|---|---|
| 1 | 1 | 1 | 0 | 1        | 0         | 0 | 0 |
|   |   |   |   | disp-low | disp-high |   |   |

Timing: 11 clocks

## Indirect within segment

|   |   |   |   |       |   |   |     |
|---|---|---|---|-------|---|---|-----|
| 1 | 1 | 1 | 1 | 1     | 1 | 1 | 1   |
|   |   |   |   | mod 0 | 1 | 0 | r/m |

Timing: 13+EA clocks

## Direct intersegment

|   |   |   |   |            |             |   |   |
|---|---|---|---|------------|-------------|---|---|
| 1 | 0 | 0 | 1 | 1          | 0           | 1 | 0 |
|   |   |   |   | offset-low | offset-high |   |   |

Timing: 20 clocks

|         |          |  |  |
|---------|----------|--|--|
| seg-low | seg-high |  |  |
|---------|----------|--|--|

## Indirect intersegment

|   |   |   |   |       |   |   |     |
|---|---|---|---|-------|---|---|-----|
| 1 | 1 | 1 | 1 | 1     | 1 | 1 | 1   |
|   |   |   |   | mod 0 | 1 | 1 | r/m |

Timing: 29+EA clocks

**JMP = Unconditional Jump**

## Direct within segment

|   |   |   |   |          |           |   |   |
|---|---|---|---|----------|-----------|---|---|
| 1 | 1 | 1 | 0 | 1        | 0         | 0 | 1 |
|   |   |   |   | disp-low | disp-high |   |   |

Timing: 7 clocks

## Direct within segment-short

|      |   |   |   |   |   |   |   |
|------|---|---|---|---|---|---|---|
| 1    | 1 | 1 | 0 | 1 | 0 | 1 | 1 |
| disp |   |   |   |   |   |   |   |

Timing: 7 clocks

## Indirect within segment

|   |   |   |   |       |   |   |     |
|---|---|---|---|-------|---|---|-----|
| 1 | 1 | 1 | 1 | 1     | 1 | 1 | 1   |
|   |   |   |   | mod 1 | 0 | 0 | r/m |

Timing: 7+EA clocks

## Direct intersegment

|   |   |   |   |            |             |   |   |
|---|---|---|---|------------|-------------|---|---|
| 1 | 1 | 1 | 0 | 1          | 0           | 1 | 0 |
|   |   |   |   | offset-low | offset-high |   |   |

Timing: 7 clocks

## Indirect intersegment

|   |   |   |   |       |   |   |     |
|---|---|---|---|-------|---|---|-----|
| 1 | 1 | 1 | 1 | 1     | 1 | 1 | 1   |
|   |   |   |   | mod 1 | 0 | 1 | r/m |

Timing: 16+EA clocks

**RET = Return from CALL**

## Within segment

|   |   |   |   |   |   |   |   |
|---|---|---|---|---|---|---|---|
| 1 | 1 | 0 | 0 | 0 | 0 | 1 | 1 |
|---|---|---|---|---|---|---|---|

Timing: 8 clocks

## Within seg. adding immed to SP

|   |   |   |   |          |           |   |   |
|---|---|---|---|----------|-----------|---|---|
| 1 | 1 | 0 | 0 | 0        | 0         | 1 | 0 |
|   |   |   |   | data-low | data-high |   |   |

Timing: 12 clocks

## Intersegment

|   |   |   |   |   |   |   |   |
|---|---|---|---|---|---|---|---|
| 1 | 1 | 0 | 0 | 1 | 0 | 1 | 1 |
|---|---|---|---|---|---|---|---|

Timing: 18 clocks

## Intersegment, adding immediate to SP

|   |   |   |   |          |           |   |   |
|---|---|---|---|----------|-----------|---|---|
| 1 | 1 | 0 | 0 | 1        | 0         | 1 | 0 |
|   |   |   |   | data-low | data-high |   |   |

Timing: 17 clocks

**JE/JZ = Jump on equal/zero**

|      |   |   |   |   |   |   |   |
|------|---|---|---|---|---|---|---|
| 0    | 1 | 1 | 1 | 0 | 1 | 0 | 0 |
| disp |   |   |   |   |   |   |   |

Timing (clocks):      Jump is taken  
                           Jump is not taken

8

4

**JL/JNGE** = Jump on less/not greater or equal

|                 |      |
|-----------------|------|
| 0 1 1 1 1 1 0 0 | disp |
|-----------------|------|

Timing (clocks):   Jump is taken                                 8  
                           Jump is not taken                             4

**JLE/JNG** = Jump on less or equal/not greater

|                 |      |
|-----------------|------|
| 0 1 1 1 1 1 1 0 | disp |
|-----------------|------|

Timing (clocks):   Jump is taken                               8  
                           Jump is not taken                           4

**JB/JNAE** = Jump on below/ not above or equal

|                 |      |
|-----------------|------|
| 0 1 1 1 0 0 1 0 | disp |
|-----------------|------|

Timing (clocks):   Jump is taken                               8  
                           Jump is not taken                           4

**JBE/JNA** = Jump on below or equal/not above

|                 |      |
|-----------------|------|
| 0 1 1 1 0 1 1 0 | disp |
|-----------------|------|

Timing (clocks):   Jump is taken                               8  
                           Jump is not taken                           4

**JP/JPE** = Jump on parity/parity even

|                 |      |
|-----------------|------|
| 0 1 1 1 1 0 1 0 | disp |
|-----------------|------|

Timing (clocks):   Jump is taken                               8  
                           Jump is not taken                           4

**JO** = Jump on overflow

|                 |      |
|-----------------|------|
| 0 1 1 1 0 0 0 0 | disp |
|-----------------|------|

Timing (clocks):   Jump is taken                               8  
                           Jump is not taken                           4

**JS** = Jump on sign

|                 |      |
|-----------------|------|
| 0 1 1 1 1 0 0 0 | disp |
|-----------------|------|

Timing (clocks):   Jump is taken                               8  
                           Jump is not taken                           4

**JNE/JNZ** = Jump on not equal/not zero

|                 |      |
|-----------------|------|
| 0 1 1 1 0 1 0 1 | disp |
|-----------------|------|

Timing (clocks):   Jump is taken                               8  
                           Jump is not taken                           4

**JNL/JGE** = Jump on not less/greater or equal

|                 |      |
|-----------------|------|
| 0 1 1 1 1 1 0 1 | disp |
|-----------------|------|

Timing (clocks):   Jump is taken                               8  
                           Jump is not taken                           4

(Continued on following page)

**JNLE/JG** = Jump on not less or equal/greater

|                 |      |
|-----------------|------|
| 0 1 1 1 1 1 1 1 | disp |
|-----------------|------|

Timing (clocks):   Jump is taken                               8  
                           Jump is not taken                           4

**JNB/JAE** = Jump on not below/above or equal

|                 |      |
|-----------------|------|
| 0 1 1 1 0 0 1 1 | disp |
|-----------------|------|

Timing (clocks):   Jump is taken                               8  
                           Jump is not taken                           4

**JNBE/JA** = Jump on not below or equal/above

|                 |      |
|-----------------|------|
| 0 1 1 1 0 1 1 1 | disp |
|-----------------|------|

Timing (clocks):   Jump is taken                               8  
                           Jump is not taken                           4

**JNP/JPO** = Jump on not parity/parity odd

|                 |      |
|-----------------|------|
| 0 1 1 1 1 0 1 1 | disp |
|-----------------|------|

Timing (clocks):   Jump is taken                               8  
                           Jump is not taken                           4

**JNO** = Jump on not overflow

|                 |      |
|-----------------|------|
| 0 1 1 1 0 0 0 1 | disp |
|-----------------|------|

Timing (clocks):   Jump is taken                               8  
                           Jump is not taken                           4

**JNS** = Jump on not sign

|                 |      |
|-----------------|------|
| 0 1 1 1 1 0 0 1 | disp |
|-----------------|------|

Timing (clocks):   Jump is taken                               8  
                           Jump is not taken                           4

**LOOP** = Loop CX times

|                 |      |
|-----------------|------|
| 1 1 1 0 0 0 1 0 | disp |
|-----------------|------|

Timing (clocks):   Jump is taken                               9  
                           Jump is not taken                           5

**LOOPZ/LOOPE** = Loop while zero/equal

|                 |      |
|-----------------|------|
| 1 1 1 0 0 0 0 1 | disp |
|-----------------|------|

Timing (clocks):   Jump is taken                               11  
                           Jump is not taken                           5

**LOOPNZ/LOOPNE** = Loop while not zero/ not equal

|                 |      |
|-----------------|------|
| 1 1 1 0 0 0 0 0 | disp |
|-----------------|------|

Timing (clocks):   Jump is taken                               11  
                           Jump is not taken                           5

**JCXZ** = Jump on CX zero

|                 |      |
|-----------------|------|
| 1 1 1 0 0 0 1 1 | disp |
|-----------------|------|

Timing (clocks):    Jump is taken  
                      Jump is not taken

9  
5

#### 8086 CONDITIONAL TRANSFER OPERATIONS

| Instruction | Condition               | Interpretation                   |
|-------------|-------------------------|----------------------------------|
| JE or JZ    | ZF = 1                  | "equal" or "zero"                |
| JL or JNGE  | (SF xor OF) = 1         | "less" or "not greater or equal" |
| JLE or JNG  | ((SP xor OF) or ZF) = 1 | "less or equal" or "not greater" |
| JB or JNAE  | CF = 1                  | "below" or "not above or equal"  |
| JBE or JNA  | (CF or ZF) = 1          | "below or equal" or "not above"  |
| JP or JPE   | PF = 1                  | "parity" or "parity even"        |
| JO          | OF = 1                  | "overflow"                       |
| JS          | SF = 1                  | "sign"                           |
| JNE or JNZ  | ZF = 0                  | "not equal" or "not zero"        |
| JNL or JGE  | (SF xor OF) = 0         | "not less" or "greater or equal" |
| JNLE or JG  | ((SF xor OF) or ZF) = 0 | "not less or equal" or "greater" |
| JNB or JAE  | CF = 0                  | "not below" or "above or equal"  |
| JNBE or JA  | (CF or ZF) = 0          | "not below or equal" or "above"  |
| JNP or JPO  | PF = 0                  | "not parity" or "parity odd"     |
| JNO         | OF = 0                  | "not overflow"                   |
| JNS         | SF = 0                  | "not sign"                       |

"Above" and "below" refer to the relation between two unsigned values, while "greater" and "less" refer to the relation between two signed values.

**INT** = Interrupt

Type specified

|                 |      |
|-----------------|------|
| 1 1 0 0 1 1 0 1 | type |
|-----------------|------|

Timing: 50 clocks

Type 3

|                 |
|-----------------|
| 1 1 0 0 1 1 0 0 |
|-----------------|

Timing: 51 clocks

**INTO** = Interrupt on overflow

|                 |
|-----------------|
| 1 1 0 0 1 1 1 0 |
|-----------------|

Timing: 52 clocks if pass      4 clocks if fail

**IRET** = Interrupt return

|                 |
|-----------------|
| 1 1 0 0 1 1 1 1 |
|-----------------|

Timing: 24 clocks

#### PROCESSOR CONTROL

**CLC** = Clear carry

|                 |
|-----------------|
| 1 1 1 1 1 0 0 0 |
|-----------------|

Timing: 2 clocks

**CMC** = Complement carry

|                 |
|-----------------|
| 1 1 1 1 0 1 0 1 |
|-----------------|

Timing: 2 clocks

**CLD** = Clear direction

|                 |
|-----------------|
| 1 1 1 1 1 1 0 0 |
|-----------------|

Timing: 2 clocks

**CLI** = Clear interrupt

|                 |
|-----------------|
| 1 1 1 1 1 0 1 0 |
|-----------------|

Timing: 2 clocks

**HLT** = Halt

|                 |
|-----------------|
| 1 1 1 1 0 1 0 0 |
|-----------------|

Timing: 2 clocks

**LOCK** = Bus lock prefix

|                 |
|-----------------|
| 1 1 1 1 0 0 0 0 |
|-----------------|

Timing: 2 clocks

**STC** = Set carry

|                 |
|-----------------|
| 1 1 1 1 1 0 0 1 |
|-----------------|

Timing: 2 clocks

**NOP** = No operation

|                 |
|-----------------|
| 1 0 0 1 0 0 0 0 |
|-----------------|

Timing: 3 clocks

**STD** = Set direction

|                 |
|-----------------|
| 1 1 1 1 1 1 0 1 |
|-----------------|

Timing: 2 clocks

**STI** = Set interrupt

|                 |
|-----------------|
| 1 1 1 1 1 0 1 1 |
|-----------------|

Timing: 2 clocks

**WAIT** = Wait

|                 |
|-----------------|
| 1 0 0 1 1 0 1 1 |
|-----------------|

Timing: 3 clocks

**ESC** = Escape (to external device)

|                 |               |
|-----------------|---------------|
| 1 1 0 1 1 x x x | mod x x x r/m |
|-----------------|---------------|

Timing: 7+EA clocks

#### Footnotes:

if d = 1 then "to"; if d = 0 then "from"

if w = 1 then word instruction; if w = 0 then byte instruction

if s:w = 01 then 16 bits of immediate data form the operand

if s:w = 11 then an immediate data byte is sign extended to form the 16-bit operand

if v = 0 then "count" = 1; if v = 1 then "count" in (CL)

x = don't care

z is used for some string primitives to compare with ZF FLAG

AL = 8-bit accumulator

AX = 16-bit accumulator

CX = Count register

DS = Data segment

DX = Variable port register

ES = Extra segment

Above/below refers to unsigned value

Greater = more positive;

Less = less positive (more negative) signed values

See page 1 for Operand Summary.

See page 2 for Segment Override Summary.