

# Rochester Electronics Manufactured Components

Rochester branded components are manufactured using either die/wafers purchased from the original suppliers or Rochester wafers recreated from the original IP. All recreations are done with the approval of the OCM.

Parts are tested using original factory test programs or Rochester developed test solutions to guarantee product meets or exceed the OCM data sheet.

# **Quality Overview**

- ISO-9001
- AS9120 certification
- Qualified Manufacturers List (QML) MIL-PRF-35835
  - Class Q Military
  - Class V Space Level
- Qualified Suppliers List of Distributors (QSLD)
- Rochester is a critical supplier to DLA and meets all industry and DLA standards.

Rochester Electronics, LLC is committed to supplying products that satisfy customer expectations for quality and are equal to those originally supplied by industry manufacturers.

The original manufacturer's datasheet accompanying this document reflects the performance and specifications of the Rochester manufactured version of this device. Rochester Electronics guarantees the performance of its semiconductor products to the original OEM specifications. 'Typical' values are for reference purposes only. Certain minimum or maximum ratings may be based on product characterization, design, simulation, or sample testing.

# 8086

16-Bit Microprocessor iAPX86 Family FINAL

## DISTINCTIVE CHARACTERISTICS

- · Directly addresses up to 1 Mbyte of memory
- · 24 operand addressing modes
- · Efficient implementation of high level languages
- Instruction set compatible with 8080 software
- · Bit, byte, word, and block operations
- 8 and 16-bit signed and unsigned arithmetic in binary or decimal
- MULTIBUS<sup>(k)</sup> system interface
- Three speed options
  - 5MHz for 8086
  - 8MHz for 8086-2
  - 10MHz for 8086-1

# **GENERAL DESCRIPTION**

The 8086 is a general purpose 16-bit microprocessor CPU. Its architecture is built around thirteen 16-bit registers and nine 1-bit flags. The CPU operates on 16-bit address spaces and can directly address up to 1 megabyte using offset addresses within four distinct memory segments, designated as code, data, stack and extra code. The 8086 implements a powerful instruction set with 24 operand addressing modes. This instruction set is compatible with that of the 8080 and 8085. In addition, the 8086 is particularly effective in executing high level languages.

The 8086 can operate in minimum and maximum modes. Maximum mode offloads certain bus control functions to a peripheral device and allows the CPU to operate efficiently in a multi-processor system. The CPU and its high performance peripherals are MULTIBUS compatible. The 8086 is implemented in N-channel, depletion load, silicon gate technology and is contained in a 40-pin CERDIP package, Molded DIP package, or Plastic Leaded Chip Carrier.

# **BLOCK DIAGRAM**



Publication # Rev. Amendment 01966 D /0 Issue Date: August 1989

8086





Note: Pin 1 is marked for orientation

1-4

# **ORDERING INFORMATION**

#### **Commercial Products**

AMD commercial products are available in several packages and operating ranges. The order number (Valid Combination) is formed by a combination of: a. Temperature Range

- b. Package Type
- c. Device Number
- d. Speed Option
- e. Optional Processing



| Valid Combinations |         |  |  |  |  |  |
|--------------------|---------|--|--|--|--|--|
|                    | 8086    |  |  |  |  |  |
| P, D, N            | 8086-2  |  |  |  |  |  |
|                    | 8086-1  |  |  |  |  |  |
| D, ID              | 8086-28 |  |  |  |  |  |
| D                  | 8086-1  |  |  |  |  |  |
| in                 | AUBER   |  |  |  |  |  |

# Valid Combinations

Valid Combinations list configurations planned to be supported in volume for this device. Consult the local AMD sales office to confirm availability of specific valid combinations, to check on newly released valid combinations, and to obtain additional data on AMD's standard military grade products.



## ORDERING INFORMATION

# **Military Products**

AMD products for Aerospace and Defense applications are available in several packages and operating ranges. APL (Approved Products List) products are fully compliant with MIL-STD-883C requirements. The order number (Valid Combination) for APL products is formed by a combination of: a. Device Number

- b. Speed Option (if applicable)
- c. Device Class
- d. Package Type



# **Valid Combinations** 8086 8086-2

#### **Valid Combinations**

Valid Combinations list configurations planned to be supported in volume for this device. Consult the local AMD sales office to confirm availability of specific valid combinations or to check for newly released valid combinations.

# **Group A Tests**

Group A tests consist of Subgroups 1, 2, 3, 7, 8, 9, 10, 11

# PIN DESCRIPTION

The following pin function descriptions are for 8086 systems in either minimum or maximum mode. The "Local Bus" in these descriptions is the direct multiplexed bus interface connection to the 8086 (without regard to additional bus buffers).

