

## Module - IV

classmate

Date \_\_\_\_\_

Page \_\_\_\_\_

### Introduction To 8086/88 MP.

- \* 8086 MP is the enhanced version of Intel 8085 MP.
- \* Designed by Intel in 1978.
- \* 8086 MP is a 16-bit MP.
- \* Has 16-bit data bus, so it can read data from / write data to memory & ports.
- \* Has 20 bit address bus.
- \* 8086 supports 2 modes of operation -
  - a) min mode
  - b) max mode

→ Difference b/w 8085 & 8086 MP =

| 8085 MP                                   | 8086 MP                                 |
|-------------------------------------------|-----------------------------------------|
| * 8-bit MP                                | 16-bit MP                               |
| * 16-bit ad. line                         | 20-bit ad. line,                        |
| * memory capacity<br>is 64 KB             | memory capacity<br>is 1 MB.             |
| + Have 5 flags                            | Has 9 flags.                            |
| * Does not support<br>pipeline            | Supports<br>pipeline.                   |
| * Does not support<br>memory segmentation | Does not support<br>memory Segmentation |

⇒ 8086 / 88 MP.

- \* They are part of the x86 family of processors, which is still widely used today in personal comp & other embedded systems.

## → Internal Architecture of 8086/88 =

- \* Includes several functional units, including ALU, the EU (Execution Unit), BIU (Bus Interface Unit) & Segment Register.
- \* BIU responsible for managing memory and I/O operation.
- \* uses a segmented memory architecture, which allows it to address more memory than 16-bit architecture.

### \* Features

|               | 8086   | 8088                            |
|---------------|--------|---------------------------------|
| * Data bus    | 16-bit | 8-bit                           |
| * Address bus | 20-bit | 20-bit                          |
| * Main memory | 1 MB   | 1 MB (bit only 64KB accessible) |

### \* (I) Set

|              | Name as          | Name as  |
|--------------|------------------|----------|
| * Pin count  | 40               | 40       |
| * Pipelining | High performance | Low-cost |
|              | PCs              | PCs      |

\* 8086 is a higher-performance processor than 8088

BIU (Bus Interface Unit) = (4)

- \* Fetch two (I)
- \* write data to memory

- \* BIU has → (I) pointer, segment (R) and (A) queue.
- \* write data to port
- \* Read data from port.

### \* EU (Execution Unit) = (3)

- \* To tell the BIU where to fetch the (I).
- \* To decode the (I).
- \* To execute the (I).

### \* General purpose (R) = (16-bit)

- \* a) AX : [Acc (R)] → Stores the result.
- \* b) BX : [Base (R)] → Stores the starting base loc. of memory.
- \* c) CX : [Counter (R)] → used in loop (I).
- \* d) DX : [Data (R)] → used to contain I/O port addresses for I/O (I).

### \* Instruction pointer (IP) :

(16-bit R) that holds the memory add. of next (I) to be executed.

### \* Instruction queue :

It is a buffer that holds up to 6 (I)s of the current (I) being executed.

### \* Segment (R) :

Used to specify the starting add. of a segment in memory.

## BIU ( )s

Segment (R) = (4 types)

a) CS (Code Segment) =

used for addressing a mem loc where  
true programs are stored.

b) DS (Data Segment) =

contain data which is used by P  
the program.

c) SS (Stack Segment) =

defined as area of memory  
used for stack.

d) ES (Extra Segment) =

similar to data segment where  
additional data is stored.

Flag (R) = (9 flag (R))



\* overflow flag:

OF = 1 → If true result is too long true now  
too small we now in acc.

\* direction flag =

DF = 1 → auto increment mode

If DF = 1 → auto decrement mode.  
used for string manipulation (I).

\* Interrupt flag :  
IF = 1 → maskable interrupt are  
recognized.

\* Trap flag :  
TF = 0 → if it is set, the processor  
will enter in single step  
execution mode.

⇒ Segmentation =

