



# PANIPAT INSTITUTE OF ENGINEERING & TECHNOLOGY

(Approved by AICTE, New Delhi & Affiliated to Kurukshetra University, Kurukshetra)

MPI

Sapna Arora  
Assistant Professor  
PIET(ECE)



# **PIN DIAGRAM OF 8086**

# Intel 8086

Intel 8086 was launched in 1978.

It was the first 16-bit microprocessor.



This microprocessor had major improvement over the execution speed of 8085.

It is available as 40-pin Dual-Inline-Package (DIP).

# Intel 8086

It is available in three versions:



8086 (5 MHz)

8086-2 (8 MHz)

8086-1 (10 MHz)

It consists of  
29,000 transistors.

# Intel 8086



It has a 16 line data bus.

And 20 line address bus.

It could address up to 1 MB of memory.

It has more than 20,000 instructions.

It supports multiplication and division.

# Pin Diagram of Intel 8086



# $AD_0 - AD_{15}$

## Pin 16-2, 39 (Bi-directional)

These lines are multiplexed bi-directional address/data bus.

During  $T_1$ , they carry lower order 16-bit address.

In the remaining clock cycles, they carry 16-bit data.

$AD_0 - AD_7$  carry lower order byte of data.

$AD_8 - AD_{15}$  carry higher order byte of data.





# Time Multiplexing

When the same pin has different functions during different time cycles, that pin is said to be time multiplexed.

Aren't all humans time multiplexed?

# $A_{19}/S_6, A_{18}/S_5, A_{17}/S_4, A_{16}/S_3$

Pin 35-38 (Unidirectional)

These lines are multiplexed unidirectional address and status bus.

During  $T_1$ , they carry higher order 4-bit address.

In the remaining clock cycles, they carry status signals.

|           |    |    |          |
|-----------|----|----|----------|
| Vss (GND) | 1  | 40 | Vcc (5P) |
| AD14      | 2  | 39 | AD15     |
| AD13      | 3  | 38 | A16/S3   |
| AD12      | 4  | 37 | A17/S4   |
| AD11      | 5  | 36 | A18/S5   |
| AD10      | 6  | 35 | A19/S6   |
| AD9       | 7  | 34 | BHE/S7   |
| AD8       | 8  | 33 | MN/MX    |
| AD7       | 9  | 32 | RD       |
| AD6       | 10 | 31 | RQ/GT0   |
| AD5       | 11 | 30 | RQ/GT1   |
| AD4       | 12 | 29 | LOCK     |
| AD3       | 13 | 28 | S2       |
| AD2       | 14 | 27 | S1       |
| AD1       | 15 | 26 | S0       |
| AD0       | 16 | 25 | QS0      |
| NMI       | 17 | 24 | QS1      |
| INTR      | 18 | 23 | TEST     |
| CLK       | 19 | 22 | READY    |
| Vss (GND) | 20 | 21 | RESET    |

|                  |    |
|------------------|----|
| GND              | 1  |
| AD <sub>1</sub>  | 2  |
| AD <sub>13</sub> | 3  |
| AD <sub>1</sub>  | 4  |
| AD <sub>11</sub> | 5  |
| AD <sub>1</sub>  | 6  |
| AD <sub>9</sub>  | 7  |
| AD <sub>8</sub>  | 8  |
| AD <sub>7</sub>  | 9  |
| AD <sub>6</sub>  | 10 |
| AD <sub>5</sub>  | 11 |
| AD <sub>4</sub>  | 12 |
| AD <sub>3</sub>  | 13 |
| AD <sub>2</sub>  | 14 |
| AD <sub>1</sub>  | 15 |
| AD <sub>0</sub>  | 16 |
|                  | 17 |
|                  | 18 |
| CLK              | 19 |
| GND              | 20 |

# 8086

|    |                                  |
|----|----------------------------------|
| 40 | V <sub>cc</sub>                  |
| 39 | AD <sub>15</sub>                 |
| 38 | A <sub>16</sub> / S <sub>3</sub> |
| 37 | A <sub>17</sub> / S <sub>4</sub> |
| 36 | A <sub>18</sub> / S <sub>5</sub> |
| 35 | A <sub>19</sub> / S <sub>6</sub> |
| 34 |                                  |
| 33 |                                  |
| 32 |                                  |
| 31 |                                  |
| 30 |                                  |
| 29 |                                  |
| 28 |                                  |
| 27 |                                  |
| 26 |                                  |
| 25 |                                  |
| 24 |                                  |
| 23 |                                  |
| 22 | READY                            |
| 21 | RESET                            |