| Pin No.*                   | Name                                    | 1/0_ | 1                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | D                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | escription                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |
|----------------------------|-----------------------------------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 39, 2-16                   | AD <sub>15</sub> -AD <sub>0</sub>       | 1/0  | bus. Ag is analo<br>be transferred of<br>lower half would                                                                                                                                                                                                                                                                                                                                                  | ogous to BHE<br>on the lower<br>d normally u                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | for the lower byte of the<br>portion of the bus in me<br>se A <sub>0</sub> to condition chip :                                                                                                                                                                                                                                                                                                                                                                                                           | nultiplexed memory/IO address ( $T_1$ ) and data ( $T_2$ , $T_3$ , $T_W$ , $T_4$ ) e data bus, pins $D_7-D_0$ . It is LOW during $T_1$ when a byte is to smooth or the propertions. Eight-bit oriented devices tied to the select functions. (See EHE.) These lines are active HIGH and dogs and local bus "hold acknowledge."                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
| 35-38                      | A19/S6,<br>A18/S5,<br>A17/S4,<br>A16/S3 | 0    | operations thes<br>during T <sub>2</sub> , T <sub>3</sub> , T<br>cycle: A <sub>17</sub> /S<br>This informati                                                                                                                                                                                                                                                                                               | Address/Status. During $T_1$ these are the four most significant address lines for memory operations. During operations these lines are LOW. During memory and $I/O$ operations, status information is available on these during $T_2$ , $T_3$ , $T_4$ , and $T_4$ . The status of the interrupt enable FLAG bit $(S_5)$ is updated at the beginning of each cycle. $A_17/S_4$ and $A_1g/S_3$ are encoded as shown. This information indicates which relocation register is presently being used for data access these float to three-state OFF during local bus "hold acknowledge."                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
|                            |                                         |      | A <sub>17</sub> /S <sub>4</sub>                                                                                                                                                                                                                                                                                                                                                                            | A <sub>16</sub> -S <sub>3</sub>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Characteristics                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | ]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
|                            | 1                                       |      | 0 (LOW)                                                                                                                                                                                                                                                                                                                                                                                                    | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Alternate Data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
|                            |                                         | 1    | 0                                                                                                                                                                                                                                                                                                                                                                                                          | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Stack                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
|                            |                                         |      | 1 (HIGH)                                                                                                                                                                                                                                                                                                                                                                                                   | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Code or None                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | ]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
|                            |                                         |      | 1                                                                                                                                                                                                                                                                                                                                                                                                          | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
|                            | -                                       | ļ    | Se is 0<br>(LOW)                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
| 34                         | BHE/S7                                  | 0    | the most signal<br>the bus would<br>and interrupt a<br>status informat                                                                                                                                                                                                                                                                                                                                     | icant half of<br>normally us<br>icknowledge<br>ion is avails                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | the data bus, pins De<br>e BHE to condition ch<br>cycles when a byte is<br>ble during T <sub>2</sub> , T <sub>3</sub> , and                                                                                                                                                                                                                                                                                                                                                                              | enable signal (BHE) should be used to enable data onto 5-0 <sub>B</sub> . Eight-bit oriented devices tied to the upper half of p select functions. BHE is LOW during 1, for read, write, to be transferred on the high portion of the bus. The S <sub>7</sub> T <sub>4</sub> . The signal is active LOW and floats to or the first interrupt acknowledge cycle.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
|                            |                                         |      | BHE                                                                                                                                                                                                                                                                                                                                                                                                        | Ao                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Characteristics                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | ]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
|                            |                                         | 1    | 0                                                                                                                                                                                                                                                                                                                                                                                                          | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Whole word                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
|                            |                                         | ļ    | 0                                                                                                                                                                                                                                                                                                                                                                                                          | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Upper byte from/<br>to odd address                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
|                            |                                         |      | 1                                                                                                                                                                                                                                                                                                                                                                                                          | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Lower byte from/<br>to even address                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
|                            |                                         | 1    | 1                                                                                                                                                                                                                                                                                                                                                                                                          | 11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | None                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | ]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
| 32                         | PD                                      | 0    |                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | s performing a memory of I/O read cycle, depending on ad devices which reside on the 8086 local bus. RD is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |
| JE.                        |                                         |      | active LOW du<br>8086 local bus                                                                                                                                                                                                                                                                                                                                                                            | ring T <sub>2</sub> , T <sub>3</sub> ,<br>thas floated                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | and Two of any read :<br>d.                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | cycle and is guaranteed to remain HIGH in T2 until the                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |
| 22                         | READY                                   | 1    | active LOW du<br>8086 local bus<br>This signal flos<br>READY. Is the<br>transfer. The F<br>READY. This s                                                                                                                                                                                                                                                                                                   | ring T <sub>2</sub> , T <sub>3</sub> , i has floated ats to three-<br>acknowledge acknowledge acknowled                    | and Tw of any read of the state OFF in "hold ac gment from the address at from memory/IO is the HIGH. The 8086 R                                                                                                                                                                                                                                                                                                                                                                                         | cycle and is guaranteed to remain HIGH in $T_2$ until the knowledge." sed memory or I/O device that it will complete the data synchronized by the 8284A Clock Generator to form $EADY$ input is not synchronized. Correct operation is not                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |
|                            | READY                                   | 1    | active LOW di.<br>8086 local bus<br>This signal flox<br>READY. Is the<br>transfer. The F<br>READY. This s<br>guaranteed if t<br>Interrupt Requi<br>tion to determi<br>vectored to vis                                                                                                                                                                                                                      | ring T <sub>2</sub> , T <sub>3</sub> , i has floated ats to three-<br>acknowledge AEADY signal is action to be set-up a set-up a lever if the properties of the properties an interruption of the set-up an interruption in the properties of the properties an interruption in the properties of the set-up an interruption in the set-up an interruption of the set-up an interruption in the set-up an interruption of the set-up and set-up and set-up an interruption of the set-up and set-up an interruption of set-up and                     | and Tw of any read at a state OFF in "hold ac gment from the addressal from memory/IO is two HIGH. The 8086 R and hold times are not el triggered input which occasion should enter in twector lookup table in twector lookup table."                                                                                                                                                                                                                                                                    | cycle and is guaranteed to remain HIGH in T <sub>2</sub> until the knowledge."  sed memory or I/O device that it will complete the data synchronized by the 8284A Clock Generator to form EADY input is not synchronized. Correct operation is not                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
| 22                         |                                         |      | active LOW di. 8086 local bus This signal flot READY. Is the transfer. The FREADY. This supuranteed if I Interrupt Requition to determine vectored to vis software resett TEST. Input is                                                                                                                                                                                                                   | wing T2, T3, in has floated ats to three-ats to three-ats to three-acknowledge EADY signal is actioned at the set-up a set. Is a levine if the property of the interrupting the interruptions are interrupting the interruptions are interrupted to the interruption of the interruptio                                             | and Twy of any read d. state OFF in "hold ac- gment from the addressal from memory/IO is a we HIGH. The 8086 R nd hold times are not el triggered input which occessor should enter in it vector lookup table if mupt enable bit. INTR by the "Wait" instruction in an "idle" state This                                                                                                                                                                                                                 | cycle and is guaranteed to remain HIGH in T <sub>2</sub> until the knowledge."  sed memory or 1/O device that it will complete the data synchronized by the 8284A Clock Generator to form EADY input is not synchronized. Correct operation is not met.  It is ampled during the last clock cycle of each instruction in interrupt acknowledge operation. A subroutine is ocated in system memory. It can be internally masked by                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
| 22                         | INTR                                    |      | active LOW du<br>8098 local bus<br>This signal flor<br>READY. Is the<br>transfer. The F<br>READY. This :<br>guaranteed if It<br>interrupt Required<br>software resett<br>TEST. Input is<br>wise, the procon the leading<br>Non-Maskable<br>to via an inter-                                                                                                                                                | ring T <sub>2</sub> , T <sub>3</sub> , i has floated it has floated its to three-acknowledge ADV sign, signal is actioned as the set-up a set. Is a levine if the price in an interrupting the intervention of the property of the property of the intervention of the inter                       | and Tw of any read state OFF in "hold ac ment from the address al from memory/IO is to the HIGH. The 8086 R and the strippered input which ocessor should enter in trector lookup table in mupt enable bit. INTR by the "Wait" instruction an "idle" state. This is, in edge-triggered input tookup table located in a LOW to HIGH initial.                                                                                                                                                              | cycle and is guaranteed to remain HIGH in T <sub>2</sub> until the knowledge."  sed memory or I/O device that it will complete the data synchronized by the 8284A Clock Generator to form EADY input is not synchronized. Correct operation is not met.  is sampled during the last clock cycle of each instruction an interrupt acknowledge operation. A subroutine is ocated in system memory. It can be internally masked by is internally synchronized. This signal is active HIGH.  In. If the TEST input is LOW, execution continues; other-                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
| 22<br>18<br>23             | TEST                                    | 1    | active LOW do. 8088 local bus This signal float BobB local bus This signal float READY. Is the FREADY. This signaranteed if it interrupt Requiped to determine the software resett TEST. Input is wise, the procont the leading Non-Maskable to via an international software. A trainput is international reset Causes Reset. Causes or at least for at least for at least for at least for signal float. | ining T <sub>2</sub> . T <sub>3</sub> , the first part of the section and the sectio                       | and Twy of any read.  state OFF in "hold ac- gment from the address if from memory/O is a we HIGH. The 8086 R nd hold times are not el triggered input which coessor should enter in at vector lookup table in mupt enable bit. INTR by the "Wait" instruction in an "idle" state. Thi L.K.  nedge-triggered input cookup table located in a LOW to HIGH initia ized.                                                                                                                                    | cycle and is guaranteed to remain HIGH in T <sub>2</sub> until the knowledge."  sed memory or I/O device that it will complete the data synchronized by the 8284A Clock Generator to form EADY input is not synchronized. Correct operation is not met.  In is sampled during the last clock cycle of each instruction an interrupt acknowledge operation. A subroutine is ocated in system memory. It can be internally masked by is internally synchronized. This signal is active HIGH.  In If the TEST input is LOW, execution continues; others input is synchronized internally during each clock cycle which causes a type 2 interrupt. A subroutine is vectored system memory. NMI is not maskable internally by tes the interrupt at the end of the current instruction. This timate its present activity. The signal must be active HIGH, as described in the Instruction Set description, when           |  |  |  |
| 22<br>18<br>23             | TEST NMI                                | 1    | active LOW do. 8086 local bus This signal float Bob86 local bus This signal float READY. Is the transfer. The F READY This is guaranteed it interrupt Requition to determine vectored to via software resett TEST, Input is wrise, the procon the leading Non-Maskable to via an interrupt lis interna software. A trainput is interna Reset. Causes for at least for RESET returns.                       | inting T <sub>2</sub> . T <sub>3</sub> , the solution T <sub>2</sub> . T <sub>3</sub> , the solution acknowledge acknowled | and Tw of any read.  state OFF in "hold ac ment from the address if from memory/IO is a ve HIGH. The 8086 R nd hold times are not el triggered input which coessor should enter in it vector lookup table in mupt enable bit. INTR by the "Wait" instruction in an "idle" state Thir K. In edge-triggered input rookup table located in a LOW to HIGH initia ized.  sor to immediately term less it restarts execution iest it restarts execution iest ir restarts execution iest ir restarts execution  | cycle and is guaranteed to remain HIGH in T <sub>2</sub> until the knowledge."  sed memory or I/O device that it will complete the data synchronized by the 8284A Clock Generator to form EADY input is not synchronized. Correct operation is not met.  In is sampled during the last clock cycle of each instruction an interrupt acknowledge operation. A subroutine is ocated in system memory. It can be internally masked by is internally synchronized. This signal is active HIGH.  In If the TEST input is LOW, execution continues; others input is synchronized internally during each clock cycle which causes a type 2 interrupt. A subroutine is vectored system memory. NMI is not maskable internally by tes the interrupt at the end of the current instruction. This timate its present activity. The signal must be active HIGH, as described in the Instruction Set description, when           |  |  |  |
| 22<br>18<br>23<br>17       | TEST NMI RESET                          | 1    | active LOW do. 8086 local bus This signal float Bob86 local bus This signal float READY. Is the transfer. The F READY This is guaranteed it interrupt Requition to determine vectored to via software resett TEST, Input is wrise, the procon the leading Non-Maskable to via an interrupt lis interna software. A trainput is interna Reset. Causes for at least for RESET returns.                       | inting T <sub>2</sub> . T <sub>3</sub> , the solution of the section of t                       | and Tw of any read.  state OFF in "hold ac ment from the address if from memory/IO is: ve HIGH. The 8086 R nd hold times are not el triggered input which coessor should enter in t vector lookup table is rupt enable bit. INTR by the "Wait" instructio in an "idle" state. Thi i.K.  redge-triggered input lookup table located in lookup table located in ookup table located in sor to immediately term les. It restarts executio ET is internally synchri timing for the processo internal timing. | cycle and is guaranteed to remain HIGH in T <sub>2</sub> until the knowledge."  sed memory or I/O device that it will complete the data synchronized by the 8284A Clock Generator to form EADY input is not synchronized. Correct operation is not met.  is sampled during the last clock cycle of each instruction an interrupt acknowledge operation. A subroutine is occated in system memory. It can be internally masked by internally synchronized. This signal is active HIGH.  In, If the TEST input is LOW, execution continues; others input is synchronized internally during each clock cycle which causes a type 2 interrupt. A subroutine is vectored system memory. NMI is not maskable internally by tes the interrupt at the end of the current instruction. This tinate its present activity. The signal must be active HIGH, in, as described in the Instruction Set description, when onlized.  |  |  |  |
| 22<br>18<br>23<br>17<br>21 | INTR TEST NMI RESET                     | 1    | active LOW do Bo86 local bus This signal float READY is the transfer. The F READY This is guaranteed it is Interrupt Requition to determine vectored to via software resett TEST input is wrise, the proco on the leading Non-Maskable to via an interrupt is interna Reset. Causes for at least for RESET returns Clock, Provide cycle to provide                                                         | inting T <sub>2</sub> . T <sub>3</sub> , the first part of the section of                       | and Tw of any read.  state OFF in "hold ac ment from the address if from memory/IO is: ve HIGH. The 8086 R nd hold times are not el triggered input which coessor should enter in t vector lookup table is rupt enable bit. INTR by the "Wait" instructio in an "idle" state. Thi i.K.  redge-triggered input lookup table located in lookup table located in ookup table located in sor to immediately term les. It restarts executio ET is internally synchri timing for the processo internal timing. | cycle and is guaranteed to remain HIGH in T <sub>2</sub> until the knowledge."  sed memory or I/O device that it will complete the data synchronized by the 8284A Clock Generator to form EADY input is not synchronized. Correct operation is not met.  is sampled during the last clock cycle of each instruction an interrupt acknowledge operation. A subroutine is ocated in system memory, it can be internally masked by is internally synchronized. This signal is active HIGH.  In. If the TEST input is LOW, execution continues; others input is synchronized internally during each clock cycle which causes a type 2 interrupt. A subroutine is vectored system memory. NMI is not maskable internally by tes the interrupt at the end of the current instruction. This tinate its present activity. The signal must be active HIGH, n. as described in the Instruction Set description, when bristed. |  |  |  |

\*Pin numbers correspond to DIPs only.



