# 8086

Prof.Ms.Aaradhana Deshmukh aaradhana-deshmukh.in

#### **Some Questions**

- 1. 8086 is how many bit processor?
- 2. 16 bit means?
- 3. What is the size of data bus?
- 4. How many bits can be read from memory and write into memory? Why?
- 5. What is the size of address bus? It can acess how many ports?
- 6. Is 8086 possible to perform bit? Byte? Word? Block operations?
- Is 8086 supports multiprogramming?
- Long form of Intel Prof. Ms. Aaradhana A. Deshmukh,

# Software architecture of the INTEL 8086

- Memory segmentation and addressing
- Block diagram of 8086
- Address space & Data organization
- Data Types
- Registers
- Stack
- 1/0 space

#### Memory segmentation and addressing

- Von Newman architecture & Harvard architecture
- Program Memory & Data Memory
- Need for Segmentation
  - To implement Harvard architecture
  - Easy to debug
  - Same Interfacing ICs can be used
  - To avoid overlap of stack with normal memory
  - Compatible with 8085

## **Segmented Memory**



## **Memory Address Generation**

 The BIU has a dedicated adder for determining physical memory addresses.



#### **Segment: Offset Address**

- Logical Address is specified as segment:offset
- Physical address is obtained by shifting the segment address 4 bits to the left and adding the offset address.
- Thus the physical address of the logical address
   A4FB:4872 is:

# Segments, Segment Registers & Offset Registers

- Segment Size = 64KB
- Maximum number of segments possible = 14
- Logical Address 16 bits
- Physical Address 20 bits
- 2 Logical Addresses for each Segments.
  - Base Address (16 bits)
  - Offset Address (16 bits)
- Segment registers are used to store the Base address of the segment.

# Segments, Segment Registers & Offset Registers

- 4 Segments in 8086
  - Code Segment (CS)
  - Data Segment (DS)
  - Stack Segment (SS)
  - Extra Segment (ES)

| SEGMENT       | SEGMENT<br>REGISTER | OFFSET REGISTER                        |
|---------------|---------------------|----------------------------------------|
| Code Segment  | CSR                 | Instruction Pointer (IP)               |
| Data Segment  | DSR                 | Source Index (SI)                      |
| Extra Segment | ESR                 | Destination Index (DI)                 |
| Stack Segment | SSR                 | Stack Pointer (SP) / Base Pointer (BP) |

# Block diagram of 8086



FIGURE 2-7 8086 internal block diagram. (Intel Corp.)

## **Block diagram of 8086**

Figure 3.1 Processor model for the 8086 microprocessor. A separate execution unit (EU) and bus interface unit (BIU) are provided.



# Pipelined architecture of the 8086 microprocessors



### **Execution and bus interface units**



#### Software Model of the 8086 Microprocessors

## Microprocessor Architecture

# Day 5 Prof. Aaradhana Deshmukh

#### Address space & Data organization

| FFFFF       |
|-------------|
| FFFFE       |
| FFFFD       |
| FFFFC       |
|             |
|             |
|             |
|             |
|             |
| ]           |
|             |
|             |
| 5           |
| 4.          |
| 3           |
| 4<br>3<br>2 |
| 1           |
| 0           |
|             |



Storing a word in memory

What is the word in (b) in Hex?

Memory address space

## **8086 Registers**



#### **General Purpose Registers**



**AX - the Accumulator** 

**BX** - the Base Register

**CX - the Count Register** 

**DX - the Data Register** 

- Normally used for storing temporary results
- Each of the registers is 16 bits wide (AX, BX, CX, DX)
- Can be accessed as either 16 or 8 bits AX, AH, AL

### **General Purpose Registers**

#### AX

- Accumulator Register
- Preferred register to use in arithmetic, logic and data transfer instructions because it generates the shortest Machine Language Code
- Must be used in multiplication and division operations
- Must also be used in I/O operations

#### BX

- Base Register
- Also serves as an address register

#### **General Purpose Registers**

#### CX

- Count register
- Used as a loop counter
- Used in shift and rotate operations

#### DX

