

**Table 2. Instruction Set Summary**

| Mnemonic and Description            | Instruction Code       |                        |                        |                        |
|-------------------------------------|------------------------|------------------------|------------------------|------------------------|
| <b>DATA TRANSFER</b>                |                        |                        |                        |                        |
| <b>MOV = Move:</b>                  | <b>7 6 5 4 3 2 1 0</b> | <b>7 6 5 4 3 2 1 0</b> | <b>7 6 5 4 3 2 1 0</b> | <b>7 6 5 4 3 2 1 0</b> |
| Register/Memory to/from Register    | 1 0 0 0 1 0 d w        | mod reg r/m            |                        |                        |
| Immediate to Register/Memory        | 1 1 0 0 0 1 1 w        | mod 0 0 0 r/m          | data                   | data if w = 1          |
| Immediate to Register               | 1 0 1 1 w reg          | data                   | data if w = 1          |                        |
| Memory to Accumulator               | 1 0 1 0 0 0 0 w        | addr-low               | addr-high              |                        |
| Accumulator to Memory               | 1 0 1 0 0 0 1 w        | addr-low               | addr-high              |                        |
| Register/Memory to Segment Register | 1 0 0 0 1 1 1 0        | mod 0 reg r/m          |                        |                        |
| Segment Register to Register/Memory | 1 0 0 0 1 1 0 0        | mod 0 reg r/m          |                        |                        |
| <b>PUSH = Push:</b>                 |                        |                        |                        |                        |
| Register/Memory                     | 1 1 1 1 1 1 1 1        | mod 1 1 0 r/m          |                        |                        |
| Register                            | 0 1 0 1 0 reg          |                        |                        |                        |
| Segment Register                    | 0 0 0 reg 1 1 0        |                        |                        |                        |
| <b>POP = Pop:</b>                   |                        |                        |                        |                        |
| Register/Memory                     | 1 0 0 0 1 1 1 1        | mod 0 0 0 r/m          |                        |                        |
| Register                            | 0 1 0 1 1 reg          |                        |                        |                        |
| Segment Register                    | 0 0 0 reg 1 1 1        |                        |                        |                        |
| <b>XCHG = Exchange:</b>             |                        |                        |                        |                        |
| Register/Memory with Register       | 1 0 0 0 0 1 1 w        | mod reg r/m            |                        |                        |
| Register with Accumulator           | 1 0 0 1 0 reg          |                        |                        |                        |
| <b>IN = Input from:</b>             |                        |                        |                        |                        |
| Fixed Port                          | 1 1 1 0 0 1 0 w        | port                   |                        |                        |
| Variable Port                       | 1 1 1 0 1 1 0 w        |                        |                        |                        |
| <b>OUT = Output to:</b>             |                        |                        |                        |                        |
| Fixed Port                          | 1 1 1 0 0 1 1 w        | port                   |                        |                        |
| Variable Port                       | 1 1 1 0 1 1 1 w        |                        |                        |                        |
| <b>XLAT = Translate Byte to AL</b>  | 1 1 0 1 0 1 1 1        |                        |                        |                        |
| <b>LEA = Load EA to Register</b>    | 1 0 0 0 1 1 0 1        | mod reg r/m            |                        |                        |
| <b>LDS = Load Pointer to DS</b>     | 1 1 0 0 0 1 0 1        | mod reg r/m            |                        |                        |
| <b>LES = Load Pointer to ES</b>     | 1 1 0 0 0 1 0 0        | mod reg r/m            |                        |                        |
| <b>LAHF = Load AH with Flags</b>    | 1 0 0 1 1 1 1 1        |                        |                        |                        |
| <b>SAHF = Store AH into Flags</b>   | 1 0 0 1 1 1 1 0        |                        |                        |                        |
| <b>PUSHF = Push Flags</b>           | 1 0 0 1 1 1 0 0        |                        |                        |                        |
| <b>POPF = Pop Flags</b>             | 1 0 0 1 1 1 0 1        |                        |                        |                        |

Mnemonics © Intel, 1978

**Table 2. Instruction Set Summary (Continued)**