| S3 | S4 | Segment |
|----|----|---------|
| 0  | 0  | Extra   |
| 0  | 1  | Stack   |
| 1  | 0  | Code    |
| 1  | 1  | Data    |

S<sub>5</sub> indicates interrupt  
flag is set  
S<sub>6</sub> is 0

# Active High/Active Low?

- Describes how a pin is activated.
- Active high pins are enabled when set to 1
- Active low pins are enabled when set to 0
- By default all pins are directly connected to the Vcc.
- Active low pins are connected via NOT gate
- If we do not want certain pins to be active by default, we will reverse their role.

# **RD** (Read)

## Pin 32 (Output)

It is a read signal used for read operation.

It is an output signal.

It is an active low signal.

|           |    |    |           |
|-----------|----|----|-----------|
| Vss (GND) | 1  | 40 | Vcc (5P)  |
| AD14      | 2  | 39 | AD15      |
| AD13      | 3  | 38 | A16/S3    |
| AD12      | 4  | 37 | A17/S4    |
| AD11      | 5  | 36 | A18/S5    |
| AD10      | 6  | 35 | A19/S6    |
| AD9       | 7  | 34 | BHE/S7    |
| AD8       | 8  | 33 | MN/MX     |
| AD7       | 9  | 32 | <b>RD</b> |
| AD6       | 10 | 31 | RQ/GT0    |
| AD5       | 11 | 30 | RQ/GT1    |
| AD4       | 12 | 29 | LOCK      |
| AD3       | 13 | 28 | S2        |
| AD2       | 14 | 27 | S1        |
| AD1       | 15 | 26 | S0        |
| AD0       | 16 | 25 | QS0       |
| NMI       | 17 | 24 | QS1       |
| INTR      | 18 | 23 | TEST      |
| CLK       | 19 | 22 | READY     |
| Vss (GND) | 20 | 21 | RESET     |

# READY

## Pin 22 (Input)

This is an acknowledgement signal from slower I/O devices or memory.

It is an active high signal.

When high, it indicates that the device is ready to transfer data.

When low, then microprocessor is in wait state.

|           |    |    |          |
|-----------|----|----|----------|
| Vss (GND) | 1  | 40 | Vcc (5P) |
| AD14      | 2  | 39 | AD15     |
| AD13      | 3  | 38 | A16/S3   |
| AD12      | 4  | 37 | A17/S4   |
| AD11      | 5  | 36 | A18/S5   |
| AD10      | 6  | 35 | A19/S6   |
| AD9       | 7  | 34 | BHE/S7   |
| AD8       | 8  | 33 | MN/MX    |
| AD7       | 9  | 32 | RD       |
| AD6       | 10 | 31 | RQ/GT0   |
| AD5       | 11 | 30 | RQ/GT1   |
| AD4       | 12 | 29 | LOCK     |
| AD3       | 13 | 28 | S2       |
| AD2       | 14 | 27 | S1       |
| AD1       | 15 | 26 | S0       |
| AD0       | 16 | 25 | QS0      |
| NMI       | 17 | 24 | QS1      |
| INTR      | 18 | 23 | TEST     |
| CLK       | 19 | 22 | READY    |
| Vss (GND) | 20 | 21 | RESET    |

# RESET

## Pin 21 (Input)

It is a system reset.

It is an active high signal.

When high, microprocessor enters into reset state and terminates the current activity.

It must be active for at least four clock cycles to reset the microprocessor.