- Data register
- Used in multiplication and division
- Also used in I/O operations

#### **Pointer and Index Registers**

| SP | Stack Pointer       |
|----|---------------------|
| ВР | Base Pointer        |
| SI | Source Index        |
| DI | Destination Index   |
| IP | Instruction Pointer |

- All 16 bits wide, L/H bytes are not accessible
- Used as memory pointers
  - Example: MOV AH, [SI]
    - Move the byte stored in memory location whose address is contained in register SI to register AH
- IP is not under direct control of the programmer

# Flag Register

- Is a flip flop — which indicates some condition — produced by execution if instruction or controls certain operations of EU

### Flag Register



### 8086 Programmer's Model

BIU registers (20 bit adder)



**EU** registers



#### The Stack

- The stack is used for temporary storage of information such as data or addresses.
- When a **CALL** is executed, the 8086 automatically **PUSH**es the current value of CS and IP onto the stack.
- Other registers can also be pushed
- Before return from the subroutine, POP instructions can be used to pop values back from the stack into the corresponding registers.

## The Stack



# 8086

5 th Day

Prof.Ms.Aaradhana Deshmukh aaradhana-deshmukh.in

# Hardware Architecture of INTEL 8086

#### Hardware Architecture of INTEL 8086

- Pin Diagram and Pin Details
- min/max mode
- Hardware organization of address space
- Control signals
- Coprocessor and Multiprocessor configuration
- I/O interfaces

## INTEL 8086 - Pin Diagram





#### **Power Supply**

5V ± 10%

#### Reset

Registers, seg regs, flags

CS: FFFFH, IP: 0000H

If high for minimum 4 clks

#### Clock

Ground

Duty cycle: 33%



#### **Address Latch Enable:**

When high, multiplexed address/data bus contains address information.



Non - maskable interrupt

**Interrupt request** 



Interrupt acknowledge



**S6**: Logic 0.

**S5**: Indicates condition of IF flag bits.

**S4-S3**: Indicate which segment is accessed during current bus cycle:

| S4 | S3 | Function           |
|----|----|--------------------|
| 0  | 0  | Extra segment      |
| 0  | 1  | Stack segment      |
| 1  | 0  | Code or no segment |
| 1  | 1  | Data segment       |



#### **Address/Status Bus**

Address bits  $A_{19}$  –  $A_{16}$  & Status bits  $S_6$  –  $S_3$ 



**0,0:** Whole word (16-bits)

**0,1:** High byte to/from odd address

**1,0:** Low byte to/from even address

**1,1:** No selection



#### **Bus High Enable/S7**

Enables most significant data bits  $D_{15} - D_8$  during read or write operation.

S<sub>7</sub>: Always 1.

## **INTEL 8086 - Pin Details**



Min/Max mode

Minimum Mode: +5V

Maximum Mode: 0V

**Minimum Mode Pins** 

Maximum Mode Pins

## Minimum Mode- Pin Details



## Minimum Mode

- When only one 8086 CPU is to be used in microcomputer system.
- CPU issues the control signals required by memory and I/O devices

## **Maximum Mode - Pin Details**

#### **S2 S1 S0**

000: INTA

001: read I/O port

010: write I/O port

011: halt

100: code access

101: read memory

110: write memory

111: none -passive



#### **Status Signal**

Inputs to 8288 to generate eliminated signals due to max mode.

## **Maximum Mode - Pin Details**

#### **Lock Output**

Used to lock peripherals off the system

Activated by using the LOCK: prefix on any instruction



DMA Request/Grant

**Lock Output** 

## **Maximum Mode - Pin Details**



00: Queue is idle

01: First byte of opcode

10: Queue is empty

11: Subsequent byte of

opcode



#### **Queue Status**

Used by numeric coprocessor (8087)

### Maximum Mode

- When more than one 8086 CPU is to be used in microcomputer system.
- The control signals generated with the help of external bus controller.

## Minimum Mode 8086 System



# Minimum Mode 8086 System



# Maximum Mode 8086 System



# Maximum Mode 8086 System