|          |                                            |     | PIN DESCRIPTION (continued)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |
|----------|--------------------------------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Pin No.* | Name                                       | 1/0 | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |
| 28-26    | \$2. \$1. \$0                              | 0   | Status Active during T <sub>4</sub> , T <sub>1</sub> , and T <sub>2</sub> and is returned to the passive state (1, 1, 1) during T <sub>3</sub> or during T when READY is HIGH. This status is used by the 8288 Bus Controller to generate all memory and 1/O access control signals. Any change by S <sub>2</sub> , S <sub>1</sub> , or S <sub>0</sub> during T <sub>4</sub> is used to indicate the beginning of bus cycle, and the return to the passive state in T <sub>3</sub> or T <sub>w</sub> is used to indicate the end of a bus cycle. These signals float to three-state OFF in "hold acknowledge." These status lines are encoded as show |  |  |  |  |  |  |
|          |                                            |     | S <sub>2</sub> S <sub>1</sub> S <sub>0</sub> Characteristics                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
|          | }                                          |     | 0 (LOW) 0 0 Interrupt Acknowledge                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
|          |                                            | 1   | 0 0 1 Read I/O Port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
|          | (                                          |     | 0 1 0 Write I/O Port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |
|          |                                            |     | 0 1 1 Halt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |
|          |                                            | 1   | 1 (HIGH) 0 0 Code Access                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |
|          |                                            |     | 1 0 1 Read Memory                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
|          |                                            | 1   | 1 1 0 Write Memory                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |
|          |                                            |     | 1 1 1 Passive                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |
| 31, 30   | RO/GT <sub>0</sub> .<br>RO/GT <sub>1</sub> | 1/0 | Request/Grant, Pins are used by other local bus masters to force the processor to release the local bus at the end of the processor's current bus cycle. Each pin is bidirectional with $R\overline{G}/GT_0$ having higher priority than $R\overline{G}/GT_0$ . This an internal pull-up resistor so it may be left unconnected. The request grant sequence is as follows:                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |
|          |                                            |     | 1 A pulse of 1 CLK wide from another local bus master indicates a local bus request ("hold") to the 8086 (pulse 1).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
|          |                                            |     | 2 During a T <sub>4</sub> or T <sub>1</sub> clock cycle, a pulse 1 CLK wide from the 8086 to the requesting master (pulse 2), indicates that the 8086 has allowed the local bus to float and that it will enter the "hold acknowledge state at the next CLK. The CPU's bus interface unit is disconnected logically from the local bus during "hold acknowledge."                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
|          |                                            |     | 3 A pulse 1 CLK wide from the requesting master indicates to the 8086 (pulse 3) that the "hold" request is about to end and that the 8086 can reclaim the local bus at the next CLK.                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |
|          |                                            | Ì   | Each master-master exchange of the local bus is a sequence of 3 pulses. There must be one dead CLK cycle after each bus exchange. Pulses are active LOW.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |
|          |                                            |     | If the request is made while the CPU is performing a memory cycle, it will release the local bus during $T_4$ of the cycle when all the following conditions are met:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |
|          |                                            |     | Request occurs on or before T2     Current cycle is not the low byte of a word (on an odd address).     Current cycle is not the first acknowledge of an interrupt acknowledge sequence.     A locked instruction is not currently executing.                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |
|          |                                            |     | If the local bus is idle when the request is made, two possible events will follow                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |
|          |                                            |     | Local bus will be released during the next clock.     A memory cycle will start within 3 clocks. Now the four rules for a currently active memory cycle apply with condition number 1 already satisfied.                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |
| 29       | LOCK                                       | 0   | TOCK Output indicates that other system bus masters are not to gain control of the system bus while LOCK is active LOW. The LOCK signal is activated by the "LOCK" prefix instruction and remains active until the completion of the next instruction. This signal is active LOW, and floats to three-state OFF in "hold acknowledge."                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |
| 24, 25   | QS <sub>1</sub> , QS <sub>0</sub>          | 0   | Queue Status. The queue status is valid during the CLK cycle after which the queue operation is per-<br>formed.<br>QS; and QS <sub>0</sub> provide status to allow external tracking of the internal 8086 instruction queue.                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
| 28       | M/10                                       | -   | Status line. Logically equivalent to S <sub>2</sub> in the maximum mode. It is used to distinguish a memory access                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |
|          |                                            |     | from an I/O access. M/IO becomes valid in the T <sub>4</sub> preceding a bus cycle and remains valid until the fir T <sub>4</sub> of the cycle (M = HIGH, IO = LOW). M/IO floats to three-state OFF in local bus "hold acknowledge."                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |
| 29       | WR                                         | 0   | Write. Indicates that the processor is performing a write memory or write I/O cycle, depending on the state of M/IO signal WRI is active for T <sub>2</sub> , T <sub>3</sub> , and T <sub>W</sub> of any write cycle. It is active LOW and floats to three-state OFF in local bus "hold acknowledge."                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |
| 24       | INTA                                       | 0   | INTA is used as a read strobe for interrupt acknowledge cycles, it is active LOW during T2, T3, and TW of each interrupt acknowledge cycle.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |
| 25       | ALE                                        | 0   | Address Latch Enable. Provided by the processor to latch the address into 8282/8283 address latch. It a HIGH pulse active during T <sub>1</sub> of any bus cycle. Note that ALE is never floated.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
| 27       | DT/A                                       | 0   | Data Transmit/Receive. Needed in minimum system that desires to use an 8286/8287 data bus transceiver. It is used to control the direction of data flow through the transceiver. Logically $DT/\overline{R}$ is equivalent to $\overline{S}_1$ in the maximum mode, and its timing is the same as for $M/\overline{IO}$ . (T = HIGH, R = LOW) This signal floats to three-state OFF in local bus "hold acknowledge."                                                                                                                                                                                                                                  |  |  |  |  |  |  |
| 26       | DEN                                        | 0   | Data Enable Provided as an output enable for the 8286/8287 in a minimum system which uses the transceiver DEN is active LOW during each memory and I/O access and for INTA cycles. For a read or INTA cycle, it is active from the middle of $T_2$ until the middle of $T_3$ , while for a write cycle, it is active from the beginning of $T_2$ until the middle of $T_4$ . DEN floats to three-state OFF in local bus "hold acknowledge".                                                                                                                                                                                                           |  |  |  |  |  |  |

\*Pin numbers correspond to DIPs only

1-8

#### PIN DESCRIPTION (continued)

| FIN DESCRIPTION (continued) |               |                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
|-----------------------------|---------------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Pin No.*                    | Name          | Name I/O Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
| 31, 30                      | HOLD,<br>HLDA | 1/0                  | HOLD, indicates that another master is requesting a local bus "hold." To be acknowledged, HOLD must be active HIGH. The processor receiving the "hold" request will issue HLDA (HIGH) as an acknowledgement in the middle of a T <sub>d</sub> or T <sub>1</sub> clock cycle. Simultaneous with the issuance of HLDA, the processor will float the local bus and control lines. After HOLD is detected as being LOW, the processor will LOWer HLDA, and when the processor needs to run another cycle, it will again drive the local bus and control lines.  The same rules as for RQ/GT apply, regarding when the local bus will be released. |  |  |  |  |
|                             |               |                      | HOLD is not asynchroneous input. External synchronization should be provided if the system cannot otherwise guarantee the set-up time.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |

<sup>\*</sup>Pin numbers correspond to DIPs only

# **DETAILED DESCRIPTION**

The 8086 CPU is internally organized into two processing units. These two units are the Bus Interface Unit (BIU) and the Execution Unit (EU). A block diagram of this organization is shown on page 1.

The BIU performs instruction fetch and queuing, operand fetch and store, address relocation, and basic bus control. The EU receives operands and instructions from the BIU and processes them on a 16-bit ALU. The EU accesses memory and peripheral devices through requests to the BIU. The BIU generates physical addresses in memory using the 4 segment registers and offset values.

The BIU and EU usually operate asynchronously. This permits the 8086 to overlap execution fetch and execution. Up to 6 instruction bytes can be queued. The instruction queue acts as a FIFO buffer for instructions, from which the EU extracts instruction bytes as required.

#### **Memory Organization**

The 8086 addresses up to 1 megabyte of memory. The address space is organized as a linear array, from 00000 to FFFFF in hexadecimal. Memory is subdivided into segments of 64K bytes each. There are 4 segments: code, stack, data, and extra (usually employed as an extra data segment). Each

segment thus contains information of a similar type. Selection of a destination segment is automatically performed using the rules in the table below. This segmentation makes memory more easily relocatable and supports a more structured programming style.

Physical addresses in memory are generated by selecting the appropriate segment, obtaining the segment "base" address from the segment register, shifting the base address 4 digits to the left, and then adding this base to the "offset" address. For programming code, the offset address is obtained from the instruction pointer. For operands, the offset address is calculated in several ways, depending upon information contained in the addressing mode. Memory organization and address generation are shown in Figure 1a.

Certain memory locations are reserved for specific CPU operations. These are shown in Figure 1b. Addresses FFFFOH through FFFFFH are reserved for operations which include a jump to the initial program loading routine. After RESET, the CPU will always begin execution at location FFFFOH, where the jump must be located.

Addresses 00000H through 003FFH are reserved for interrupt operations. The service routine of each of the 256 possible interrupt types is signaled by a 4-byte pointer. The pointer elements must be stored in reserved memory addresses before the interrupts are invoked.



Figure 1a. Memory Organization

Figure 1b. Reserved Memory Locations



| Memory Reference Need  | Segment Register<br>Used | Segment Selection Rule                                                                                           |
|------------------------|--------------------------|------------------------------------------------------------------------------------------------------------------|
| instructions           | CODE (CS)                | Automatic for all prefetching of instructions.                                                                   |
| Stack                  | STACK (SS)               | All stack pushes and pops, and all memory references relative to BP base register except data references.        |
| Local Data             | DATA (DS)                | Data references which are relative to the stack, the destination of a string operation, or explicitly overriden. |
| External (Global) Data | EXTRA (ES)               | Destination of string operations, when they are explicitly selected using a segment override.                    |

#### Minimum and Maximum Modes

The 8086 has two system configurations, minimum and maximum mode. The CPU has a strap pin, MN/ $\overline{\rm MX}$ , which defines the system configuration. The status of this strap pin defines the function of pin numbers 24 through 31.

When MN/MX is strapped to GND, the 8086 operates in maximum mode. The operations of pins 24 through 31 are redefined. In maximum mode, several bus timing and control functions are "off-loaded" to the 8288 bus controller, thus

freeing up the CPU. The CPU communicates status information to the 8288 through pins  $S_0,\,S_1,\,$  and  $S_2.\,$  In maximum mode, the 8086 can operate in a multiprocessor system, using the LOCK signal within a Multibus format.

When MN/ $\overline{MX}$  is strapped to V<sub>CC</sub>, the 8086 operates in minimum mode. The CPU sends bus control signals itself through pins 24 through 31. This is shown in the Connection Diagrams (in parentheses). Examples of minimum and maximum mode systems are shown in Figure 2.



Figure 2a. Minimum Mode 8086 Typical Configuration



Figure 2b. Maximum Mode 8086 Typical Configuration

# **Bus Operation**

The 8086 has a combined address and data bus, commonly referred to as "a time multiplexed bus." This technique provides the most efficient use of pins on the processor while permitting the use of a standard 40-lead package. This bus can be used throughout the system with address latching provided on memory and I/O modules. The bus can also be demultiplexed at the processor with a single set of address latches if a standard non-multiplexed bus is desired for the system.

Each bus cycle consists of at least four CLK cycles. These are referred to as  $T_1,\,T_2,\,T_3$  and  $T_4$  (see Figure 5). The address is sent from the processor during  $T_1.$  Data transfer occurs on the bus during  $T_3$  and  $T_4,\,T_2$  is used for changing the direction of the bus during read operations. In the event that a "NOT READY" indication is given by the addressed device, "Wait" states (T<sub>W</sub>) are inserted between  $T_3$  and  $T_4.$  Each inserted "Wait" state is of the same duration as a CLK cycle. "Idle" states (T\_1) or inactive CLK cycles can occur between 8086 bus cycles. The processor uses these cycles for internal housekeeping.

During T<sub>1</sub> of any bus cycle, the ALE (Address Latch Enable) signal is emitted (by either the processor or the 8288 bus controller, depending on the MN/ $\overline{\rm MN}$  strap). At the trailing edge of this pulse, a valid address and certain status information for the cycle may be latched.

Status bits  $\overline{S_0}$ ,  $\overline{S_1}$ , and  $\overline{S_2}$  are used, in maximum mode, by the bus controller to identify the type of bus transaction according to the following table:

|         | ₹ <sub>1</sub> | Ī5₀ | Characteristics        |
|---------|----------------|-----|------------------------|
| 0(LOW)  | 0              | 0   | Interrupt Acknowledge  |
| 0       | 0              | 1   | Read I/O               |
| 0       | 1              | 0   | Write I/O              |
| 0       | 1              | 1   | Hait                   |
| 1(HIGH) | 0              | 0   | Instruction Fetch      |
| 1       | 0              | 1   | Read Data from Memory  |
| 1       | 1              | 0   | Write Data to Memory   |
| 1       | 1              | 1   | Passive (no bus cycle) |

Status bits  $S_3$  through  $S_7$  are multiplexed with high-order address bits and the BHE signal, and are therefore valid during  $T_2$  through  $T_4$ .  $S_3$  and  $S_4$  indicate which segment register (see instruction Set description) was used for this bus cycle in forming the address, according to the following table:

| S <sub>4</sub> | S <sub>3</sub> | Characteristics                |
|----------------|----------------|--------------------------------|
| 0(LOW)         | 0              | Alternate Data (extra segment) |
| 0              | 1              | Stack                          |
| 1(HIGH)        | 0              | Code or None                   |
| 1              | 1              | Data                           |

 $S_5$  is a reflection of the PSW interrupt enable bit.  $S_6 = 0$  and  $S_7$  is a spare status bit.

#### I/O Addressing

8086 I/O operations can address up to a maximum of 64K I/O byte registers or 32K I/O word registers. The I/O address appears in the same format as the memory address on bus lines  $A_{15}\text{--}A_0$ . The address lines  $A_{19}\text{--}A_{16}$  are zero in I/O operations. I/O instructions which use register DX as a pointer have full address capability. Direct I/O instructions directly address one or two of the 256 I/O byte locations in page 0 of the I/O address space. I/O ports are addressed in the same manner as memory locations.



# Figure 3. Basic System Timing

# **EXTERNAL INTERFACE**

#### Processor Reset and Initialization

Processor initialization or start up is accomplished with activation (HIGH) of the RESET pin. The 8086 RESET is required to be HIGH for greater than 4 CLK cycles. The 8086 will terminate operations on the high-going edge of RESET and will remain dormant as long as RESET is HIGH. The low-going transition of RESET triggers an internal reset sequence for approximately 10 CLK cycles. After this interval the 8086 operates normally beginning with the instruction in absolute location FFFF0H (see Figure 1b). The details of this operation are explained in the Instruction Set description of the MCS-86 Family User's Manual. The RESET input is internally synchronized to the processor clock. At initialization the HIGH-to-LOW transition of RESET must occur no sooner than 50µs after power-up, to allow complete initialization of the 8086.

NMI may not be asserted prior to the 2nd CLK cycle following the end of RESET.

# interrupt Operations

Interrupt operations fall into two classes: software or hardware initiated. The software initiated interrupts and software aspects of hardware interrupts are described in the Instruction Set description. Hardware interrupts are either non-maskable or maskable.

Interrupts transfer control to a new program location. A 256-element table containing address pointers to the interrupt service program locations resides in absolute locations through 3FFH (see Figure 1b), which are reserved for this purpose. Each element in the table is 4 bytes in size and corresponds to an interrupt "type." An interrupting device supplies an 8-bit type number during the interrupt acknowledge sequence, which is used to "vector" through the appropriate element to the new interrupt service program location.

#### Non-Maskable Interrupt (NMI)

The processor provides a single non-maskable interrupt pin (NMI) which has higher priority than the maskable interrupt request pin (INTR). A typical use would be to activate a power

failure routine. The NMI is edge-triggered on a LOW-to-HIGH transition. The activation of this pin causes a type 2 interrupt. (See Instruction Set description.)

NMI is required to have a duration in the HIGH state of greater than two CLK cycles, but is not required to be synchronized to the clock. Any high-going transition of NMI is latched on-chip and will be serviced at the end of the current instruction or between whole moves of a block-type instruction. Worst case response to NMI would be to multiply, divide, and variable shift instructions. There is no specification on the occurrence of the low-going edge; it may occur before, during, or after the servicing of NMI. Another high-going edge triggers another response if it occurs after the start of the NMI procedure. The signal must be free of logical spikes in general and be free of bounces on the low-going edge to avoid triggering extraneous responses.

#### Maskable Interrupt (INTR)

The 86/10 provides a single interrupt request input (INTR) which can be masked internally by software with the resetting of the interrupt enable FLAG status bit. The interrupt request signal is level-triggered. It is internally synchronized during each clock cycle on the high-going edge of CLK. To be responded to, INTR must be present (HIGH) during the clock period preceding the end of the current instruction or the end of a whole move for a block-type instruction. During the interrupt response sequence, further interrupts are disabled. The enable bit is reset as part of the response to any interrupt (INTR, IMI, software interrupt, or single-step), although the FLAGS register, which is automatically pushed onto the stack, reflects the state of the processor prior to the Interrupt. Until the old FLAGS register is restored, the enable bit will be zero unless specifically set by an instruction.

During the response sequence (Figure 4), the processor executes two successive (back-to-back) interrupt acknowledge cycles. The 8086 emils the LOCK signal from T<sub>2</sub> of the first bus cycle until T<sub>2</sub> of the second. A local bus "hold" request will not be honored until the end of the second bus cycle. In the second bus cycle, a byte is fetched from the external interrupt system (e.g., 8259A PIC) which identifies the source (type) of the interrupt. This byte is multiplied by four and used as a pointer into the interrupt vector lookup table. An INTR signal left HIGH will be continually responded to within the limitations of the enable bit and sample period. The INTERRUPT RETURN instruction includes a FLAGS pop, which returns the status of the original interrupt enable bit when it restores the FLAGS.

#### HALT

When a software "HALT" instruction is executed, the processor indicates that it is entering the "HALT" state in one of two ways depending upon which mode is strapped. In minimum mode, the processor issues one ALE with no qualifying bus control signals. In Maximum Mode, the processor issues appropiate HALT status on  $\overline{S}_2\overline{S}_1\overline{S}_0$ , and the 8288 bus controller issues one ALE. The 8086 will not leave the "HALT" state when a local bus "hold" is entered while in "HALT." In this case, the processor reissues the HALT indicator. An interrupt request or RESET will force the 8086 out of the "HALT" state.

# Read/Modify/Write (Semaphore) Operation Via Lock

The LOCK status information is provided by the processor when directly consecutive bus cycles are required during the execution of an instruction. This provides the processor with the capability of performing read/modify/write operations on memory (via the Exchange Register With Memory Instruction, for example) without the possibility of another system bus

master receiving intervening memory cycles. This is useful in multiprocessor system configurations to accomplish "test and set lock" operations. The LOCK signal is activated (forced LOW) in the clock cycle following the one in which the software "LOCK" prefix instruction is decoded by the EU. It is deactivated at the end of the last bus cycle of the instruction following the "LOCK" prefix instruction. While LOCK is active, a request on a RO/GT pin will be recorded and then honored at the end of the LOCK.

#### **External Synchronization Via Test**

As an alternative to the interrupts and general I/O capabilities, the 8086 provides a single software-testable input known as the TEST signal. At any time, the program may execute a WAIT instruction. If at that time the TEST signal is inactive (HIGH), program execution becomes suspended while the processor waits for TEST to become active. It must remain active for at least 5 CLK cycles. The WAIT instruction is re-executed repeatedly until that time. This activity does not consume bus cycles. The processor remains in an idle state while waiting. All 8086 drivers go to three-state OFF if bus "HOLD" is entered. If interrupts are enabled, they may occur while the processor is waiting. When this occurs, the processor fetches the WAIT instruction one extra time, processes the interrupt, and then re-fetches and re-executes the WAIT instruction upon returning from the interrupt.

#### **Basic System Timing**

Typical system configurations for the processor operating in minimum mode and in maximum mode are shown in Figures 2a and 2b, respectively. In minimum mode, the processor emits bus control signals in a manner similar to the 8085. In maximum mode, the processor emits coded status information which the 8288 bus controller uses to generate MULTIBUS compatible bus control signals. Figure 3 illustrates the signal timing relationships.

# System Timing - Minimum System

The read cycle begins in T1 with the assertion of the Address Latch Enable (ALE) signal. The trailing (low-going) edge of this signal is used to latch the address information, which is valid on the local bus at this time, into the 8282/8283 latch. The BHE and Ao signals address the low, high, or both bytes. From T<sub>1</sub> to T<sub>4</sub>, the M/IO signal indicates a memory or I/O operation. At To the address is removed from the local bus and the bus goes to a high impedance state. The read control signal is also asserted at T2. The read (AD) signal causes the addressed device to enable its data bus drivers to the local bus. Some time later valid data will be available on the bus and the addressed device will drive the READY line HIGH. When the processor returns the read signal to a HIGH level, the addressed device will again 3-state its bus drivers. If a transceiver (8286/8287) is required to buffer the 8086 local bus, signals DT/R and DEN are provided by the 8086.

A write cycle also begins with the assertion of ALE and the emission of the address. The  $M/\overline{O}$  signal is again asserted to indicate a memory or I/O write operation. In the  $T_2$  immediately following the address emission, the processor emits the data to be written into the addressed location. This data remains valid until the middle of  $T_4$ . During  $T_2$ ,  $T_3$ , and  $T_W$ , the processor asserts the write control signal. The write  $(\overline{WR})$  signal becomes active at the beginning of  $T_2$  as opposed to the read which is delayed somewhat into  $T_2$  to provide time for the bus to float.

The  $\overline{\text{BHE}}$  and  $A_0$  signals are used to select the proper byte(s) of the memory/IO word to be read or written according to the following table.



| BHE | 8 | Characteristics                 |  |  |  |  |
|-----|---|---------------------------------|--|--|--|--|
| ٥   | 0 | Whole word                      |  |  |  |  |
| 0   | 1 | Upper byte from/to odd address  |  |  |  |  |
| 1   | 0 | Lower byte from/to even address |  |  |  |  |
| 1   | 1 | None                            |  |  |  |  |

1/O ports are addressed in the same manner as memory location. Even addressed bytes are transferred on the  $D_7$ – $D_0$  bus lines and odd addressed bytes on  $D_{15}$ – $D_8$ .

The basic difference between the interrupt acknowledge cycle and a read cycle is that the interrupt acknowledge signal (INTA) is asserted in place of the read (RD) signal and the address bus is floated. (See Figure 6.) In the second of two successive INTA cycles, a byte of information is read from bus lines  $D_7\!-\!D_0$  as supplied by the interrupt system logic (i.e., 8259A Priority Interrupt Controller). This byte identifies the source (type) of the interrupt. It is multiplied by four and used as a pointer into a interrupt vector lookup table, as described earlier.

#### Bus Timing - Medium Size Systems

For medium size systems, the MN/ $\overline{MX}$  pin is connected to V<sub>SS</sub>, and the 8288 Bus Controller is added to the system as well as

an 8282/8283 latch for latching the system address and a 8286/8287 transceiver to allow for bus loading greater than the 8086 is capable of handling. Signals ALE, DEN, and DT/R are generated by the 8288 instead of the processor in this configuration, although their timing remains relatively the same. The 8086 status (\$\overline{S}\_2\$, \$\overline{S}\_1\$, and \$\overline{S}\_0\$) provide type-of-cycle information and become 8288 inputs. This bus cycle information specifies read (code, data, or I/O), write (data or I/O), interrupt acknowledge, or software halt. The 8288 thus issues control signals specifying memory read or write, I/O read or write, or interrupt acknowledge. The 8288 provides two types of write strobes, normal and advanced, to be applied as required. The normal write strobes have data valid at the leading edge of write. The advanced write strobes have the same timing as read strobes, and hence, data isn't valid at the leading edge of write. The 8286/8287 transceiver receives the usual T and OE inputs from the 8288's DT/A and DEN.

The pointer into the interrupt vector table, which is passed during the second INTA cycle, can derive from an 8259A located on either the local bus or the system bus. If the master 8259A Priority Interrupt Controller is positioned on the local bus, a TTL gate is required to disable the 8286/8287 transceiver when reading from the master 8259A during the interrupt acknowledge sequence and software "poll."



## **ABSOLUTE MAXIMUM RATINGS**

| Storage Temperature65          | to | + 150°C |
|--------------------------------|----|---------|
| Ambient Temperature Under Bias | 0  | to 70°C |
| Voltage on any Pin             |    |         |
| with Respect to Ground1        | to | +7.0 V  |
| Power Dissipitation            |    | 2.5 W   |

Stresses above those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent device failure. Functionality at or above these limits is not implied. Exposure to absolute maximum ratings for extended periods may affect device reliability.

## **OPERATING RANGES**

| Commercial (C) Devices  Temperature (T <sub>A</sub> ) | С |
|-------------------------------------------------------|---|
| 8086 5 V ± 109                                        | 6 |
| 8086-1, 8086-2 5 V ± 59                               | 6 |
| ndustrial (I) Devices                                 |   |
| Temperature (T <sub>A</sub> )40 to +85°               | С |
| Supply Voltage (VCC)                                  |   |
|                                                       |   |
| 8086 5 V ± 109                                        | 6 |

Operating ranges define those limits between which the functionality of the device is guaranteed.

# DC CHARACTERISTICS over COMMERCIAL operating range

| Parameters      | Description                                                                              | Test Conditions                            | Min   | Max                   | Unite |
|-----------------|------------------------------------------------------------------------------------------|--------------------------------------------|-------|-----------------------|-------|
| V <sub>IL</sub> | Input Low Voltage                                                                        |                                            | -0.5  | + 0.8                 | V     |
| ViH             | Input High Voltage                                                                       |                                            | 2.0   | V <sub>CC</sub> + 0.5 | V     |
| VOL             | Output Low Voltage                                                                       | I <sub>OL</sub> = 2.5 mA                   |       | 0.45                  | V     |
| Voh             | Output High Voltage                                                                      | I <sub>OH</sub> = ~400 μA                  | 2.4   |                       | V     |
| Icc             | Power Supply Current                                                                     | All Speeds                                 |       | 340                   | mA    |
| lui             | Input Leakage Current                                                                    | ov ≤ v <sub>IN</sub> ≤ v <sub>CC</sub>     |       | ± 10                  | μА    |
| LO              | Output Leakage Current                                                                   | 0.45V ≤ V <sub>OUT</sub> ≤ V <sub>CC</sub> |       | ±10                   | μА    |
| V <sub>CL</sub> | Clock Input Low Voltage                                                                  |                                            | - 0.5 | + 0.6                 | ٧     |
| V <sub>CH</sub> | Clock Input High Voltage                                                                 |                                            | 3.9   | V <sub>CC</sub> + 1.0 | ٧     |
| Cin             | Capacitance of Input Buffer (All input except AD <sub>0</sub> -AD <sub>15</sub> , RO/GT) | Ic = 1 MHz                                 |       | 15                    | ρF    |
| C <sub>IO</sub> | Capacitance of 1/O Buffer (AD <sub>0</sub> -AD <sub>15</sub> , RQ/GT)                    | fc = 1 MHz                                 |       | 15                    | pF    |

# SWITCHING CHARACTERISTICS over COMMERCIAL operating range MINIMUM COMPLEXITY SYSTEM TIMING REQUIREMENTS

|            |                                                | Test              | 8086 |     | 8086- | -2  | 8086-1 |     | İ     |
|------------|------------------------------------------------|-------------------|------|-----|-------|-----|--------|-----|-------|
| Parameters | Description                                    | Conditions        | Min  | Max | Min   | Max | Min    | Max | Units |
| TCLCL      | CLK Cycle Period                               |                   | 200  | 500 | 125   | 500 | 100    | 500 | ns    |
| TCLCH      | CLK Low Time                                   |                   | 118  |     | 68    |     | 53     |     | ns    |
| TCHCL      | CLK High Time                                  |                   | 69   |     | 44    |     | 39     |     | ns    |
| TCH1CH2    | CLK Rise Time                                  | From 1.0 to 3.5V  |      | 10  |       | 10  |        | 10  | ns    |
| TCL2CL1    | CLK Fall Time                                  | From 3.5 to 1.0V  |      | 10  |       | 10  | •      | 10  | ns    |
| TDVCL      | Data in Set-up Time                            |                   | 30   |     | 20    |     | 5      |     | ns    |
| TCLDX      | Data in Hold Time                              |                   | 10   |     | 10    |     | 10     |     | ns    |
| TRIVCL     | RDY Set-up Time into 8284A<br>(See Notes 1, 2) |                   | 35   |     | 35    |     | 35     |     | ns    |
| TCLR1X     | RDY Hold Time into 8284A<br>(See Notes 1, 2)   |                   | 0    |     | 0     |     | 0      |     | ns    |
| TRYHCH     | READY Set-up Time into 8086                    |                   | 118  |     | 68    |     | 53     |     | ns    |
| TCHRYX     | READY Hold Time into 8086                      | T - T             | 30   |     | 20    |     | 20     |     | ns    |
| TRYLCL     | READY Inactive to CLK<br>(See Note 3)          |                   | -8   |     | -8    |     | - 10   |     | ns    |
| THVCH      | HQLD Set-up Time                               |                   | 35   |     | 20    |     | 20     | 7   | ns    |
| TINVCH     | INTR, NMI, TEST Set-up<br>Time (See Note 2)    |                   | 30   |     | 15    |     | 15     |     | ns    |
| TILIH      | Input Rise Time<br>(Except CLK)                | From 0.8 to 2.0 V |      | 20  |       | 20  |        | 20  | ns    |
| TIHIL      | Input Fall Time (Except CLK)                   | From 2.0 to 0.8 V |      | 12  |       | 12  |        | 12  | ns    |

Notes. 1. Signal at 8284A shown for reference only.

2. Set-up requirement for asynchronous signal only to guarantee recognition at next CLK.

3. Applies only to T2 state (8ns into T3)



# **SWITCHING CHARACTERISTICS** over **COMMERCIAL** operating range (continued) TIMING RESPONSES

|            |                                       | Test                                         | 8086        |     | 8086-2      |     | 8086-1      |     |       |  |
|------------|---------------------------------------|----------------------------------------------|-------------|-----|-------------|-----|-------------|-----|-------|--|
| Parameters | Description                           | Conditions                                   | Min         | Max | Min         | Max | Min         | Max | Units |  |
| TCLAV      | Address Valid Delay                   |                                              | 10          | 110 | 10          | 60  | 10          | 50  | ns    |  |
| TCLAX      | Address Hold Time                     | ]                                            | 10          |     | 10          |     | 10          |     | ns    |  |
| TCLAZ      | Address Float Delay                   | ]                                            | TCLAX       | 80  | TCLAX       | 50  | 10          | 40  | ns    |  |
| TLHLL      | ALE Width                             | ]                                            | TCLCH - 20  |     | TCLCH - 10  |     | TCLCH - 10  |     | ns    |  |
| TCLLH      | ALE Active Delay                      |                                              |             | 80  |             | 50  |             | 40  | ns    |  |
| TCHLL      | ALE inactive Delay                    |                                              |             | 85  |             | 55  |             | 45  | ns    |  |
| TLLAX      | Address Hold Time to<br>ALE Inactive  | ]                                            | TCHCL - 10  |     | TCHCL - 10  |     | TCHCL - 10  |     | ns    |  |
| TCLDV      | Data Valid Delay                      |                                              | 10          | 110 | 10          | 60  | 10          | 50  | ns    |  |
| TCHDX      | Data Hold Time                        |                                              | 10          |     | 10          |     | 10          |     | ns    |  |
| TWHDX      | Data Hold Time After WR               |                                              | TCLCH - 30  | 1   | TCLCH - 30  |     | TCLCH - 25  |     | ns    |  |
| TCVCTV     | Control Active Delay 1                | 1                                            | 10          | 110 | 10          | 70  | 10          | 50  | ns    |  |
| TCHCTV     | Control Active Delay 2                | *C <sub>L</sub> = 20-100 pF                  | 10          | 110 | 10          | 60  | 10          | 45  | ns    |  |
| TCVCTX     | Control Inactive Delay                | for all 8086<br>Outputs (in addition         | 10          | 110 | 10          | 70  | 10          | 50  | ns    |  |
| TAZRL      | Address Float to<br>READ active       | to 8086 self-load).<br>Typical Ct. = 100 pF. | 0           |     | 0           |     | 0           |     | ns    |  |
| TCLAL      | RD Active Delay                       | 1                                            | 10          | 165 | 10          | 100 | 10          | 70  | nş    |  |
| TCLRH      | RD Inactive Delay                     |                                              | 10          | 150 | 10          | 80  | 10          | 60  | ns    |  |
| TRHAV      | RD Inactive to Next<br>Address Active | ]                                            | TCLCL - 45  |     | TCLCL -40   |     | TCLCL - 35  |     | ns    |  |
| TCLHAV     | HLDA Valid Delay                      |                                              | 10          | 160 | 10          | 100 | 10          | 60  | ns    |  |
| TRLRH      | RD Width                              | 1                                            | 2TCLCL - 75 |     | 2TCLCL -50  |     | 2TCLCL - 40 |     | ns    |  |
| TWLWH      | WR Width                              | 1                                            | 2TCLCL -60  |     | 2TCLCL - 40 |     | 2TCLCL - 35 |     | ns    |  |
| TAVAL      | Address Valid to ALE Low              | 1                                            | TCLCH - 60  |     | TCLCH - 40  |     | TCLCH - 35  |     | ns    |  |
| TOLOH      | Output Rise Time                      | From 0.8 to 2.0 V                            |             | 20  |             | 20  |             | 20  | ns    |  |
| TOHOL      | Output Fall Time                      | From 2.0 to 0.8 V                            | 1           | 12  |             | 12  |             | 12  | ns    |  |