|           |            |           |                                |    |                     |
|-----------|------------|-----------|--------------------------------|----|---------------------|
| GND       |            | 1         |                                | 40 | $V_{cc}$            |
| $AD_{14}$ |            | 2         |                                | 39 | $AD_{15}$           |
| $AD_{13}$ |            | 3         |                                | 38 | $A_{16}/S_3$        |
| $AD_{12}$ | <b>BHE</b> | <b>A0</b> | <b>Access</b>                  |    | $A_{17}/S_4$        |
| AD        | 0          | 0         | 16-bit word ( $D_{15} - D_0$ ) |    | $A_{18}/S_5$        |
| AD        | 0          | 1         | Upper byte ( $D_{15} - D_8$ )  |    | $A_{19}/S_6$        |
| AD        | 1          | 0         | Lower byte ( $D_7 - D_0$ )     |    | $\overline{HE}/S_7$ |
| AD        | 1          | 1         | Invalid                        |    |                     |
| $AD_6$    | 10         |           | <b>8086</b>                    | 31 |                     |
| $AD_5$    | 11         |           |                                | 30 |                     |
| $AD_4$    | 12         |           |                                | 29 |                     |
| $AD_3$    | 13         |           |                                | 28 |                     |
| $AD_2$    | 14         |           |                                | 27 |                     |
| $AD_1$    | 15         |           |                                | 26 |                     |
| $AD_0$    | 16         |           |                                | 25 |                     |
| NMI       | 17         |           |                                | 24 |                     |
| INTR      | 18         |           |                                | 23 |                     |
| CLK       | 19         |           |                                | 22 | READY               |
| GND       | 20         |           |                                | 21 | RESET               |

**BHE = 0**

Enable data on  $D_8 - D_{15}$

**BHE = 1**

Enable data on  $D_0 - D_7$

$S_7$  reserved for future

# INTR

## Pin 18 (Input)

It is an interrupt request signal.

It is active high.

It is level triggered.

|           |    |    |          |
|-----------|----|----|----------|
| Vss (GND) | 1  | 40 | Vcc (5P) |
| AD14      | 2  | 39 | AD15     |
| AD13      | 3  | 38 | A16/S3   |
| AD12      | 4  | 37 | A17/S4   |
| AD11      | 5  | 36 | A18/S5   |
| AD10      | 6  | 35 | A19/S6   |
| AD9       | 7  | 34 | BHE/S7   |
| AD8       | 8  | 33 | MN/MX    |
| AD7       | 9  | 32 | RD       |
| AD6       | 10 | 31 | RQ/GT0   |
| AD5       | 11 | 30 | RQ/GT1   |
| AD4       | 12 | 29 | LOCK     |
| AD3       | 13 | 28 | S2       |
| AD2       | 14 | 27 | ST       |
| AD1       | 15 | 26 | S0       |
| AD0       | 16 | 25 | QS0      |
| NMI       | 17 | 24 | QS1      |
| INTR      | 18 | 23 | TEST     |
| CLK       | 19 | 22 | READY    |
| Vss (GND) | 20 | 21 | RESET    |

# NMI

## Pin 17 (Input)

It is a non-maskable interrupt signal.

It is an active high.

It is an edge triggered interrupt.

|           |    |    |          |      |
|-----------|----|----|----------|------|
| Vss (GND) | 1  | 40 | Vcc (5P) |      |
| AD14      | 2  | 39 | AD15     |      |
| AD13      | 3  | 38 | A16/S3   |      |
| AD12      | 4  | 37 | A17/S4   |      |
| AD11      | 5  | 36 | A18/S5   |      |
| AD10      | 6  | 35 | A19/S6   |      |
| AD9       | 7  | 34 | BHE/S7   |      |
| AD8       | 8  | 33 | MN/MX    |      |
| AD7       | 9  | 32 | RD       |      |
| AD6       | 10 | 31 | RQ/GT0   | HOLD |
| AD5       | 11 | 30 | RQ/GT1   | HLDA |
| AD4       | 12 | 29 | LOCK     | WR   |
| AD3       | 13 | 28 | S2       | M/I  |
| AD2       | 14 | 27 | S1       | DT/R |
| AD1       | 15 | 26 | S0       | DEN  |
| AD0       | 16 | 25 | QS0      | ALE  |
| NMI       | 17 | 24 | QS1      | INTA |
| INTR      | 18 | 23 | TEST     |      |
| CLK       | 19 | 22 | READY    |      |
| Vss (GND) | 20 | 21 | RESET    |      |

# TEST

## Pin 23 (Input)

It is used to test the status of math co-processor 8087.

The BUSY pin of 8087 is connected to this pin of 8086.

If low, execution continues else microprocessor is in wait state.