| Mnemonic and Description                 | Instruction Code |                 |                 |                   |
|------------------------------------------|------------------|-----------------|-----------------|-------------------|
| <b>ARITHMETIC</b>                        | 7 6 5 4 3 2 1 0  | 7 6 5 4 3 2 1 0 | 7 6 5 4 3 2 1 0 | 7 6 5 4 3 2 1 0   |
| <b>ADD = Add:</b>                        |                  |                 |                 |                   |
| Reg./Memory with Register to Either      | 0 0 0 0 0 d w    | mod reg r/m     |                 |                   |
| Immediate to Register/Memory             | 1 0 0 0 0 s w    | mod 0 0 0 r/m   | data            | data if s: w = 01 |
| Immediate to Accumulator                 | 0 0 0 0 0 1 0 w  | data            | data if w = 1   |                   |
| <b>ADC = Add with Carry:</b>             |                  |                 |                 |                   |
| Reg./Memory with Register to Either      | 0 0 0 1 0 0 d w  | mod reg r/m     |                 |                   |
| Immediate to Register/Memory             | 1 0 0 0 0 s w    | mod 0 1 0 r/m   | data            | data if s: w = 01 |
| Immediate to Accumulator                 | 0 0 0 1 0 1 0 w  | data            | data if w = 1   |                   |
| <b>INC = Increment:</b>                  |                  |                 |                 |                   |
| Register/Memory                          | 1 1 1 1 1 1 1 w  | mod 0 0 0 r/m   |                 |                   |
| Register                                 | 0 1 0 0 0 reg    |                 |                 |                   |
| <b>AAA = ASCII Adjust for Add</b>        | 0 0 1 1 0 1 1 1  |                 |                 |                   |
| <b>BAA = Decimal Adjust for Add</b>      | 0 0 1 0 0 1 1 1  |                 |                 |                   |
| <b>SUB = Subtract:</b>                   |                  |                 |                 |                   |
| Reg./Memory and Register to Either       | 0 0 1 0 1 0 d w  | mod reg r/m     |                 |                   |
| Immediate from Register/Memory           | 1 0 0 0 0 0 s w  | mod 1 0 1 r/m   | data            | data if s w = 01  |
| Immediate from Accumulator               | 0 0 1 0 1 1 0 w  | data            | data if w = 1   |                   |
| <b>SSB = Subtract with Borrow</b>        |                  |                 |                 |                   |
| Reg./Memory and Register to Either       | 0 0 0 1 1 0 d w  | mod reg r/m     |                 |                   |
| Immediate from Register/Memory           | 1 0 0 0 0 0 s w  | mod 0 1 1 r/m   | data            | data if s w = 01  |
| Immediate from Accumulator               | 0 0 0 1 1 1 w    | data            | data if w = 1   |                   |
| <b>DEC = Decrement:</b>                  |                  |                 |                 |                   |
| Register/memory                          | 1 1 1 1 1 1 1 w  | mod 0 0 1 r/m   |                 |                   |
| Register                                 | 0 1 0 0 1 reg    |                 |                 |                   |
| <b>NEG = Change sign</b>                 | 1 1 1 1 0 1 1 w  | mod 0 1 1 r/m   |                 |                   |
| <b>CMP = Compare:</b>                    |                  |                 |                 |                   |
| Register/Memory and Register             | 0 0 1 1 1 0 d w  | mod reg r/m     |                 |                   |
| Immediate with Register/Memory           | 1 0 0 0 0 0 s w  | mod 1 1 1 r/m   | data            | data if s w = 01  |
| Immediate with Accumulator               | 0 0 1 1 1 1 0 w  | data            | data if w = 1   |                   |
| <b>AAS = ASCII Adjust for Subtract</b>   | 0 0 1 1 1 1 1 1  |                 |                 |                   |
| <b>DAS = Decimal Adjust for Subtract</b> | 0 0 1 0 1 1 1 1  |                 |                 |                   |
| <b>MUL = Multiply (Unsigned)</b>         | 1 1 1 1 0 1 1 w  | mod 1 0 0 r/m   |                 |                   |
| <b>IMUL = Integer Multiply (Signed)</b>  | 1 1 1 1 0 1 1 w  | mod 1 0 1 r/m   |                 |                   |
| <b>AAM = ASCII Adjust for Multiply</b>   | 1 1 0 1 0 1 0 0  | 0 0 0 0 1 0 1 0 |                 |                   |
| <b>DIV = Divide (Unsigned)</b>           | 1 1 1 1 0 1 1 w  | mod 1 1 0 r/m   |                 |                   |
| <b>IDIV = Integer Divide (Signed)</b>    | 1 1 1 1 0 1 1 w  | mod 1 1 1 r/m   |                 |                   |
| <b>AAD = ASCII Adjust for Divide</b>     | 1 1 0 1 0 1 0 1  | 0 0 0 0 1 0 1 0 |                 |                   |
| <b>CBW = Convert Byte to Word</b>        | 1 0 0 1 1 0 0 0  |                 |                 |                   |
| <b>CWD = Convert Word to Double Word</b> | 1 0 0 1 1 0 0 1  |                 |                 |                   |