# SWITCHING TEST INPUT/OUTPUT WAVEFORM

# 0.45 TEST POINTS 1.5 WF009381

# SWITCHING TEST LOAD CIRCUIT



AC Testing inputs are driven at 2.4 V for a logic "1" and 0.45 V for a logic "0." Timing measurements are made at 1.5 V for both a logic "1" and "0."

Ci includes jig capacitance



# SWITCHING CHARACTERISTICS over COMMERCIAL operating range (continued) MAX MODE SYSTEM (USING 8288 BUS CONTROLLER) TIMING REQUIREMENTS

|            |                                                                 | Test              | 808 | 5   | 8086-2 |     | 8086-1 |     | l     |
|------------|-----------------------------------------------------------------|-------------------|-----|-----|--------|-----|--------|-----|-------|
| Parameters | ters Description Conditions                                     | Conditions        | Min | Max | Min    | Max | Min    | Max | Units |
| TCLCL      | CLK Cycle Period                                                |                   | 200 | 500 | 125    | 500 | 100    | 500 | ns    |
| TCLCH      | CLK Low Time                                                    |                   | 118 |     | 68     | 1 1 | 53     | 1   | ns    |
| TCHCL      | CLK High Time                                                   |                   | 69  |     | 44     |     | 39     | 1 - | ns    |
| TCH1CH2    | CLK Rise Time                                                   | From 1.0 to 3.5 V |     | 10  | •      | 10  |        | 10  | ns    |
| TCL2CL1    | CLK Fall Time                                                   | From 3.5 to 1.0 V | _   | 10  | •      | 10  |        | 10  | ns    |
| TDVCL      | Data in Set-up Time                                             |                   | 30  |     | 20     |     | 5      |     | ns    |
| TCLDX      | Data in Hold Time                                               |                   | 10  |     | 10     | 1 1 | 10     |     | ns    |
| TRIVCL     | RDY Set-up Time into 6284A<br>(See Notes 1, 2)                  |                   | 35  |     | 35     |     | 35     |     | ns    |
| TCLR1X     | RDY Hold Time into 8284A<br>(See Notes 1, 2)                    |                   | 0   |     | 0      |     | 0      |     | ns    |
| TRYHCH     | READY Set-up Time into 8086                                     |                   | 118 |     | 68     |     | 53     |     | ns    |
| TCHRYX     | READY Hold Time into 8086                                       |                   | 30  |     | 20     |     | 20     |     | ns    |
| TRYLCL     | READY Inactive to CLK<br>(See Note 4)                           |                   | - 8 |     | -8     |     | - 10   |     | ns    |
| TINVCH     | Set-up Time for Recognition<br>(INTR, NMI, TEST<br>(See Note 2) |                   | 30  |     | 15     |     | 15     |     | ns    |
| TGVCH      | RO/GT Set-up Time                                               |                   | 30  | 11  | 15     |     | 12     |     | ns    |
| TCHGX      | AQ Hold Time into 8066                                          |                   | 40  |     | 30     |     | 20     |     | ns    |
| TILIH      | Input Rise Time<br>(Except CLK)                                 | From 0.8 to 2.0 V |     | 20  |        | 20  |        | 20  | ns    |
| TIHIL      | Input Fall Time<br>(Except CLK)                                 | From 2.0 to 0.8 V |     | 12  |        | 12  |        | 12  | ns    |

Notes: 1. Signal at 8284A or 8288 shown for reference only

Set-up requirement for asynchronous signal only to guarantee recognition at next CLK.
 Applies only to T3 and wait states

4. Applies only to T2 state (8ns into T3).



# SWITCHING CHARACTERISTICS over COMMERCIAL and INDUSTRIAL ranges (continued) TIMING RESPONSES

| _          | <u> </u>                                         | Test                                    | 8086                                             | 8086 |             | 8086-2 |             | 8086-1 |       |
|------------|--------------------------------------------------|-----------------------------------------|--------------------------------------------------|------|-------------|--------|-------------|--------|-------|
| Parameters | Description                                      | Conditions                              | Min                                              | Max  | Min         | Max    | Min         | Max    | Units |
| TCLML      | Command Active Delay<br>(See Note 1)             |                                         | 10                                               | 35   | 10          | 35     | 10          | 35     | ns    |
| TCLMH      | Command Inactive Delay<br>(See Note 1)           |                                         | 10                                               | 35   | 10          | 35     | 10          | 35     | ns    |
| TRYHSH     | READY Active to Status<br>Passive (See Note 3)   |                                         |                                                  | 110  |             | 65     |             | 45     | ns    |
| TCHSV      | Status Active Delay                              | ]                                       | 10                                               | 110  | 10          | 60     | 10          | 45     | ns    |
| TCLSH      | Status inactive Delay                            |                                         | 10                                               | 130  | 10          | 70     | 10          | 55     | ns    |
| TCLAV      | Address Valid Delay                              |                                         | 10                                               | 110  | 10          | 60     | 10          | 50     | ns    |
| TCLAX      | Address Hold Time                                |                                         | 10                                               |      | 10          |        | 10          |        | ns    |
| TCLAZ      | Address Float Delay                              | 7                                       | TCLAX                                            | 80   | TCLAX       | 50     | 10          | 40     | ns    |
| TSVLH      | Status Valid to ALE High<br>(See Note 1)         | 1                                       |                                                  | 15   |             | 15     |             | 15     | ns    |
| TSVMCH     | Status Valid to MCE High (See Note 1)            |                                         |                                                  | 15   |             | 15     |             | 15     | ns    |
| TCLLH      | CLK Low to ALE Valid<br>(See Note 1)             |                                         |                                                  | 15   |             | 15     |             | 15     | ns    |
| TCLMCH     | CLK Low to MCE High<br>(See Note 1)              |                                         |                                                  | 15   |             | 15     |             | 15     | ns    |
| TCHLL      | ALE Inactive Delay<br>(See Note 1)               | CL = 20-100 pF<br>for all 8086          |                                                  | 15   |             | 15     |             | 15     | ns    |
| TCLMCL     | MCE Inactive Delay<br>(See Note 1)               | Outputs (in addition to 8086 self-load) |                                                  | 15   |             | 15     |             | 15     | ns    |
| TCLDV      | Data Valid Delay                                 |                                         | 10                                               | 110  | 10          | 60     | 10          | 50     | ns    |
| TCHDX      | Data Hold Time                                   | 7                                       | 10                                               |      | 10          |        | 10          |        | ns    |
| TCVNV      | Control Active Delay<br>(See Note 1)             |                                         | 5                                                | 45   | 5           | 45     | 5           | 45     | ns    |
| TCVNX      | Control Inactive Delay<br>(See Note 1)           |                                         | 10                                               | 45   | 10          | 45     | 10          | 45     | ns    |
| TAZRL      | Address Float to<br>Read Active                  |                                         | 0                                                |      | 0           |        | 0           |        | ns    |
| TCLRL      | RD Active Delay                                  | 7                                       | 10                                               | 165  | 10          | 100    | 10          | 70     | ns    |
| TCLRH      | RD Inactive Delay                                |                                         | 10                                               | 150  | 10          | 60     | 10          | 60     | ns    |
| TRHAV      | RD Inactive to Next<br>Address Active            | 1                                       | TCLCL -45                                        |      | TCLCL - 40  |        | TCLCL - 35  |        | ns    |
| TCHDTL     | Direction Control Active<br>Delay (See Note 1)   |                                         |                                                  | 50   |             | 50     |             | 50     | ns    |
| TCHDTH     | Direction Control Inactive<br>Delay (See Note 1) |                                         |                                                  | 30   |             | 30     |             | 30     | ns    |
| TCLGL      | GT Active Delay                                  |                                         | 0                                                | 85   | 0           | 50     | 0           | 38     | ns    |
| TCLGH      | GT Inactive Delay                                |                                         | 0                                                | 85   | 0           | 50     | 0           | 45     | пs    |
| TALAH      | AD Width                                         | 7                                       | 2TCLCL - 75                                      |      | 2TCLCL - 50 | _      | 2TCLCL - 40 |        | ns    |
| TOLOH      | Output Rise Time                                 | From 0.8 to 2.0 V                       | 1 -                                              | 20   |             | 20     |             | 20     | ns    |
| TOHOL      | Output Fall Time                                 | From 2.0 to 0.8 V                       | <del>                                     </del> | 12   |             | 12     |             | 12     | ns    |