|           |    |    |               |
|-----------|----|----|---------------|
| Vss (GND) | 1  | 40 | Vcc (5P)      |
| AD14      | 2  | 39 | AD15          |
| AD13      | 3  | 38 | A16/S3        |
| AD12      | 4  | 37 | A17/S4        |
| AD11      | 5  | 36 | A18/S5        |
| AD10      | 6  | 35 | A19/S6        |
| AD9       | 7  | 34 | <u>BHE/S7</u> |
| AD8       | 8  | 33 | MN/MX         |
| AD7       | 9  | 32 | <u>RD</u>     |
| AD6       | 10 | 31 | <u>RQ/GT0</u> |
| AD5       | 11 | 30 | <u>RQ/GT1</u> |
| AD4       | 12 | 29 | <u>LOCK</u>   |
| AD3       | 13 | 28 | <u>S2</u>     |
| AD2       | 14 | 27 | <u>ST</u>     |
| AD1       | 15 | 26 | <u>S0</u>     |
| AD0       | 16 | 25 | <u>QS0</u>    |
| NMI       | 17 | 24 | <u>QS1</u>    |
| INTR      | 18 | 23 | <u>TEST</u>   |
| CLK       | 19 | 22 | <u>READY</u>  |
| Vss (GND) | 20 | 21 | <u>RESET</u>  |

# CLK

## Pin 19 (Input)

This clock input provides the basic timing for processor operation.

The range of frequency of different versions is 5 MHz, 8 MHz and 10 MHz.

|           | 8086 |                |
|-----------|------|----------------|
| Vss (GND) | 1    | 40 Vcc (5P)    |
| AD14      | 2    | 39 AD15        |
| AD13      | 3    | 38 A16/S3      |
| AD12      | 4    | 37 A17/S4      |
| AD11      | 5    | 36 A18/S5      |
| AD10      | 6    | 35 A19/S6      |
| AD9       | 7    | 34 BHE/S7      |
| AD8       | 8    | 33 MN/MX       |
| AD7       | 9    | 32 RD          |
| AD6       | 10   | 31 RQ/GT0 HOLD |
| AD5       | 11   | 30 RQ/GT1 HLDA |
| AD4       | 12   | 29 LOCK WR     |
| AD3       | 13   | 28 S2 M/I      |
| AD2       | 14   | 27 ST DT/R     |
| AD1       | 15   | 26 S0 DEN      |
| AD0       | 16   | 25 QS0 ALE     |
| NMI       | 17   | 24 QS1 INTA    |
| INTR      | 18   | 23 TEST        |
| CLK       | 19   | 22 READY       |
| Vss (GND) | 20   | 21 RESET       |

# $V_{CC}$ and $V_{SS}$

## Pin 40 and Pin 20 (Input)

$V_{CC}$  is power supply signal.

+5V DC is supplied through this pin.

$V_{SS}$  is ground signal.



# Modes of Operation

Processor needs control over the address, data and control buses to access memory and I/O devices.

- Minimum mode – single processor mode
  - Processor issues control signals
- Maximum mode – multi processor mode
  - The bus controller issues control signals

These modes of operations are available only in 8086/88.

# MN / $\overline{MX}$

## Pin 33 (Input)

- 8086 works in two modes:
  - Minimum Mode
  - Maximum Mode
- If MN/ $\overline{MX}$  is high, it works in minimum mode.
- If MN/ $\overline{MX}$  is low, it works in maximum mode.



# MN / $\overline{MX}$

## Pin 33 (Input)

Pins 24 to 31 issue two different sets of signals.

One set of signals is issued when CPU operates in minimum mode.

Other set of signals is issued when CPU operates in maximum mode.





# Pin Description for Minimum Mode

# INTA

## Pin 24 (Output)

This is an interrupt acknowledge signal.

When microprocessor receives INTR signal, it acknowledges the interrupt by generating this signal.

It is an active low signal.

|           |    |    |          |
|-----------|----|----|----------|
| Vss (GND) | 1  | 40 | Vcc (5P) |
| AD14      | 2  | 39 | AD15     |
| AD13      | 3  | 38 | A16/S3   |
| AD12      | 4  | 37 | A17/S4   |
| AD11      | 5  | 36 | A18/S5   |
| AD10      | 6  | 35 | A19/S6   |
| AD9       | 7  | 34 | BHE/S7   |
| AD8       | 8  | 33 | MN/MX    |
| AD7       | 9  | 32 | RD       |
| AD6       | 10 | 31 | RQ/GT0   |
| AD5       | 11 | 30 | RQ/GT1   |
| AD4       | 12 | 29 | LOCK     |
| AD3       | 13 | 28 | S2       |
| AD2       | 14 | 27 | ST       |
| AD1       | 15 | 26 | S0       |
| AD0       | 16 | 25 | QS0      |
| NMI       | 17 | 24 | QS1      |
| INTR      | 18 | 23 | TEST     |
| CLK       | 19 | 22 | READY    |
| Vss (GND) | 20 | 21 | RESET    |