\* It is memory management technique used in  
comp system to divide memory into segments,  
each with its own unique ad - & size.  
\* can be used to separate different types  
of memory like code & data.  
\* In 8086, segmentation is implemented  
using segment (R).  
\* 2 types — code segment & data segment.

|             | Code Segment                 | Data Segment                  |
|-------------|------------------------------|-------------------------------|
| a) purpose  | contains program             | contains program              |
| (I)         |                              | data.                         |
| b) (R) used | CS (Code segment)            | DS (Data segment)             |
| c) eq       | machine ( )                  | variables, arrays             |
| d) size     | values based on program size | values based on program data. |



$\Rightarrow$  Physical address calculation =

\* Segment (R) = contains 16-bit address which points to the starting address loc. of each segment.

\* Offset address = within a segment part used loc. is pointed by offset ad.

\* Physical address = 20-bit ad. obtained by adding segment (R) & offset ad.

\* Segmnt (R) is shifted to left by adding OH to segment ad.

\* eg  $\rightarrow$  ①

Segment ad = 1034H      16  
Offset ad = 4404H.

1034H x 10H  $\rightarrow$  10340H

10340H  $\rightarrow$  0100 0100 0000 0100.

1000 0000 0011 0100 0000 +

1000 0100 0111 0100 0100

8      4      7      4      4       $\rightarrow$  PA

$\therefore$  84744H is physical ad (PA).

② CS  $\rightarrow$  4042H.

Value of offset ad  $\rightarrow$  BX: 2025H

$\checkmark$  IP: 0580H

DI: 4247H.

= 4042H x 10H + 0580H.

= 41000H

$\downarrow$

[IP  $\Rightarrow$  holds offset address]

$\Rightarrow$  Addressing modes of 8086 :

D) Immediate mode

Addressing mode

eg.

1) Immediate

Operand value is directly specified in the (I).

\* MOV AX, 1234H,  
\* MOV CL, 12H.

2) Register

Operand value is in a (R) A-mode

\* ADD AX, BX,  
\* MOV AX, BX.

3) Direct memory

Operand value is in memory at the address specified.

\* MOV AX, [1234H]  
\* MOV CL, [1321H]  
\* MOV [4321], 2322  
[data-memory]

4) Register based

Operand value is in memory with the address specified by the contents of a (R)

\* MOV AX, [BX]  
[16-bit data]  
(BX) into AX  
\* MOV AL, [BX]

5) Register relative

Operand value is in memory with the address specified by the contents of a (R) + a displacement

\* MOV AX,  
[BX+2H].

c) Base indexed

Operand value is in memory with the

\* MOV AX,  
[BX+SI]

cL  $\rightarrow$  Counter low  $\rightarrow$  ~~counter~~ cL  $\Rightarrow$  ②  $\downarrow$   
lower 8 bit is cL (16 bit)  
 $\checkmark$  DI (16 bit)

ALC (Acc low)  $\rightarrow$  8 bit lowered of AX (R) 

AH (Acc High)



ad. Specified by  
the sum of the  
contents of  $\oplus 2(R)$ .

D) Relative  
operand value is  
based  
indexed  
A-mode  
sum of the contents  
of  $\oplus 2(R)$  + a displacement

E) Implied  
A-mode

HLT,  
STC.

\* CCR's

(continuation)

- a) AX [ACC (R)]
- b) BX [Base (R)]
- c) CX [Counter (R)]
- d) DX [Data (R)]
- e) SI [Source Index (R)] =  
used as pointer to source data  
in memory for string operations.

- f) DI [Destination Index (R)] =  
used as pointer to the destination  
data in memory for string operations.
- g) BP [Base pointer (R)] =  
used as base pointer for stack operation.  
SP [Stack pointer (R)] = used as stack pointer  
for stack operations.

\* Index (R) =

\* Also  $\rightarrow$  Base (R) / pointer (R).  
as a base / offset for memory access.