Notes: 1. Signal at 8284A or 8288 shown for reference only.

Set-up requirement for asynchronous signal only to guarantee recognition at next CLK.
 Applies only to T3 and wail states.

<sup>4.</sup> Applies only to T2 state (8ns into T3)

# **ABSOLUTE MAXIMUM RATINGS**

## Storage Temperature ...... -65 to +150°C Ambient Temperature Under Bias ...... 0 to 70°C Voltage on any Pin with Respect to Ground .....-1 to +7.0 V

Stresses above those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent device failure. Functionality at or above these limits is not implied. Exposure to absolute maximum ratings for extended periods may affect device reliability.

# **OPERATING RANGES**

| Military (M) Devices          |               |
|-------------------------------|---------------|
| Temperature (T <sub>C</sub> ) | -55 to +125°C |
| Supply Voltage (VCC)          | 5 V ±10%      |

Operating ranges define those limits between which the functionality of the device is guaranteed.

DC CHARACTERISTICS over MILITARY operating range (for APL Products, Group A, Subgroups 1, 2, 3 are tested unless otherwise noted)

| Parameter<br>Symbol | Parameter Description                                          | Test Conditions                                              | Min.  | Max.                   | Unit |
|---------------------|----------------------------------------------------------------|--------------------------------------------------------------|-------|------------------------|------|
| V <sub>IL</sub> †   | Input LOW Voltage                                              | V <sub>CC</sub> = Min. & Max.                                | -0.5° | + 0.8                  | ٧    |
| ViH +               | Input HIGH Voltage                                             | V <sub>CC</sub> = Min. & Max.                                | 2.0   | V <sub>CC</sub> + 0.5* | ٧    |
| VoL                 | Output LOW Voltage                                             | I <sub>OL</sub> = 2.0 mA,<br>V <sub>CC</sub> = Min.          |       | 0.45                   | v    |
| v <sub>OH</sub>     | Output HIGH Voltage                                            | I <sub>OH</sub> =400 μA,<br>V <sub>CC</sub> = Min.           | 2.4   |                        | ٧    |
| loc                 | Power Supply Current (Note 1)                                  | T <sub>C</sub> = 25°C, V <sub>CC</sub> = Max.                |       | 340                    | mA   |
| iu                  | Input Leakage Current                                          | V <sub>CC</sub> = Max.,<br>V <sub>IN</sub> = 5.5 V & 0 V     | - 10  | 10                     | μΑ   |
| lo ++               | Output Leakage Current                                         | V <sub>CC</sub> = Max.,<br>V <sub>OUT</sub> = 5.5 V & 0.45 V | - 10  | 10                     | μА   |
| V <sub>CL</sub> +   | Clock Input LOW Voltage                                        | V <sub>CC</sub> = Min. & Max.                                | ~0.5° | + 0.6                  | ٧    |
| V <sub>CH</sub> †   | Clock Input HIGH Voltage                                       | V <sub>CC</sub> = Min. & Max.                                | 3.9   | V <sub>CC</sub> + 1.0° | ٧    |
| C <sub>IN</sub> +++ | Capacitance of Input Buffer (All Input Except AD0-AD15, RQ/GT) | fc = 1 MHz                                                   |       | 20*                    | ρF   |
| Cio ttt             | Capacitance of I/O Buffer (ADn-AD15, RQ/GT)                    | fc = 1 MHz                                                   |       | 20*                    | pF   |