# ALE

## Pin 25 (Output)

This is an Address Latch Enable signal.

It indicates that valid address is available on bus  $AD_0 - AD_{15}$ .

It is an active high signal and remains high during  $T_1$  state.

It is connected to enable pin of latch 8282.

|           | 8086 |                |
|-----------|------|----------------|
| Vss (GND) | 1    | 40 Vcc (5P)    |
| AD14      | 2    | 39 AD15        |
| AD13      | 3    | 38 A16/S3      |
| AD12      | 4    | 37 A17/S4      |
| AD11      | 5    | 36 A18/S5      |
| AD10      | 6    | 35 A19/S6      |
| AD9       | 7    | 34 BHE/S7      |
| AD8       | 8    | 33 MN/MX       |
| AD7       | 9    | 32 RD          |
| AD6       | 10   | 31 RQ/GT0 HOLD |
| AD5       | 11   | 30 RQ/GT1 HLDA |
| AD4       | 12   | 29 LOCK WR     |
| AD3       | 13   | 28 S2 M/I/O    |
| AD2       | 14   | 27 S1 DT/R     |
| AD1       | 15   | 26 S0 DEN      |
| AD0       | 16   | 25 QS0 ALE     |
| NMI       | 17   | 24 QS1 INTA    |
| INTR      | 18   | 23 TEST        |
| CLK       | 19   | 22 READY       |
| Vss (GND) | 20   | 21 RESET       |

# **DEN**

## **Pin 26 (Output)**

This is a Data Enable signal.

This signal is used to enable the transceiver 8286.

Transceiver is used to separate the data from the address/data bus.

It is an active low signal.

|           |    |    |             |
|-----------|----|----|-------------|
| Vss (GND) | 1  | 40 | Vcc (5P)    |
| AD14      | 2  | 39 | AD15        |
| AD13      | 3  | 38 | A16/S3      |
| AD12      | 4  | 37 | A17/S4      |
| AD11      | 5  | 36 | A18/S5      |
| AD10      | 6  | 35 | A19/S6      |
| AD9       | 7  | 34 | BHE/S7      |
| AD8       | 8  | 33 | MN/MX       |
| AD7       | 9  | 32 | RD          |
| AD6       | 10 | 31 | RQ/GT0 HOLD |
| AD5       | 11 | 30 | RQ/GT1 HLDA |
| AD4       | 12 | 29 | LOCK WR     |
| AD3       | 13 | 28 | S2 M/I/O    |
| AD2       | 14 | 27 | ST DT/R     |
| AD1       | 15 | 26 | S0 DEN      |
| AD0       | 16 | 25 | QS0 ALE     |
| NMI       | 17 | 24 | QS1 INTA    |
| INTR      | 18 | 23 | TEST        |
| CLK       | 19 | 22 | READY       |
| Vss (GND) | 20 | 21 | RESET       |

# DT / $\bar{R}$

## Pin 27 (Output)

This is a Data Transmit/Receive signal.

It decides the direction of data flow through the transceiver.

When it is high, data is transmitted out.

When it is low, data is received in.

|           |    |    |             |
|-----------|----|----|-------------|
| Vss (GND) | 1  | 40 | Vcc (5P)    |
| AD14      | 2  | 39 | AD15        |
| AD13      | 3  | 38 | A16/S3      |
| AD12      | 4  | 37 | A17/S4      |
| AD11      | 5  | 36 | A18/S5      |
| AD10      | 6  | 35 | A19/S6      |
| AD9       | 7  | 34 | BHE/S7      |
| AD8       | 8  | 33 | MN/MX       |
| AD7       | 9  | 32 | RD          |
| AD6       | 10 | 31 | RD/GT0 HOLD |
| AD5       | 11 | 30 | RD/GT1 HLDA |
| AD4       | 12 | 29 | LOCK WR     |
| AD3       | 13 | 28 | S2 M/I      |
| AD2       | 14 | 27 | S1 DT/R     |
| AD1       | 15 | 26 | S0 DEN      |
| AD0       | 16 | 25 | QSO ALE     |
| NMI       | 17 | 24 | QS1 INTA    |
| INTR      | 18 | 23 | TEST        |
| CLK       | 19 | 22 | READY       |
| Vss (GND) | 20 | 21 | RESET       |



