

# MicroProcessor 8086

Date - 25.02



Computer System



Decoding

# MP instruction Cycle have 3 Part



Support [20 bit] Address Bus

Architecture [16 bit MP] 8086



Section/Add  $\rightarrow$  [DS | CS | SS | ES]  
Segment

\* Physical Add. = (Seg. Add  $\times$  10H) + (Off. Add)

Example:

$$\begin{aligned} PA &= (1000H \times 10H) + 2345H \\ &= 10000H + 2345H \\ &= \boxed{12345H} \end{aligned}$$



\* 8086 supports maximum 6 byte instruction.

Arithmetic Operat<sup>n</sup>

Sub.  
Addition  
Multi.  
Divi.



AX  
BX  
CX  
DX

{ Data Register

SP  
BP

{ Pointer Reg.

SI  
DI

{ Index Reg.

\* Example :

$$\frac{04\text{H}}{1\text{byte}} + \frac{05\text{H}}{1\text{byte}} = \frac{09\text{H}}{1\text{byte}}$$

Ans : MOV AL, 04H

MOV BL, 05H



⇒ 2 independent functional Unit

### \* Bus Interface Unit (BIU)

1. Fetch instruction from memory
2. Read data from Port and memory
3. Write data to Port and memory

### \* Execution Unit (EU)

1. Tells the BIU where to fetch
2. Decodes instruction
3. Executes instruction

## ① ALU():

Add, subtract, AND, OR, XOR, increment, decrement, Complement, shift binary numbers.

## ② Total 19 Register [16 bit]

### ① Data Reg



### ② ADDRESS Reg.



### ③ Status Register / Flags Reg. [Hold Current status]



### ④ Temporary Register [Holding Operands]

For starting Add. — Var X 10

Ending Add. — (Starting add. + OFFFFFh)

## Physical Address Calculation

Ex:

- (i) 1000 H
- (ii) 1234 H

Soln:

Seg. Reg.

1000 H

1234 H

Val x 10

Star. Add

10000 H

12340 H

(St. Add + OFFRPH)

Erdig Add.

1FFFF H

12233 FH

?

Ex: Physical Add for > A9FB: 9872

Segment  
Add

Offset  
Add

$$PA = [Seg \times 10H + Off \text{ Add.}]$$

$$\Rightarrow A9FB0H \times 10H + 9872H$$

$$\Rightarrow A9FB0H + 9872H$$

$$\Rightarrow A9822H$$

$$\begin{array}{r} A9FB0 \\ 9872 \\ \hline A9822 \end{array}$$

$$1 \times 16 + 8$$

$$1 + F + 8 = 15 + 8 = 23$$

$$= (1 \times 16 + 8)$$

C

$$\begin{array}{r} B + 7 \\ n + 7 = 18 - 16 \\ = 2 \end{array}$$

$$1 + 4 + 9 = 14$$

## Flag Registers

16 bit — 9 Active flag



OF — Overflow Flag      ZF — Zero Flag

DF — Direction Flag      AF — Auxiliary Carry

IF — Interrupt Flag      PF — Parity

TF — Trap Flag      CF — Carry

SF — Sign

## Segment Registers

Memory Seg.

Sy register

Off. Reg.

Data Seg.

DSR

source index (SI)

Code "

CSR

Instruction Pointer (IP)

Stack Seg.

SSR

Stack Pointer (SP)  
Base Pointer (BP)

Extra Seg.

ESR

Destination Index (DI)

## Low Level Language



(\*) Assembly Language → SUB AX, BX  
(\*) Machine Language → 000101 00001 00100

### Program Statement :

1. Name Field [Colon(:)]
2. Operation [MOV, SUB --]
3. Operand [ADD AX, 2] → Two Operand Field
4. Comment u

(\*) colon separates  
MOV CX, 0 ; move 0 to CX  
Comment

(\*) semicolon ends  
Assembler ignores anything after ;

(\*) semicolon separates

MOV Word1, Word2  
 XCHG Word1, Word2

} illegal [Memory to memory & move is illegal]

MOV AX, Word1  
 XCHG Word1, AX

} Legal      MOV AX, Byte1      Illegal

\* Ex: NEH BX [BX = 0002]

Soln:

| Before | After |
|--------|-------|
| 0002   | FFFE  |
| BX     | BX    |

|      |      |                   |      |
|------|------|-------------------|------|
| 0000 | 0000 | 0000              | 0010 |
| 1111 | 1111 | 1111              | 1101 |
|      | 1    |                   | 1    |
|      |      | <u>10000 1110</u> |      |

Statement

① B = A

Translation

MOV AX, A ;

MOV B, AX ;

② A = 5 - A

MOV AX, 5 ; Put 5 in AX

SWB AX, A ; AX ... 5 - A

MOV A, AX ; Put it in A

③)  $A = B - 2^k A$        $MOV \ AX, B ; Ax has B$

$SUB \ AX, A ; Ax has B - A$

$SUB \ AX, A ; Ax has B - 2^k A$

$MOV \ A, AX ; move results to B$

# Different interface used in 8086 microProcessor

1. Memory interface [DRAM/ SRAM/ ROM]

2. Input/Output I/O

3. Interrupt I/O

4. Direct Memory Access Interface [Memory  $\rightarrow$  I/O Device]

5. Bus interface

# Addressing Mode:

1. Immediate Add. mode

6. Based Add. mode

2. Register

3. Direct

4. Indirect

5. Indexed

## \* # MicroProcessor Vs MicroController:

- |                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                    |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <p>① MP is the heart of Computer System</p> <p>② It is only a Processor, so memory and I/O devices need to be connected externally</p> <p>③ Memory and I/O device need to be connect externally, so the circuit becomes larger.</p> <p>④ You can't use it in compact system.</p> <p>⑤ Cost of the entire system high</p> | <p>① MC is the heart of an embedded system.</p> <p>② MC has a Processor along with internal memory and I/O devices.</p> <p>③ Memory and I/O are already present and the internal circuit is small</p> <p>④ You can use it in compact sys.</p> <p>⑤ Cost of the entire sys. low</p> |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|