- \* Guaranteed by design, not tested † Group A, Subgroups 7 and 8 only are tested. †† Group A, Subgroups 1 and 2 only are tested ††† Not included in Group A tests.

Notes: 1. ICC is measured while running a functional pattern with spec value IOL/IOH loads applied



SWITCHING CHARACTERISTICS over MILITARY operating range (for APL Products, Group A, Subgroups 9, 10, 11 are tested unless otherwise noted)

# MINIMUM COMPLEXITY SYSTEM TIMING REQUIREMENTS

| Parameter | Parameter                               | Test<br>Conditions | 8086    |      | 8086-2 |      |      |
|-----------|-----------------------------------------|--------------------|---------|------|--------|------|------|
| Symbol    | Description                             | (Note 6)           | Min.    | Max. | Min.   | Max. | Unit |
| TCLCL     | CLK Cycle Period (Note 11)              |                    | 200     | 500  | 125    | 500  | ns   |
| TCLCH     | CLK LOW Time                            |                    | 118     |      | 68     |      | ns   |
| TCHCL     | CLK HIGH Time                           |                    | 69      |      | 44     |      | ns   |
| TCH1CH2   | CLK Rise Time (Note 5)                  | From 1.0 to 35 V   |         | 10   |        | 10   | ns   |
| TCL2CL1   | CLK Fall Time (Note 5)                  | From 3.5 to 1.0 V  |         | 10   |        | 10   | ns   |
| TDVCL     | Data in Setup Time                      |                    | 30      |      | 20     |      | ns   |
| TCLDX     | Data in Hold Time                       |                    | 10      |      | 10     |      | ns   |
| TRIVCL    | RDY Setup Time into 8284A (Notes 1 & 2) |                    | 35      |      | 35     |      | ns   |
| TCLR1X    | RDY Hold Time into 8284A (Notes 1 & 2)  |                    | 0       |      | 0      |      | ns   |
| TRYHCH    | READY Setup Time into 8086              |                    | 118     |      | 68     |      | ns   |
| TCHRYX    | READY Hold Time into 8086               |                    | 30      |      | 20     |      | ns   |
| TRYLCL    | READY Inactive to CLK (Note 4)          |                    | -8      |      | -8     |      | ns   |
| THVCH     | HOLD Setup Time                         |                    | 35      |      | 20     |      | ns   |
| TINVCH    | INTR, NMI, TEST Setup Time (Note 2)     |                    | 30      |      | 15     |      | ns   |
| TILIH     | Input Rise Time (Except CLK) (Note 5)   | From 08 to 20 V    | 1       | 20   | Γ      | 20   | ns   |
| TIHIL     | Input Fall Time (Except CLK) (Note 5)   | From 20 to 08 V    | <b></b> | 12   |        | 12   | ns   |

- Notes
- Input Fall Time (Except CLK) (Note 5) From 2.0 to 0.8 V

  1. Signal at 8284A and 8288 shown for reference only
  2. Setup requirement for asynchronous signal only to guarantee recognition at next CLK
  3. Applies only to T2 state (8 ns into T3).
  4. Applies only to T2 state (8 ns into T3).
  5. Not tested, these specs are controlled by the Teradyne J941 tester
  6. V<sub>CC</sub> = 4.5 V, 5.5 V V<sub>IH</sub> = 2.4 V
  V<sub>IL</sub> = 4.5 V V<sub>IHC</sub> = 4.3 V
  V<sub>ILC</sub> = 2.5 V V<sub>OH</sub> = 1.6 V
  V<sub>OL</sub> = 1.4 V
  7. Minimum spec tested at V<sub>CC</sub> Max (5.5 V) only
  8. Maximum spec tested at V<sub>CC</sub> Max (5.5 V) only
  9. Tested at V<sub>CC</sub> Max (5.5 V) only
  10. Tested at V<sub>CC</sub> Min (4.5 V) only
  11. Test conditions for TCLCL Max are
  V<sub>CC</sub> = 4.5 V V<sub>OH</sub> = 1.0 V
  V<sub>IL</sub> = 0.0 V V<sub>IH</sub> = 4.0 V
  V<sub>IL</sub> = 0.0 V V<sub>IH</sub> = 5.0 V

# SWITCHING CHARACTERISTICS over MILITARY operating range (continued) TIMING RESPONSES