Mnemonics © Intel, 1978

**Table 2. Instruction Set Summary (Continued)**

| Mnemonic and Description                 | Instruction Code |                 |
|------------------------------------------|------------------|-----------------|
|                                          | 7 6 5 4 3 2 1 0  | 7 6 5 4 3 2 1 0 |
| <b>PROCESSOR CONTROL</b>                 |                  |                 |
| <b>CLC</b> = Clear Carry                 | 1 1 1 1 1 0 0 0  |                 |
| <b>CMC</b> = Complement Carry            | 1 1 1 1 0 1 0 1  |                 |
| <b>STC</b> = Set Carry                   | 1 1 1 1 1 0 0 1  |                 |
| <b>CLD</b> = Clear Direction             | 1 1 1 1 1 1 0 0  |                 |
| <b>STD</b> = Set Direction               | 1 1 1 1 1 1 0 1  |                 |
| <b>CLI</b> = Clear Interrupt             | 1 1 1 1 1 0 1 0  |                 |
| <b>STI</b> = Set Interrupt               | 1 1 1 1 1 0 1 1  |                 |
| <b>HLT</b> = Halt                        | 1 1 1 1 0 1 0 0  |                 |
| <b>WAIT</b> = Wait                       | 1 0 0 1 1 0 1 1  |                 |
| <b>ESC</b> = Escape (to External Device) | 1 1 0 1 1 x x x  | mod x x x r/m   |
| <b>LOCK</b> = Bus Lock Prefix            | 1 1 1 1 0 0 0 0  |                 |

**NOTES:**

AL = 8-bit accumulator

AX = 16-bit accumulator

CX = Count register

DS = Data segment

ES = Extra segment

Above/below refers to unsigned value

Greater = more positive;

Less = less positive (more negative) signed values

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

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

if mod = 11 then r/m is treated as a REG field

if mod = 00 then DISP = 0\*, disp-low and disp-high are absent

if mod = 01 then DISP = disp-low sign-extended to 16 bits, disp-high is absent

if mod = 10 then DISP = disp-high; disp-low

if r/m = 000 then EA = (BX) + (SI) + DISP

if r/m = 001 then EA = (BX) + (DI) + DISP

if r/m = 010 then EA = (BP) + (SI) + DISP

if r/m = 011 then EA = (BP) + (DI) + DISP

if r/m = 100 then EA = (SI) + DISP

if r/m = 101 then EA = (DI) + DISP

if r/m = 110 then EA = (BP) + DISP\*

if r/m = 111 then EA = (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.

Mnemonics © Intel, 1978

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 string primitives for comparison with ZF FLAG

**SEGMENT OVERRIDE PREFIX**

0 0 1 reg 1 1 0

REG is assigned according to the following table:

| 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        |         |

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

FLAGS = X:X:X:(OF):(IF):(TF):(SF):(ZF):X:(AF):X:(PF):X:(CF)

**DATA SHEET REVISION REVIEW**

The following list represents key differences between this and the -004 data sheet. Please review this summary carefully.

1. The Intel 8086 implementation technology (HMOS) has been changed to (HMOS-III).
2. Delete all "changes from 1985 Handbook Specification" sentences.