# Internal Architecture Of 8086 Microprocessor

#### **Course Teacher:**

#### Md. Fahmidur Rahman Sakib

Lecturer, Department of Computer Science & Engineering Metropolitan University

Course ID: CSE 237

Course Title: Microprocessor and Interfacing

#### Lecture References:

#### Book:

Microprocessors and Interfacing: Programming and Hardware, Chapter # 2, Author: Douglas V. Hall

## Organization of the 8086

- Microprocessor 8086 is internally divided into two separate functional units. These are:
  - Bus Interface Unit (BIU)
  - Execution Unit (EU).
- These two functional units can work simultaneously to increase system speed and hence the throughput.
- Throughput is a measure of number of instructions executed per unit time.
- These two units interact directly with each other through Internal Bus.

#### 16-Bit 8086 Intel Processor Architecture



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

#### Bus Interface Unit

- ➤ **BIU:** facilitates communication between the EU & the memory or I/O circuits. It provides a full 16-bit bidirectional data bus and 20-bit address bus.
  - Responsible for transmitting addresses, data, and control signals on the buses.
  - Registers (CS, DS, ES, SS, and IP) hold addresses of memory locations.
  - > **IP** (instruction pointer) contain the address of the next instruction to be executed by the EU.

#### Bus Interface Unit

The bus interface unit is responsible for performing all external bus operations, as listed below.

- It sends address of the memory or I/O.
- It fetches instruction from memory.
- It reads data from port/memory.
- It Writes data into port/memory.
- It supports instruction queuing.
- It provides the address relocation facility.

#### Physical Address Calculation in BIU

➤ To generate 20 bit physical address Segment Registers (CS, DS, SS, ES) and Pointer and Index Registers (IP, SP, BP, SI, DI) are needed.

| Segment | Offset Registers | Function                                                 |
|---------|------------------|----------------------------------------------------------|
| CS      | IP               | Address of the next instruction                          |
| DS      | BX, DI, SI       | Address of data                                          |
| SS      | SP, BP           | Addresses in the stack                                   |
| ES      | BX, DI, SI       | Address of destination data<br>(for string instructions) |

#### Memory Segment and Segment Registers



CSE 237 : Microprocessor & Interfacing Metropolitan University

#### Physical Address Calculation Examples



#### Physical Address Calculation Examples

The contents of the following segment registers are as given.

CS = 1111H, DS = 3333H, SS = 2526H.

IP = 1232H, SP = 1100H, offset in data segment = 0020H.

Calculate the corresponding physical addresses for the addressed byte in a) CS b) SS and c) DS.

#### Solution

- a) The base address of the code segment is 11110H. The address of the next instruction to be executed is referenced by CS and IP which is given by 11110H + 1232H = 12342H.
- b) The current top of the stack is referenced by SS and SP. The base address of the stack segment is 25260H. The corresponding physical address is 25260H + 1100H = 26350H.
- c) The data that needs to be accessed is given by DS and the offset. The base address of the data segment is 33330H. The physical address of this data is calculated as 33330H + 0020H = 33350H.

### Instruction Queue

- To speed up program execution, the BIU fetches six instruction bytes ahead of time from the memory.
- These prefetched instruction bytes are held for the execution unit in a group of registers called Queue.
- With the help of queue it is possible to fetch next instruction when current instruction is in execution.
- The queue operates on the principle first in first out (FIFO). So that the execution unit gets the instructions for execution in the order they are fetched.
- Exceptions: JUMP and CALL instructions

# Instruction Queue



### Instruction Queue



Fig: Pipelining

# Execution Unit (EU)

- The execution unit of Internal Architecture of 8086 tells the BIU from where to fetch instructions or data, decodes instructions and executes instructions. It contains
  - Control Circuitry
  - 2. Instruction Decoder
  - 3. Arithmetic Logic Unit (ALU)
  - 4. Flag Register
  - General Purpose Registers
  - 6. Pointers and Index Registers

# Execution Unit (EU)

- The main components of the EU are General purpose registers, the ALU, Special purpose registers, Instruction Register and Instruction Decoder and the Flag/Status Register.
- Fetches instructions from the Queue in BIU, decodes and executes arithmetic and logic operations using the ALU.
- Sends control signals for internal data transfer operations within the microprocessor.
- Sends request signals to the BIU to access the external module.
- It operates with respect to T-states (clock cycles) and not machine cycles.

# Arithmetic Logic Unit (ALU)

- This unit performs all arithmetic and logical computations.
- Instructions those are fetched and decoded, are executed in the ALU

Thus, ALU has direct access to General Purpose Registers and Flags.

# Temporary and Flag registers

- Every processor has some temporary registers those are not visible to the programmers.
- For these registers, our data are not lost in between different kinds of operations,
  - > XCNG CX, BX
    - MOV temp, CX
    - MOV CX, BX
    - MOV BX, temp
- > FLAG Registers: A flag is a flip—flop which indicates some condition produced by the execution of an instruction or controls certain operations of the EU.

# Thank You!!