- Here, either a numeric coprocessor of the type 8087 or another processor is interfaced with 8086.
- The Memory, Address Bus, Data Buses are shared resources between the two processors.
- The control signals for Maximum mode of operation are generated by the Bus Controller chip 8788.
- The three status outputs S0\*, S1\*, S2\* from the processor are input to 8788.
- The outputs of the bus controller are the Control Signals, namely DEN, DT/R\*, IORC\*, IOWTC\*, MWTC\*, MRDC\*, ALE etc.

## 8086 Interrupts



## **8086 Interrupts Procedure**

#### The Operation of Real Mode Interrupt

- 1. The contents of the FLAG REGISTERS are pushed onto the stack
- 2. Both the interrupt (IF) and (TF) flags are cleared. This disables the INTR pin and the trap or single-step feature. (Depending on the nature of the interrupt, a programmer can unmask the INTR pin by the STI instruction)
- The contents of the code segment register (CS) is pushed onto the stack.
- 4. The contents of the instruction pointer (IP) is pushed onto the stack.
- The interrupt vector contents are fetched, and then placed into both IP and CS so that the next instruction executes at the interrupt service procedure addressed by the interrupt vector.
- 6. While returning from the interrupt-service routine by the instruction IRET, flags return to their state prior to the interrupt and and operation restarts at the prior IP address.

# 8086 External Interrupts



# **8086 Control Signals**

- 1. ALE
- 2. BHE
- 3. M/IO
- 4. DT/R
- 5. RD
- 6. WR
- 7. DEN

# Coprocessor and Multiprocessor configuration

 Multiprocessor Systems refer to the use of multiple processors that executes instructions simultaneously and communicate with each other using mail boxes and Semaphores.

- Maximum mode of 8086 is designed to implement 3 basic multiprocessor configurations:
  - **1. Coprocessor (8087)**
  - 2. Closely coupled (8089)
  - 3. Loosely coupled (Multibus)

# Coprocessor and Multiprocessor configuration

- Coprocessors and Closely coupled configurations are similar in that both the 8086 and the external processor shares the:
  - Memory
  - I/O system
  - Bus & bus control logic
  - Clock generator

# Coprocessor / Closely Coupled Configuration



## TEST pin of 8086

- Used in conjunction with the WAIT instruction in multiprocessing environments.
- This is input from the 8087 coprocessor.
- During execution of a wait instruction, the CPU checks this signal.
- If it is low, execution of the signal will continue; if not, it will stop executing.

## **Coprocessor Execution Example**

Coprocessor cannot take control of the bus, it does everything through the CPU



## **Closely Coupled Execution Example**

- Closely Coupled processor may take control of the bus independently.
- Two 8086's cannot be closely coupled.



## **Loosely Coupled Configuration**

- has shared system bus, system memory, and system
   I/O.
- each processor has its own clock as well as its own memory (in addition to access to the system resources).
- Used for medium to large multiprocessor systems.
- Each module is capable of being the bus master.
- Any module could be a processor capable of being a bus master, a coprocessor configuration or a closely coupled configuration.

## **Loosely Coupled Configuration**

- No direct connections between the modules.
- Each share the system bus and communicate through shared resources.
- Processor in their separate modules can simultaneously access their private subsystems through their local busses, and perform their local data references and instruction fetches independently. This results in improved degree of concurrent processing.
- **Excellent** for real time applications, as separate modules can be assigned specialized tasks

# Advantages of Multiprocessor Configuration

- 1. High system throughput can be achieved by having more than one CPU.
- 2. The system can be expanded in modular form.

  Each bus master module is an independent unit and normally resides on a separate PC board. One can be added or removed without affecting the others in the system.
- 3. A **failure** in one module normally does not affect the breakdown of the entire system and the faulty module can be easily detected and replaced
- 4. Each bus master has its own local bus to access dedicated memory or IO devices. So a greater degree of parallel processing can be achieved.

## **8086 System Memory Circuitry**

1. Minimum Mode System Memory Circuitry

2. Maximum Mode System Memory Circuitry

## **Minimum Mode System Memory Circuitry**



### **Maximum Mode System Memory Circuitry**