| Parameter | Parameter                                    | Test<br>Conditions                   | 80   | 86   | 8086-2 |      |      |
|-----------|----------------------------------------------|--------------------------------------|------|------|--------|------|------|
| Symbol    | Description                                  | (Note 6)                             | Min. | Max. | Min.   | Max. | Unit |
| TCLAV     | Address Valid Delay                          |                                      | 10   | 110  | 10     | 60   | ns   |
| TCLAX     | Address Hold Time (Notes 7 & 8)              |                                      | 10   |      | 10     |      | ns   |
| TCLAZ     | Address Float Delay (Note 8)                 |                                      | 10   | 80   | 10     | 50   | ns   |
| TLHLL     | ALE Width (Note 10)                          |                                      | 98   |      | 58     |      | ns   |
| TCLLH     | ALE Active Delay (Note 8)                    |                                      |      | 80   |        | 50   | ns   |
| TCHLL     | ALE Inactive Delay (Note 8)                  |                                      |      | 85   |        | 55   | ns   |
| TLLAX     | Address Hold Time to ALE Inactive (Note 7)   |                                      | 59   |      | 34     |      | ns   |
| TCLDV     | Data Valid Delay (Note 8)                    |                                      | 10   | 110  | 10     | 60   | ns   |
| TCHDX     | Data Hold Time (Note 10)                     |                                      | 10   |      | 10     |      | ns   |
| TWHDX     | Data Hold Time After WR (Note 9)             |                                      | 88   |      | 38     |      | ns   |
| TCVCTV    | Control Active Delay 1 (Note 8)              |                                      | 10   | 110  | 10     | 70   | ns   |
| TCHCTV    | Control Active Delay 2 (Note 8)              | C <sub>L</sub> = 100 pF              | 10   | 110  | 10     | 60   | ns   |
| TCVCTX    | Control Inactive Delay (Note 8)              | for all 8086<br>Outputs (in addition | 10   | 110  | 10     | 70   | ns   |
| TAZRL     | Address Float to READ Active (Note 9)        | to 8086 internal loads)              | 0    |      | 0      |      | ns   |
| TCLRL     | RD Active Delay (Note 8)                     |                                      | 10   | 165  | 10     | 100  | ns   |
| TCLRH     | RD Inactive Delay (Note 8)                   | 7                                    | 10   | 150  | 10     | 80   | ns   |
| TRHAV     | RD Inactive to Next Address Active (Note 10) |                                      | 155  |      | 85     |      | ns   |
| TCLHAV    | HLDA Valid Delay (Note 8)                    |                                      | 10   | 160  | 10     | 100  | ns   |
| TRLAH     | RD Width (Note 10)                           | 7                                    | 325  |      | 200    |      | ns   |
| TWLWH     | WR Width (Note 10)                           |                                      | 340  |      | 210    |      | ns   |
| TAVAL     | Address Valid to ALE LOW (Note 9)            |                                      | 58   |      | 28     |      | ns   |
| TOLOH     | Output Rise Time (Note 9)                    | From 0.8 to 2.0 V                    |      | 20   |        | 20   | ns   |
| TOHOL     | Output Fall Time (Note 9)                    | From 2.0 to 0.8 V                    |      | 12   |        | 12   | ns   |

| Notes: 1. Signal at 8284A and 8288 shown for reference only. 2. Setup requirement for asynchronous signal only to guarantee recognition at next CLK. 3. Applies only to 13 and wait states. 4. Applies only to 12 state (8 ns into 13). 5. Not tested; these specs are controlled by the Teradyne J941 tester 6. V<sub>CC</sub> = 4.5 V, 5.5 V V<sub>IH</sub> = 2.4 V V<sub>IL</sub> = 4.5 V V<sub>IH</sub> = 2.4 V V<sub>IL</sub> = 4.5 V V<sub>IH</sub> = 4.3 V V<sub>IL</sub> = 4.5 V V<sub>IH</sub> = 1.6 V V<sub>IL</sub> = 1.7 V<sub></sub>

8086



# SWITCHING CHARACTERISTICS over MILITARY operating range (continued)

# MAX MODE SYSTEM (USING 8288 BUS CONTROLLER) TIMING REQUIREMENTS

| Parameter | Parameter                                             | Test<br>Conditions | 8086 |      | 8086-2 |      |      |  |
|-----------|-------------------------------------------------------|--------------------|------|------|--------|------|------|--|
| Symbol    | Description                                           | (Note 6)           | Min. | Max. | Min.   | Max. | Unit |  |
| TCLGL     | CLK Cycle Period (Note 11)                            |                    | 200  | 500  | 125    | 500  | ns   |  |
| TCLCH     | CLK LOW Time                                          |                    | 118  |      | 68     | ,,,, | ns   |  |
| TCHCL     | CLK HIGH Time                                         |                    | 69   |      | 44     |      | ns   |  |
| TCH1CH2   | CLK Rise Time (Note 5)                                | From 10 to 35 V    |      | 10   |        | 10   | ns   |  |
| TCL2CL1   | CLK Fall Time (Note 5)                                | From 3.5 to 1.0 V  |      | 10   |        | 10   | ns   |  |
| TDVCL     | Data in Setup Time                                    | 1                  | 30   |      | 20     | 1    | ns   |  |
| TCLDX     | Data in Hold Time                                     |                    | 10   |      | 10     |      | ns   |  |
| TR1VCL    | RDY Setup Time into 8284A (Notes 1 & 2)               |                    | 35   |      | 35     |      | ns   |  |
| TCLR1X    | RDY Hold Time into 8284A (Notes 1 & 2)                |                    | 0    |      | 0      | T    | ns   |  |
| TRYHCH    | READY Setup Time into 8086                            | T                  | 118  |      | 68     |      | ns   |  |
| TCHRYX    | READY Hold Time into 8086                             | T                  | 30   |      | 20     |      | ns   |  |
| TRYLCL    | READY Inactive to CLK (Note 4)                        |                    | 8    |      | -8     |      | ns   |  |
| TINVCH    | Setup Time for Recognition (INTR, NMI, TEST) (Note 2) |                    | 30   |      | 15     |      | ns   |  |
| TGVCH     | RQ/GT Setup Time                                      | T                  | 30   | T    | 15     | 1    | ns   |  |
| TCHGX     | RO Hold Time into 8066                                |                    | 40   |      | 30     | 1    | ns   |  |
| TILIH     | Input Rise Time (Except CLK) (Note 5)                 | From 0.8 to 20 V   |      | 20   | 1      | 20   | ns   |  |
| TIHIL     | Input Fall Time (Except CLK) (Note 5)                 | From 20 to 08 V    |      | 12   | 1      | 12   | ns   |  |

| Notes | 1. Signal at B284A and 8288 shown for reference only | 2. Setup requirement for asynchronous signal only to guarantee recognition at next CLK | 3. Applies only to T3 and wait states | 4. Applies only to T3 and wait states | 4. Applies only to T2 state (8 ns into T3) | 5. Not tested, these specs are controlled by the Teradyne J941 tester | 6. V<sub>CC</sub> = 4.5 V , 5.5 V | V<sub>IH</sub> = 2.4 V | V<sub>IL</sub> = 4.5 V | V<sub>IHC</sub> = 4.3 V | V<sub>IHC</sub> = 4.5 V | V<sub>IHC</sub> = 4.3 V | V<sub>IHC</sub> = 2.5 V | V<sub>IHC</sub> = 4.3 V | V<sub>IHC</sub> = 1.6 V | V<sub>IHC</sub> = 1.6 V | V<sub>IHC</sub> = 1.6 V | V<sub>IHC</sub> = 1.0 V | V<sub>IHC</sub> = 5.0 V | V<sub>IH</sub>

# SWITCHING CHARACTERISTICS over MILITARY operating range (continued) TIMING RESPONSES

| Parameter | Parameter                                 | Test<br>Conditions                           | 80   | 86   | 801  | 36-2 |      |
|-----------|-------------------------------------------|----------------------------------------------|------|------|------|------|------|
| Symbol    | Description                               | (Note 6)                                     | Min. | Max. | Min. | Max. | Unit |
| TCLML     | Command Active Delay (Note 1)             |                                              | 10   | 35   | 10   | 35   | ns   |
| TCLMH     | Command Inactive Delay (Note 1)           | 1                                            | 10   | 35   | 10   | 35   | ns   |
| TRYHSH    | READY Active to Status Passive (Note 3)   | 1                                            | ·    | 110  |      | 65   | ns   |
| TCHSV     | Status Active Delay (Notes 7 & 8)         | 1 1                                          | 10   | 110  | 10   | 60   | ns   |
| TCLSH     | Status Inactive Delay                     | 1                                            | 10   | 130  | 10   | 70   | ns   |
| TCLAV     | Address Valid Delay                       |                                              | 10   | 110  | 10   | 60   | ns   |
| TCLAX     | Address Hold Time                         | 1                                            | 10   |      | 10   |      | ns   |
| TCLAZ     | Address Float Delay                       | 1                                            | 10   | 80   | 10   | 50   | ns   |
| TSVLH     | Status Valid to ALE HIGH (Note 1)         | 1                                            |      | 15   |      | 15   | ns   |
| TSVMCH    | Status Valid to MCE HIGH (Note 1)         | 1                                            |      | 15   |      | 15   | ns   |
| TCLLH     | CLK LOW to ALE Valid (Note 1)             | 1 1                                          |      | 15   |      | 15   | ns   |
| TCLMCH    | CLK LOW to MCE HIGH (Note 1)              | 1                                            |      | 15   |      | 15   | ns   |
| TCHLL     | ALE Inactive Delay (Note 1)               | C <sub>L</sub> = 100 pF<br>for all 8086      |      | 15   |      | 15   | ns   |
| TCLMCL    | MCE Inactive Delay (Note 1)               | Outputs (In addition to 8086 internal loads) |      | 15   |      | 15   | ns   |
| TCLDV     | Data Valid Delay                          | 1 1                                          | 10   | 110  | 10   | 60   | ns   |
| TCHDX     | Data Hold Time                            | 1                                            | 10   |      | 10   |      | ns   |
| TCVNV     | Control Active Delay (Note 1)             | 1                                            | 5    | 45   | 5    | 45   | ns   |
| TCVNX     | Control Inactive Delay (Note 1)           | 7                                            | 10   | 45   | 10   | 45   | ns   |
| TAZRL     | Address Float to Read Active              | 1 1                                          | 0    |      | 0    |      | ns   |
| TCLRL     | RD Active Delay                           | 1                                            | 10   | 165  | 10   | 100  | ns   |
| TCLRH     | RD Inactive Delay                         |                                              | 10   | 150  | 10   | 80   | ns   |
| TRHAV     | RD Inactive to Next Address Active        | 1                                            | 155  |      | 85   |      | ns   |
| TCHDTL    | Direction Control Active Delay (Note 1)   | 1 1                                          |      | 50   |      | 50   | ns   |
| TCHDTH    | Direction Control Inactive Delay (Note 1) | 1                                            |      | 30   |      | 30   | ns   |
| TCLGL     | GT Active Delay (Note 8)                  | 1                                            | 0    | 85   | 0    | 50   | ns   |
| TCLGH     | GT Inactive Delay (Note 8)                |                                              | 0    | 85   | 0    | 50   | nş   |
| TRLAH     | RD Width                                  | 1                                            | 325  | 1    | 200  |      | ns   |
| TOLOH     | Output Rise Time                          | From 0.8 to 2.0 V                            |      | 20   |      | 20   | ns   |
| TOHOL     | Output Fall Time                          | From 2.0 to 0.8 V                            |      | 12   |      | 12   | ns   |

Notes: 1. Signal at 8284A and 8288 shown for reference only.

2. Setup requirement for asynchronous signal only to guarantee recognition at next CLK

3. Applies only to 13 and wait states.

4. Applies only to 12 state (8 ns into 13).

5. Not tested, these specs are controlled by the Teradyne J941 tester.

6. VCC = 4.5 V, 5.5 V V<sub>IH</sub> = 2.4 V
V<sub>IL</sub> = 4.5 V V<sub>IHC</sub> = 4.3 V
V<sub>ILC</sub> = 2.5 V V<sub>IHC</sub> = 4.3 V
V<sub>ILC</sub> = 1.4 V
V<sub>ILC</sub> = 5 V