# M / $\overline{IO}$

## Pin 28 (Output)

This signal is issued by the microprocessor to distinguish memory access from I/O access.

When it is high, memory is accessed.

When it is low, I/O devices are accessed.

|           |    |    |             |
|-----------|----|----|-------------|
| Vss (GND) | 1  | 40 | Vcc (5P)    |
| AD14      | 2  | 39 | AD15        |
| AD13      | 3  | 38 | A16/S3      |
| AD12      | 4  | 37 | A17/S4      |
| AD11      | 5  | 36 | A18/S5      |
| AD10      | 6  | 35 | A19/S6      |
| AD9       | 7  | 34 | BHE/S7      |
| AD8       | 8  | 33 | MN/MX       |
| AD7       | 9  | 32 | RD          |
| AD6       | 10 | 31 | RQ/GT0 HOLD |
| AD5       | 11 | 30 | RQ/GT1 HLDA |
| AD4       | 12 | 29 | LOCK WR     |
| AD3       | 13 | 28 | S2 M/IO     |
| AD2       | 14 | 27 | S1 DT/R     |
| AD1       | 15 | 26 | S0 DEN      |
| AD0       | 16 | 25 | QS0 ALE     |
| NMI       | 17 | 24 | QS1 INTA    |
| INTR      | 18 | 23 | TEST        |
| CLK       | 19 | 22 | READY       |
| Vss (GND) | 20 | 21 | RESET       |

# **WR**

## **Pin 29 (Output)**

It is a Write signal.

It is used to write data in memory or output device depending on the status of M/IO signal.

It is an active low signal.

|           |    |    |             |
|-----------|----|----|-------------|
| Vss (GND) | 1  | 40 | Vcc (5P)    |
| AD14      | 2  | 39 | AD15        |
| AD13      | 3  | 38 | A16/S3      |
| AD12      | 4  | 37 | A17/S4      |
| AD11      | 5  | 36 | A18/S5      |
| AD10      | 6  | 35 | A19/S6      |
| AD9       | 7  | 34 | BHE/S7      |
| AD8       | 8  | 33 | MN/MX       |
| AD7       | 9  | 32 | RD          |
| AD6       | 10 | 31 | RQ/GT0 HOLD |
| AD5       | 11 | 30 | RQ/GT1 HLDA |
| AD4       | 12 | 29 | LOCK WR     |
| AD3       | 13 | 28 | S2 M/IO     |
| AD2       | 14 | 27 | S1 DT/R     |
| AD1       | 15 | 26 | S0 DEN      |
| AD0       | 16 | 25 | QS0 ALE     |
| NMI       | 17 | 24 | QS1 INTA    |
| INTR      | 18 | 23 | TEST        |
| CLK       | 19 | 22 | READY       |
| Vss (GND) | 20 | 21 | RESET       |

# HLDA

## Pin 30 (Output)

It is a Hold Acknowledge signal.

It is issued after receiving the HOLD signal.

It is an active high signal.

|           |    |    |          |
|-----------|----|----|----------|
| Vss (GND) | 1  | 40 | Vcc (5P) |
| AD14      | 2  | 39 | AD15     |
| AD13      | 3  | 38 | A16/S3   |
| AD12      | 4  | 37 | A17/S4   |
| AD11      | 5  | 36 | A18/S5   |
| AD10      | 6  | 35 | A19/S6   |
| AD9       | 7  | 34 | BHE/S7   |
| AD8       | 8  | 33 | MN/MX    |
| AD7       | 9  | 32 | RD       |
| AD6       | 10 | 31 | RQ/GT0   |
| AD5       | 11 | 30 | RQ/GT1   |
| AD4       | 12 | 29 | LOCK     |
| AD3       | 13 | 28 | S2       |
| AD2       | 14 | 27 | S1       |
| AD1       | 15 | 26 | S0       |
| AD0       | 16 | 25 | QS0      |
| NMI       | 17 | 24 | QS1      |
| INTR      | 18 | 23 | TEST     |
| CLK       | 19 | 22 | READY    |
| Vss (GND) | 20 | 21 | RESET    |

# HOLD

## Pin 31 (Input)

When DMA controller needs to use address/data bus, it sends a request to the CPU through this pin.

It is an active high signal.

When microprocessor receives HOLD signal, it issues HLDA signal to the DMA controller.

|           | 8086 |                |
|-----------|------|----------------|
| Vss (GND) | 1    | 40 Vcc (5P)    |
| AD14      | 2    | 39 AD15        |
| AD13      | 3    | 38 A16/S3      |
| AD12      | 4    | 37 A17/S4      |
| AD11      | 5    | 36 A18/S5      |
| AD10      | 6    | 35 A19/S6      |
| AD9       | 7    | 34 BHE/S7      |
| AD8       | 8    | 33 MN/MX       |
| AD7       | 9    | 32 RD          |
| AD6       | 10   | 31 RQ/GT0 HOLD |
| AD5       | 11   | 30 RQ/GT1 HLDA |
| AD4       | 12   | 29 LOCK WR     |
| AD3       | 13   | 28 S2 M/I/O    |
| AD2       | 14   | 27 ST DT/R     |
| AD1       | 15   | 26 S0 DEN      |
| AD0       | 16   | 25 QSO ALE     |
| NMI       | 17   | 24 QS1 INTA    |
| INTR      | 18   | 23 TEST        |
| CLK       | 19   | 22 READY       |
| Vss (GND) | 20   | 21 RESET       |



# **Pin Description for Maximum Mode**

# QS<sub>1</sub> and QS<sub>0</sub>

## Pin 24 and 25 (Output)

These pins provide the status of instruction queue.

|           |    |    |          |
|-----------|----|----|----------|
| Vss (GND) | 1  | 40 | Vcc (5P) |
| AD14      | 2  | 39 | AD15     |
| AD13      | 3  | 38 | A16/S3   |
| AD12      | 4  | 37 | A17/S4   |
| AD11      | 5  | 36 | A18/S5   |
| AD10      | 6  | 35 | A19/S6   |
| AD9       | 7  | 34 | BHE/S7   |
| AD8       | 8  | 33 | MN/MX    |
| AD7       | 9  | 32 | RD       |
| AD6       | 10 | 31 | RQ/GT0   |
| AD5       | 11 | 30 | RQ/GT1   |
| AD4       | 12 | 29 | LOCK     |
| AD3       | 13 | 28 | S2       |
| AD2       | 14 | 27 | ST       |
| AD1       | 15 | 26 | S0       |
| AD0       | 16 | 25 | QS0      |
| NMI       | 17 | 24 | QS1      |
| INTR      | 18 | 23 | TEST     |
| CLK       | 19 | 22 | READY    |
| Vss (GND) | 20 | 21 | RESET    |

| $QS_1$   | $QS_0$ | Queue Status                                                                                          |
|----------|--------|-------------------------------------------------------------------------------------------------------|
| 0 (low)  | 0      | No Operation. During the last clock cycle, nothing was taken from the queue.                          |
| 0        | 1      | First Byte. The byte taken from the queue was the first byte of the instruction.                      |
| 1 (high) | 0      | Queue Empty. The queue has been reinitialized as a result of the execution of a transfer instruction. |
| 1        | 1      | Subsequent Byte. The byte taken from the queue was a subsequent byte of the instruction.              |

# $\overline{S_0}, \overline{S_1}, \overline{S_2}$

## Pin 26, 27, 28 (Output)

These status signals indicate the operation being done by the microprocessor.

This information is required by the Bus Controller 8288.

Bus controller 8288 generates all memory and I/O control signals.

|           |    |    |          |
|-----------|----|----|----------|
| Vss (GND) | 1  | 40 | Vcc (5P) |
| AD14      | 2  | 39 | AD15     |
| AD13      | 3  | 38 | A16/S3   |
| AD12      | 4  | 37 | A17/S4   |
| AD11      | 5  | 36 | A18/S5   |
| AD10      | 6  | 35 | A19/S6   |
| AD9       | 7  | 34 | BHE/S7   |
| AD8       | 8  | 33 | MN/MX    |
| AD7       | 9  | 32 | RD       |
| AD6       | 10 | 31 | RQ/GT0   |
| AD5       | 11 | 30 | RQ/GT1   |
| AD4       | 12 | 29 | LOCK     |
| AD3       | 13 | 28 | S2       |
| AD2       | 14 | 27 | S1       |
| AD1       | 15 | 26 | S0       |
| ADO       | 16 | 25 | QS0      |
| NMI       | 17 | 24 | QS1      |
| INTR      | 18 | 23 | TEST     |
| CLK       | 19 | 22 | READY    |
| Vss (GND) | 20 | 21 | RESET    |