- - inserted.
  - 3. Cascade address is valid between first and second INTA cycle.
  - 4. Two INTA cycles run back-to-back. The 8086 LOCAL ADDR/DATA BUS is floating during both INTA cycles. Control for pointer address is shown for second INTA cycle.
  - 5. Signals at 8284A or 8288 are shown for reference only.
  - 6. The issuance of the 8286 command and control signals (MRDC, MWTC, AMWC, IORC, IOWC, Alowc, INTA and DEN) lags the active high 8288 CEN.
  - 7. All timing measurements are made at 1.5 V unless otherwise noted.
  - 8. Status inactive in state just prior to T4.





data if w = 1

# 8086/8088 INSTRUCTION SET SUMMARY

#### DATA TRANSFER

| MOV = Mov | <b>/•</b> |  |
|-----------|-----------|--|
|-----------|-----------|--|

Register/memory to /from register

Immediate to register/memory

Immediate to register Memory to accumulator

Accumulator to memory

Register/memory to segment register

Segment register to register/memory

76543210 76543210 76543210 7 6 5 4 3 2 1 0

100010dw mod reg r/m

1 1 0 0 0 1 1 w mod 0 0 0 r/m data

1 0 1 1 w reg data if w = 1 date 1010000w addr-high addr-low

1010001w addr-low addr-high 10001110 mod 0 reg r/m

10001100 mod 0 reg r/m

PUSH = Push:

Register/memory

Register Segment register

POP ≈ Pop:

Register/memory

Register

Seament register

XCHG = Exchange:

Register/memory with register

Register with accumulator

IN = Input from:

Fixed port

Variable port

OUT - Ouput to:

Fixed port

Variable port

XLAT - Translate byte to AL

LEA - Load EA to register LDS - Load pointer to DS

LES - Load pointer to ES

LANF - Load AH with flags

SANF - Store AH into flags

PUSHF = Push flags

POPF - Pop flags

11111111 mod 1 1 0 r/m

0 1 0 1 0 reg

0 0 0 reg 1 1 0

10001111 mod 0 0 0 r/m

0 1 0 1 1 reg

0 0 0 reg 1 1 1

1000011w mod reg r/m

1 0 0 1 0 req

1110010w port

1110110w

1110011w port

1110111w

11010111

10001101 mod reg r/m 11000101 mod reg r/m

11000100 mod reg r/m

10011111

10011110

10011100 10011101



| INST                               | TRUCTION SET SUN | IMARY (contin  | ued)          |                  |
|------------------------------------|------------------|----------------|---------------|------------------|
| ARITHMETIC                         |                  |                |               |                  |
| ADD = Add                          | 76543210         | 76543210       | 76543210      | 7 6 5 4 3 2 1 0  |
| Reg/memory with register to either | 000000dw         | mod reg r/m    |               | <del> </del>     |
| Immediate to register / memory     | 100000sw         | mod 0 0 0 r/m  | data          | data if s:w = 01 |
| Immediate to accumulator           | 0000010w         | data           | data if w = 1 |                  |
| ADC = Add with carry:              |                  |                |               |                  |
| Reg/memory with register to either | 000100dw         | mod reg r/m    | ì             |                  |
| immediate to register/memory       | 100000sw         | mod 0 1 0 r/m  | data          | data if s:w = 01 |
| Immediate to accumulator           | 0001010w         | data           | data if w = 1 |                  |
| INC = Increment:                   |                  |                |               |                  |
| Register/memory                    | 111111W          | mod 0 0 0 r/m  |               |                  |
| Register                           | 0 1 0 0 0 reg    |                | l             |                  |
| AAA = ASCII adjust for add         | 00110111         |                |               |                  |
| DAA - Decimal adjust for add       | 00100111         | l              |               |                  |
| DAN - DECRINAL BUILDS (IO) add     |                  |                |               |                  |
| SUB = Subtract:                    |                  |                | 1             |                  |
| Reg/memory and register to either  | 001010dw         | mod reg r/m    |               |                  |
| Immediate from register/memory     | 100000sw         | mod 1 0 1 r/m  | data          | data :f s:w = 01 |
| immediate from accumulator         | 0010110w         | data           | data if w = 1 | }                |
| SBB = Subtract with borrow:        |                  |                |               |                  |
| Reg/memory and register to either  | 000110dw         | mod reg r/m    |               |                  |
| Immediate from register/memory     | 100000sw         | mod 0 1 1 r/m  | data          | data if s:w = 01 |
| Immediate from accumulator         | 0 0 0 1 1 1 0 w  | data           | data if w = 1 |                  |
| DEC = Decrement:                   |                  |                |               |                  |
| Register/memory                    | 1 1 1 1 1 1 W    | mod 0 0 1 r/m  | 1             |                  |
| Register                           | 0 1 0 0 1 reg    |                |               |                  |
| NEG Change sign                    | 1 1 1 1 0 1 1 w  | mod: 0 1 1 r/m | 1             |                  |
| CMP = Compare:                     |                  |                |               |                  |
| Register/memory with register      | 0011101w         | mod reg r/m    |               |                  |
| Register with register/memory      | 0011100w         | mod reg r/m    |               |                  |
| Immediate with register/memory     | 100000sw         | mod 1 1 1 r/m  | dala          | data if s:w = 01 |
| Immediate with accumulator         | 0011110w         | data           | data if w = 1 | ]                |
| AAS ASCH adjust for subtract       | 0011111          | ·              |               |                  |
| DAS Decimal adjust for subtract    | 00101111         |                |               |                  |
| MUL Mulitiply (unsigned)           | 1111011w         | mod 1 0 0 r/m  | ]             |                  |
| (MUL Integer multiply (signed):    | 1111011w         |                | ]             |                  |
| AAM ASCII adjust for multiply      | 11010100         | 00001010       |               |                  |
| DIV Divide (unsigned)              | 1111011 w        | mod 1 1 0 r/m  | Ì             |                  |
| IDIV Integer divide (signed)       | 1111011w         | mod 1 1 1 r/m  | )             |                  |
| AAD ASCH adjust for divide         | 11010101         | 00001010       | ]             |                  |
| CBW Convert byte to word           | 10011000         |                | ı             |                  |
|                                    | 1                |                |               |                  |

1-30 8086

#### INSTRUCTION SET SUMMARY (continued) LOGIC 76543210 76543210 76543210 7 6 5 4 3 2 1 0 NOT Invert 1111011w mod 0 1 0 r/m SHL/SAL Shift logical/arithmetic left 1 1 0 1 0 0 v w | mod 1 0 0 r/m SHR Shift logical right 1 1 0 1 0 0 v w | mod 1 0 1 r/m SAR Shift arithmetic right 110100vw mod 1 1 1 r/m ROL Rotate left 110100vw mod 0 0 0 r/m ROR Rotate right 110100vw mod 0 0 1 r/m RCL Rotate through carry flag left 1 1 0 1 0 0 v w mod 0 1 0 r/m mod 0 1 1 r/m RCR Rotate through carry right 110100vw AND = And: Reg/memory and register to either 001000dw mod reg r/m Immediate to register/memory 10000000w data if w = 1 mod 1 0 0 r/m data data if w = 1 Immediate to accumulator 0010010w data TEST = And function to flags, no result: 1000010w Register/memory and register mod reg r/m 1111011w data if w = 1 Immediate data and register/memory mod 0 0 0 r/m data data if w = 1 immediate data and accumulator 1010100w data OR = Or Reg/memory and register to either 000010dw mod reg r/m 1000000w mod 0 0 1 r/m data if w = 1 Immediate to register/memory data Immediate to accumulator 0000110w data data if w = 1 XOR = Exclusive or: Reg/memory and register to either 001100dw mod reg r/m Immediate to register/mamory 1000000w mod 1 1 0 r/m data data if w = 1 0011010w Immediate to accumulator data data if w = 1 STRING MANIPULATION: 1 1 1 1 0 0 1 z RFP - Renest MOVS = Move byte/word 1010010w CMPS = Compare byte/word 1010011w SCAS - Scan byte/word 1010111 w LODS - Load byte/wd to AL/AX 1010110w STOS - Stor byte/wd from AL/A 1010101w



#### INSTRUCTION SET SUMMARY (continued) CONTROL TRANSFER CALL = Call 7 6 5 4 3 2 1 0 76543210 76543210 76543210 disp-high Direct within segment 11101000 disp-low indirect within segment 1111111 mod 0 1 0 r/m 10011010 Direct intersegment offset-low offset-high seg-low seg-high Indirect intersegment 1 1 1 1 1 1 1 1 mod 0 1 1 r/m JMP = Unconditional jump: 11101001 Direct within segment disp-low disp-high 11101011 Direct within segment-short disp Indirect within segment 11111111 mod 1 0 0 r/m Direct intersegment 11101010 offset-low offset-high seg-high Indirect interseament 1111111 mod 1 0 1 r/m RET = Return from CALL: 11000011 Within segment 11000010 data-high Within seg adding immed to SP data-low Intersegment 11001011 Intersegment adding immediate to SP 11001010 data-low data-high JE/JZ = Jump on equal/zero 01110100 JL/JNGE - Jump on less/not greater or equal 01111100 disp 01111110 JLE/JNG - Jump on less or equal/not greater disp JB/JNAE = Jump on below/not above or equal 01110010 disp JBE/JNA - Jump on below or equal/not above 01110110 disp JP/JPE - Jump on parity/parity even 01111010 JO - Jump on overflow 01110000 01111000 JS = Jump on sign disn 01110101 JNE/JNZ = Jump on not equal/not zero diso JNL/JGE - Jump on not less/greater or equal 01111101 disp JNLE/JG - Jump on not less or equal/greater 01111111 disp JNB/JAE - Jump on not below/above or equal 01110011 JNBE/JA - Jump on not below or equal/above 01110111 JNP/JPO - Jump on not par/par odd 0 1 1 1 1 0 1 1 disp 01110001 JNO - Jump on not overflow disp JNS - Jump on not sign 01111001 disp LOOP - Loop CX times 11100010 LOCPZ/LOOPE = Loop while zero/equal 11100001 diso LOOPNZ/LOOPNE = Loop while not zero/equal 11100000 diso JCXZ - Jump on CX zero 11100011 disp

1-32 8086

#### INSTRUCTION SET SUMMARY (continued) CONTROL TRANSFER (Cont'd.) INT = Interrupt 76543210 76543210 76543210 76543210 Type specified 11001101 type 11001100 Type 3 11001110 INTO = Interrupt on overflow 11001111 IRET - interrupt return PROCESSOR CONTROL 11111000 CLC = Clear carry CMC = Complement carry 11110101 STC = Set carry 11111001 CLD - Clear direction 1111100 STD = Set direction 11111101 CLL = Clear interrupt 1 1 1 1 1 0 1 0 STI - Set interrupt 11111011 HLT - Halt 11110100 WAIT - Wait 10011011 ESC = Processor Extension Escape 11011xxx mod x x x r/m

11110000

#### Footnotes:

LOCK = Bus lock prefix

| AL = 8-bit accumulator                                      |
|-------------------------------------------------------------|
| AX = 16-bit accumulator                                     |
| CX = Count register DS = Data segment                       |
| 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            |
| 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 DfSP = disp-high; disp-low

If mod = 10 then DISP = disp-righ, disp-righ If r/m = 000 then EA = (BX) + (SI) + DISP If r/m = 010 then EA = (BR) + (DI) + DISP If r/m = 010 then EA = (BP) + (DI) + DISP If r/m = 101 then EA = (BP) + (DI) + DISP If r/m = 100 then EA = (DI) + DISP If r/m = 110 then EA = (BP) + DISP If r/m = 111 then EA = (BP) + 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.

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.

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 tiles as a 16-bit object use the symbol FLAGS to represent the file:

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