# $\overline{S_0}, \overline{S_1}, \overline{S_2}$

## Pin 26, 27, 28 (Output)

| $\overline{S_2}$ | $\overline{S_1}$ | $\overline{S_0}$ | Status                |
|------------------|------------------|------------------|-----------------------|
| 0                | 0                | 0                | Interrupt Acknowledge |
| 0                | 0                | 1                | I/O Read              |
| 0                | 1                | 0                | I/O Write             |
| 0                | 1                | 1                | Halt                  |
| 1                | 0                | 0                | Opcode Fetch          |
| 1                | 0                | 1                | Memory Read           |
| 1                | 1                | 0                | Memory Write          |
| 1                | 1                | 1                | Passive               |



# **LOCK**

## **Pin 29 (Output)**

This signal indicates that other processors should not ask CPU to relinquish the system bus.

When it goes low, all interrupts are masked and HOLD request is not granted.

This pin is activated by using LOCK prefix on any instruction.

|           | 8086 |                |
|-----------|------|----------------|
| Vss (GND) | 1    | 40 Vcc (5P)    |
| AD14      | 2    | 39 AD15        |
| AD13      | 3    | 38 A16/S3      |
| AD12      | 4    | 37 A17/S4      |
| AD11      | 5    | 36 A18/S5      |
| AD10      | 6    | 35 A19/S6      |
| AD9       | 7    | 34 BHE/S7      |
| AD8       | 8    | 33 MN/MX       |
| AD7       | 9    | 32 RD          |
| AD6       | 10   | 31 RQ/GT0 HOLD |
| AD5       | 11   | 30 RQ/GT1 HLDA |
| AD4       | 12   | 29 LOCK WR     |
| AD3       | 13   | 28 S2 M/I/O    |
| AD2       | 14   | 27 ST DT/R     |
| AD1       | 15   | 26 S0 DEN      |
| AD0       | 16   | 25 QSO ALE     |
| NMI       | 17   | 24 QS1 INTA    |
| INTR      | 18   | 23 TEST        |
| CLK       | 19   | 22 READY       |
| Vss (GND) | 20   | 21 RESET       |

# $\overline{\text{RQ/GT}}_1$ and $\overline{\text{RQ/GT}}_0$

## Pin 30 and 31 (Bi-directional)

These are Request/Grant pins.

Other processors request the CPU through these lines to release the system bus.

After receiving the request, CPU sends acknowledge signal on the same lines.

---

$\overline{\text{RQ/GT}}_0$  has higher priority than  $\overline{\text{RQ/GT}}_1$ .

|           |    |    |               |
|-----------|----|----|---------------|
| Vss (GND) | 1  | 40 | Vcc (5P)      |
| AD14      | 2  | 39 | AD15          |
| AD13      | 3  | 38 | A16/S3        |
| AD12      | 4  | 37 | A17/S4        |
| AD11      | 5  | 36 | A18/S5        |
| AD10      | 6  | 35 | A19/S6        |
| AD9       | 7  | 34 | BHE/S7        |
| AD8       | 8  | 33 | MN/MX         |
| AD7       | 9  | 32 | RD            |
| AD6       | 10 | 31 | <b>RQ/GT0</b> |
| AD5       | 11 | 30 | <b>RQ/GT1</b> |
| AD4       | 12 | 29 | LOCK          |
| AD3       | 13 | 28 | S2            |
| AD2       | 14 | 27 | S1            |
| AD1       | 15 | 26 | S0            |
| AD0       | 16 | 25 | QS0           |
| NMI       | 17 | 24 | QS1           |
| INTR      | 18 | 23 | TEST          |
| CLK       | 19 | 22 | READY         |
| Vss (GND) | 20 | 21 | RESET         |

8086

# The Ready & Wait State

The READY input causes wait states for slower memory & I/O components.

A wait state( $T_w$ ) is an extra clocking period, inserted between T2 & T3, that lengthens the bus cycle.

If one wait state is inserted, then the memory access time, normally 460 ns with a 5 MHz clock, is lengthened by one clocking period (200ns) to 660 ns.