

## Introduction of 8086 MP's

### D. i) Register Organization of 8086 :-

In 8086 MP has Powerful set of Registers known as General Purpose Registers and Special Purpose Registers. All are 16-bit Registers.

The general purpose registers, can be used as either 8-bit registers (d) 16-bit registers which are used for holding data, variable and immediate results temporarily (e) for other purpose like a Counter (f) for storing offset address for particular address.

The special purpose registers used as segment registers, pointers, index registers, (g) as offset storage register for particular addressing model.

The Registers are categorized into 4-groups :-

- General Data Registers
- Segment Registers
- Pointers and Index Registers
- Flag Registers.

#### a) General Data Registers :-

The Registers AX, BX, CX, & DX are the 16-bit general purpose Registers.

→ AX is used as 16-bit accumulator with lower 8-bit of AX designated as "AL" and higher 8-bit designated as "AH". This is the most important general purpose register having multiple functions.

- The "Bx" register is used as an offset storage for forming physical address in case of certain addressing modes.
- The "Cx" register is used as default counter in case of string and loop instructions.
- The "Dx" register is used as a implicit operand (8-bit destination) in case of a few instructions.

From all above register's X-letter stands for specify the complete 16-bit registers.

Higher (8-bit)

Lower (8-bit)

AX

AH

AL

(Accumulator)

BX

BH

BL

(Base Register)

CX

CH

CL

(Count Register)

D<sub>X</sub>

DH

DL

(Data Register)

16-bit registers

### b) Segment Registers :-

The Complete 1 Megabyte memory which the 32-bit address, is divided in to 16 logical segments. Each segment thus contains 64 Kbytes of memory.

There are four (4) Segment Registers.

- Code segment
- Stack segment
- Data segment
- Extra segment



Segment Registers

3

- a) The Code Segment :- This register is used for addressing a memory location in the Code Segment of the memory, where the executable Program is stored.
- b) Data Segment :- This type of register Points to the data segment of the memory where the data is Resided.
- c) Extra Segment :- Refers to a segment which essentially is another data segment of the memory. Thus Extra segment also contains data. ~~segment~~.
- d) Stack Segment :- Register is used for addressing Stack segment of memory which is used to store stack data. The CPU uses the stack for temporarily storing important data.

Note:- All these segment registers are logical segments.

#### General Info of Segment Registers:-

- While addressing any location in the memory bank, the physical address is calculated from two parts,
- (i) Segment Address      (ii) Offset
  - (i) Segment Address Contains 16-bit segment base addresses related to different segments.
  - (ii) In any of pointer and index registers (iii) BX may contain offset of the location to be addressed.

The advantage of this scheme is that instead of maintaining a 20-bit register for a physical address, the Processor just maintains two 16-bit registers which are within the word length capacity of the machine.

They may or may not be physically separated. In other words, a single segment may require more than one memory chip (or) more than one segment may be accommodated in a single memory chip.

### c) Pointers and Index Registers :-

The pointer contains offset within the particular segments.

The pointer IP, BP and SP usually contain offset within the code (JP) and stack (BP & SP) segments.

#### (i) Stack Pointer :-

used to hold the address of stack top. Stack top is upper most filled memory location in stack memory

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

#### (ii) Base pointer :-

Acts as a memory pointer to stack segment register.

Where BP is mainly used to access any location directly in the stack.

#### (iii) Source Index & Destination Index :-

Acts as memory pointers

relative to segment register  
of the data from SI and  
DI (Note:- Index register used in string manipulation).

DS. & IP will take effective address  
stores in DI. (Note:- Index register used in string manipulation).

#### (iv) Instruction Pointer :-

The offset address of the next instruction is contained in IP. That is IP points to next instruction to be fetched from code segment.

#### d) Flag Registers :-

The 8086 flag registers contents indicates the results of computation in the ALU. It contains some flag bits to control the CPU operations..

#### e) Architecture of 8086 Micro Processor :-

→ 8086 provides no:- of improvements over 8085 MP.

→ 8086 provides 16-bit ALU (Arithmetic Logical unit),  
→ The 8086 MP supports 16-bit registers, and provides Segmented registers, a set of 16-bit registers, and provides Segmented registers, memory addressing capability, a rich instruction set, Powerful interrupt architecture, fetched instruction queue for overlapped fetching and execution etc;

→ The 8086 MP Architecture divided in two parts.

(a) Bus Interface Unit (BIU)

(b) Execution Unit (EU).

→ The 8086 MP a 16-bit MP with 16-bit internal and external data bus, with 20-address lines it can access

$2^{20}$  = 1 MB memory.

#### a) Bus Interface Unit (BIU) :-

It contains the circuit for physical address calculations and a Predecoding instructions byte queue (6-bytes long). This BIU takes the system's bus signal available for external interfacing of the devices, which this unit is responsible for establishing communication with external devices & peripherals including memory via bus.

b) Execution Unit (EU):- Executes the previously decoded instructions concurrently. The BIU along with Execution Unit (EU) thus forms a pipeline.

\* → The BIU, thus manages the complete interface of execution unit with memory and I/O devices, of course, under control of timing and control unit.

\* → The EU contains the register set of 8086 except segment register and instruction pointer (IP). It has.

and ALU, able to perform arithmetic and logical operations.

\* 16-bit ALU, able to perform arithmetic and logical operations.

\* 16-bit Flag register reflects the result of execution by ALU.

\* The decoding unit decodes the opcode byte issued from the instruction byte.

\* The timing and control unit devices the necessary control signals to execute the instruction opcode received from the queue, depending upon the information made available by decoding circuit.

\* Thus Execution unit may pass the results to the bus.

\* Interface unit for storing them in memory.

## Working Process:-

(7)

① Bus Interface Unit :- It Contains following

- (i) The circuit for Physical address Calculations (Adder)
- (ii) Pre decoding instruction byte Queue
- (iii) Segment registers
- (iv) Instruction pointers.

The main function of BIU are

- \* The BIU handles all interfaces with external bus and generates external memory and I/O address.
- \* The BIU reads data from the memory and ports and write data in to memory and ports.
- \* It fetches instructions codes from the memory and keeps them in to a 6-byte instruction queue.
- \* Whenever the bus is idle and 2-bytes of the queue are vacant.
- \* In case of Jump and CALL instructions the BIU jumps the queue and then starts rebinding it from new address.

i) Adder :- The 8086 MP address a Segmented memory. The complete physical address which is 20 bits long is generated using segment and offset registers. For generating a physical address from contents of these two registers, the contents of segment registers also called as segment address is shifted by bit wise four times and to this result. Content of offset register is also called offset register. Address offset produce 20-bit physical address.

e.g. If segment address is 1005H  
and offset address is 5555H then physical address  
is calculated as

$$\begin{array}{l} \text{Segment address} \rightarrow 1005\text{H} \\ \text{Offset address} \rightarrow 5555\text{H} \end{array}$$



where

$$\begin{array}{l} \text{Segment address} \rightarrow 1005\text{H} \rightarrow 0001 \ 0000 \quad 0000 \ 0101 \\ \text{Shifted by 4-bit position} \rightarrow 0001 \ 0000 \ 0000 \quad 0101 \ 0000 \quad \} + \\ + \quad ; \quad , \quad 0101 \ 0101 \ 0101 \ 0101 \\ \text{Offset address} \rightarrow 5555\text{H} \rightarrow \\ \hline 0001 \ 0101 \ 0101 \ 1010 \ 0101 \\ 1 \quad 5 \quad 5 \quad A \quad 5 \end{array}$$

\* The segment register indicates the base address of particular segment

\* The offset register indicates the distance of required memory location  
in segment from base of the address.

\* The segment address by segment value "1005H" can have offset  
from "0000H" to "FFFFH" within it, i.e. maximum 64K locations.  
may be accommodated in the segment.

\* Since the offset is a 16-bit number each segment can have a  
maximum 64K locations.

The Bus Interface Unit has a separate ability to perform  
this procedure for obtaining physical address while addressing memory.

\* The segment address value is to be taken from an appropriate  
segment register depending upon whether code, data (or) stack  
are to be accessed, while the offset may be content of IP, BX,  
DI, SP, BP (or) an immediate 16-bit value depending on addressing mode.

### (ii) Instruction Queue :-

In 8085 MP, once the OP-Code is fetched and decoded, the external bus remains free for some time, while the processor internally executes the instruction. This time slot is utilized in 8086 to achieve the overlapped fetch and execution cycles, while the fetched instruction is executed internally the external bus is used to fetch the machine code of next instruction and arrange it in a queue called as Predecoded instruction byte Queue.

Queue is a 6-bytes long, first in - first out structure. The instruction from the queue are taken for decoding sequentially. Once a byte is decoded, the queue is re-arranged by pushing it out and the queue status is checked for the possibility of the next OP-Code fetch cycle.

### (iii) Segment Registers :-

- \* The Code segment contains instructions codes of a program.
- \* The Stack segment is that segment of memory which is used to store stack data.
- \* The Extra segment contains the destination of source data of certain string instruction.
- \* The Data segment contains program defined data, variables and constants.

### (iv) Instruction Pointer:-

It acts as a program counter. It holds 16-bit offset pointing to the next instruction in the current 64KB code segment.

### b) Execution Unit :- (EU)

(b)

- \* → The EU receives Prefetched instructions from the queue. It decodes them and then executes them. The queue acts as first in first out for EU.
- \* → If the queue is empty, the EU waits until the queue gets at least one byte. Such situation arises after the execution of a jump instruction.
- \* → The EU contains the register set of 8086 except segment registers and IP.
- \* → The EU has 8 GPR's (General Purpose Registers) labeled as AH, AL, BH, BL, CH, CL, DH, DL and used individually for temporary storage of 8-bit data.

The advantage of using internal register for temporary storage is that, since the data is already in the EU, it can be accessed much more quickly than it could be accessed in external memory.

- \* → It has ALU (Arithmetic Logical Unit) of 16-bit able to perform arithmetic and logical operations.
- \* → The 16-bit flag register reflects the result of execution by ALU.
- \* → The decoding unit decodes the op-code byte issued from the instruction byte queue.
- \* → The timing and control unit derives the necessary control signals to execute the instruction op-code received from the queue.
- \* → The EU may pass the result to the BIU for storing them in memory.



Fig. 1.2 8086 Architecture

The complete architecture of 8086 can be divided into two parts (a) Bus Interface Unit (BIU) and (b) Execution Unit (EU). The bus interface unit contains the circuit for physical address calculations and

### 3) Status Registers (or) flag Registers :- (16-bit)

- \* → A flag is a flip-flop which indicates some condition produced by the execution of an instruction. The 8086 CPU has 16-bit Program Status Word (PSW).
- \* → In 16-bit flag Registers 8086 CPU has 9-flags and remaining 7-flags bit positions of status registers are undefined (X).
- \* → In 9-bit of flags 6-flags are conditional flags they are set (S) or reset by the processor depending on the result of some arithmetic & logical operations.
- \* → The 6-conditional flags are CF, PF, AF, ZF, SF, OF.
- \* → The remaining 3-flags are control flags these are set (S) or reset by programmer as required by certain instructions in a program.
- \* → The control flags are TF, DF, IF.

8086 CPU  
Configurable Flags

|    |    |    |    |    |    |    |    |    |    |   |    |   |    |   |    |
|----|----|----|----|----|----|----|----|----|----|---|----|---|----|---|----|
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5 | 4  | 3 | 2  | 1 | 0  |
| X  | X  | X  | X  | OF | DF | IF | TF | SF | ZF | X | AF | X | PF | X | CF |

X → undefined (7-bits of flags positions of status Registers).

#### 6 - Conditional flags

- CF → Carry Flag
- PF → Parity Flag
- AF → Auxiliary Flag
- ZF → ZERO Flag
- SF → Sign Flag
- OF → Over Flow Flag

#### 3 - Control flags

- DF → Direction Flag
- IF → Interrupt Enable flag
- TF → Trap flag

## (i) Conditional flags :-

- a) Carry flag (CF) :- This flag is set whenever a carry/borrow occurs during arithmetic operations such as addition (or) subtraction otherwise it is reset.
- b) Parity flag (PF) :- This flag is set to '1' if the lower byte of the result contains even no. of 1's.  
 If the lower byte of result contains odd no. then Parity flag is set as zero (0);
- c) Auxiliary Carry flag (ACF) :- This is set if there is a carry from the lowest nibble  
 Eg:- ie; bit three during addition of borrow for lowest nibble (4-bit)  
 Eg:- ie; bit three during subtraction <sup>into</sup> (two bit).
- d) Sign flag :- (SF) :- This flag is set when the result of any computation is negative.  
 If the flag is set, if MSB of the result is zero.  
 It is set to zero if the MSB of result is zero.
- e) Zero flag :- (ZF) :- This flag is set if the result of an arithmetic (or) logic operation is zero. In case of non zero result this flag is set zero.
- f) Overflow flag (OF) :- This flag is set if an overflow occurs i.e if the result of a signed operation is large enough to be accommodated in a destination register overflow flag has no significance in unsigned arithmetic operation.

## ii) Control flags:-

- a) Trap flag (TF):- It is used for single step control . If this flag is set the processor enters the single step execution mode. It allows user to execute one instruction of a program at a time for debugging.
- b) Interrupt flag (IF):- It is a interrupt enable/disable flag. If this is set the maskable interrupts are recognized by the CPU , otherwise they are ignored.
- c) Direction flag (DF):- It is used by string manipulation instructions. If this flag bit is '0' the string is processed beginning from the lowest address to the highest address i.e auto incrementing mode otherwise the string is processed from the highest address towards lowest address i.e auto decrementing mode.

## 4) Memory Segmentation :-

Memory is physically a linear sequence of addresses, each address holding a single byte. The lowest memory address is '0', the next address is address '1' and so on until the highest memory address is reached.

The highest memory address for the 8086 is address FFFFH. In 8086 available memory space is divided into "chunks" called segments, such a memory is known as segment memory. The 8086 is able to address 1MB bytes of physical memory. The complete 1MB of memory can be divided into 6 segments, each of 64 kbytes size.



- \* The address of the segment may be assigned as  $0000H$  to  $FFFFH$  respectively.
- \* The offset address values are from  $0000H$  to  $FFFFH$  respectively.
- \* The above four segments are non-overlapped segments.
- \* In some user segments may be overlapping to address a specific memory location within a segment an offset address is needed.

The main advantages of segmented memory scheme are:

- (i) Allows the memory capacity to be 1Mbyte although the actual address space of 16-bit size.

(16)

- 2) Allows the placing of code, data and stack portions of the same program in different parts (segment) of memory, for data and code operation.
- 3) permits a program and/or its data to be put into different areas of memory each time the program is executed i.e. provision for relocation is done.

### Calculations of Physical address :-

In overlapped area location Physical address =  $CS_1 + IP_1 = CS_2 + IP_2$

where '+' indicates the procedure of physical address formation.



Non overlapping segments



Overlapping segments.

Eg:- Calculate physical address of CS:IP = 348A : 4214 ?



Eg:- Calculate the Physical address of SS:SP = 5000 : FFE0 ? (17)



Eg:- If an absolute address of the type 6A3D9 is given express it in the form of CS:IP?

Let us assume that CS contains 6000H the offset address is calculated as

$$\text{Offset} = 6A3D9H - 6000 \times 10H = A3D9H$$

$$\text{Hence } CS:IP = 6000 : A3D9.$$

## 5) Addressing Modes:-

Each instruction performs an operation on the specified data (operand). Hence an operand must be specified for an instruction to be executed. The operand may be reside in accumulator, in a general purpose register (R) or in a memory location.

\* The way by which an operand is specified for an instruction is called "Addressing Mode".

As to the flow of instruction execution the instructions

may be categorized as

(i) sequential control flow instructions

(ii) Control transfer instructions,

## ADDRESSING MODES

- An instruction performs an operation on the specified data is known as **operand**.
- Addressing modes indicates a way of locating data or operand which is accessed by an instruction that to be executed.

### **categories of addressing modes:**

1. sequential control flow
2. control transfer instruction

#### 1. Sequential control flow instruction:-

which offers execution, control transfer to the next instruction appearing immediately after it in the program.

Eg:- arithmetic, logical , data transfer, processor control

#### 2. Control transfer instruction

Instructions transfer control to the some predefined address or the address some how specified in the instructions ,after their execution.

Eg:- INT,CALL,RET,& JUMP

### **Addressing modes in sequential control flow**

There are 8 addressing modes for sequential control flow

- In this 2-addressing modes are provided for instructions which operate on Registers (or) immediate operands
- The remaining 6- addressing modes are for specifying an operand stored in the memory

### **Types of Addressing modes for Register (or) operand instructions**

1. Immediate Addressing Mode
2. Direct Addressing Mode
3. Register Addressing Mode
4. Register Indirect Addressing Mode
5. Indexed Addressing Mode
6. Register Relative Addressing Mode
7. Based Indexed Addressing Mode
8. Relative Based Indexed Addressing Modes

#### **Register addressing mode :**

The operand to be accessed is specified as residing in an internal register of 8086.

Fig. below shows internal registers, any one can be used as a source or destination operand, however only the data registers can be accessed as either a byte or word.

| <b>REGISTER</b>      | <b>OPERAND</b> | <b>SIZES</b>                             |
|----------------------|----------------|------------------------------------------|
|                      |                | <b>BYTE (REG-8)</b> <b>WORD (reg-16)</b> |
| <b>ACCUMULATOR</b>   | <b>AL, AH</b>  | <b>AX</b>                                |
| <b>BASE</b>          | <b>BL,BH</b>   | <b>BX</b>                                |
| <b>COUNT</b>         | <b>CL,CH</b>   | <b>CX</b>                                |
| <b>DATA</b>          | <b>DL,DH</b>   | <b>DX</b>                                |
| <b>STACK POINTER</b> | -              | <b>SP</b>                                |
| <b>BASE POINTER</b>  | -              | <b>BP</b>                                |

|                          |   |           |
|--------------------------|---|-----------|
| <b>SOURCE INDEX</b>      | - | <b>SI</b> |
| <b>DESTINATION INDEX</b> | - | <b>DI</b> |
| <b>CODE SEGMENT</b>      | - | <b>CS</b> |
| <b>DATA SEGMENT</b>      | - | <b>DS</b> |
| <b>STACK SEGMENT</b>     | - | <b>SS</b> |
| <b>EXTRA SEGMENT</b>     | - | <b>ES</b> |

### 1. Immediate Addressing Mode

The data is part of instruction itself and is available in successive bytes of instruction code.

**Example:** -

MOV AL,26H //\*\*\*\*\* copies 8-bit data 26H in to AL register  
(since AL is 8-bit register)

**Example:-**

MOV AX, 4653H //\*\*\*\*\*copies 16-bit data 4653H in to ax register pair  
( Since AX is pair of two 8-bit AL & AH registers)

### 2. Direct Addressing Mode

The instruction operands specifies in memory address (offset) where data is located.

**Example:-**

MOV AX, [5000] ; 5000 is a ~~Effective~~ <sup>OFFSET</sup> Address [offset] directly written in the address.



Data resides in a memory location in data segment(DS), whose Effective Address is computed using 5000H as the offset address & content DS as segment address

**Effective Address {EA}** here is =  $10H * DS + 5000H$

### 3. Register Addressing Mode

Refers the data in a register (or) in a register pair . All the registers, except IP, may be used in this mode.

**Eg:** -

MOV AX, CX //\*\*\*\*copies 16-bit content of CX into AX register pair  
MOV AL, CL //\*\*\*\* copies 8-bit content of CL into AL register



#### 4. Register Indirect Addressing Mode

The address of the memory location which contain data or operand is determined as indirect way. Using the offset register, this mode of addressing is known as register indirect mode.

In this mode the offset address is either BX (or) SI (or) DI register.

The default segment is either DS (or) ES .

Eg:

**MOV AX, [BX]** //\*\* data present in memory location in DS whose offset address is i BX.

$$\text{Effective address} = 10H * \text{DS} + [\text{BX}]$$



#### 5. Indexed Addressing Mode

- In this addressing mode, offset of the operand is stores in one of the index registers. DS is the default segment for index register SI and DI . in this case DS and ES are default segment for SI and DI respectively .
- This mode is special case of the above discussed register indirect addressing mode.

Eg:-

**MOV AX, [SI]**

Here data is available at an offset address stored in SI in DS. The Effective Address, in this case is computed as

$$\text{EA} = 10H * \text{DS} + [\text{SI}]$$

#### 6. Register Relative Addressing Mode

- In this addressing mode , data is available at EA formed by adding 8-bit (or) 16-bit displacement With content of any of registers BX,BP,SI and DI in the default (either DS or ES) segment.

Eg:-

**MOV AX, 50H[BX]**

Here Effective Address =  $10H * \text{DS} + 50H + [\text{BX}]$



## 7. Based Indexed Addressing Mode

### ➤ Based Addressing Mode:

The effective address will be the contents of base register (or) base pointer register.

### ➤ Based Indexed Addressing Mode:

- This is same as register indirect
- The effective address of the operand is formed by adding contents of base register to the index registers.
- DS and ES are default segments,
- SI and DI are used as index registers and BX and BP are used as base registers.

**Example:** MOV AX, [BX][SI]



## 8. Relative Based Indexed Addressing Modes

The Effective address of the operand is formed by adding 8-bit or 16-bit displacement with the contents of any one of the base registers( i.e. BX/BP) and index register (i.e. SI/DI) in the default segments.

**Example:** MOV AX, 50H [BX][SI]

Here 50H is immediate displacement



ii) Control transfer instructions :-(ox) Program Memory access A.M :-

\* → The Program memory access addressing modes explain about the transfer of control to some other location which is not in sequence hence applicable to Control transfer instruction and some times known as Control transfer addressing modes.

\* → The Control transfer addressing modes depends upon whether the destination location is within same segment (8) or in different on. It is also depends up on the method of passing the destination address to the processor.

There are 2-types of Addressing modes for Control transfer instructions.

(i) Inter segment Am

(ii) Intra segment Am.

\* → If the location to which the control is to be transferred lies in a different segment other than the current one, the mode is called intersegment mode.

\* → If the destination location lies in the same segment the mode is called intrasegment mode.

Model for Control transfer instructions



### (i) Intra Segment Direct mode :-

In this mode the address to which the control is to be transferred lies in the same segment in which the control transfer of instruction lies and appears directly in instruction as an immediate displacement value.

In this addressing mode the displacement is computed relative to the Content of Instruction Pointed IP.

The Effective Address to which the Control will be transferred is given by sum of 8 (8) 16-bit displacement and Content Content of IP.

In case of jump instruction, if the signed displacement ( $d$ ) is of 8-bit (ie  $-128 < d < 127$ ), we term it as short jump. If it is 16-bits (ie  $-32768 < d < 32767$ ) it is termed as long jump.

Eg.: JMP SHORT LABEL; LABEL lies within -128 to 127 from the Current IP Content thus SHORT LABEL is 8-bit signed displacement.

### ii) Intra Segment Indirect mode:-

In this mode, the displacement to which the control to be transferred, is in the same segment in which the control transfer instructions lies, but it is passed to the instruction indirectly.

Here, the branch address is found as the content of a register or a memory location. The addressing mode may be used in unconditional branch instructions.

JMP [BX]; Jump to effective address stored in BX  
 JMP [BX + 5000H].

(iii) Inter segment Direct :-

In this mode, the address to which the control is to be transferred is in a different segment. This addressing mode provides a means of branching from one code segment to another code segment.

Here the CS and IP of the destination address are specified directly in the instruction.

Eg:- JMP 5000H : 2000H ; Jump to effective address 2000H in segment 5000H.

(iv) Inter segment Indirect :-

In this mode, the address to which the control is to be transferred lies in a different segment and it is passed to the instruction indirectly.

Contents of a memory block containing four bytes i.e IP (LSB), IP (MSB), CS (LSB) and CS (MSB) sequentially.

The starting address of the memory block may be referred using any of the addressing modes, except immediate mode.

Eg:- JMP [2000H] ;

Jump to an address in the other segment specified at effective address 2000H in DS, that points to the memory block or said above.

MSB → Most Significant Bit

LSB → Least " "

## 6) Forming the Effective Address :-

e.g.: - The Contents of different registers are given below. form EA for different addressing mode.

$$\text{offset (displacement)} = 5000H$$

$$[AX] = 1000H, [BX] = 2000H, [SI] = 3000H, [DI] = 4000H,$$

$$[BP] = 5000H, [SP] = 6000H, [CS] = 0000H, [DS] = 1000H,$$

$$[SS] = 2000H, [IP] = 7000H$$

shifting a number four times is equivalent to multiply it by  $16_D$  ( $10_H$ )

### (i) Direct addressing mode:-

MOV Ax, [5000H]  $\xrightarrow{\text{offset address}}$

$$DS : \text{OFFSET} \Leftrightarrow 1000H : 5000H$$

$$10H * DS = 10000$$

$$\text{offset} = +5000$$
$$\underline{15000H} \rightarrow \text{Effective address}$$

### (ii) Register indirect:-

MOV Ax, [BX]

$$DS : BX \Leftrightarrow 1000H : 2000H$$

$$10H * DS = 10000$$

$$[BX] = \underline{\frac{2000}{12000H}} \rightarrow EA$$

### (iii) Register relative :-

MOV Ax, 5000H [BX]

$$DS : [5000 + BX]$$

$$(10H * DS) \Rightarrow 10000$$

$$\text{offset} \Rightarrow 5000$$

$$[BX] \Rightarrow \underline{\frac{2000}{17000H}} \rightarrow EA$$

(iv) Based indexed :-

MOV AX, [BX][SI]

(20)

$$DS : [BX] + [SI] = 1000H : 2000H + 3000H$$

$$\begin{array}{lcl} 10H * DS & \Rightarrow & 10000 \\ [BX] & \Rightarrow & 2000 \\ [SI] & \Rightarrow & 3000 \\ \hline & & 15000H \rightarrow EA \end{array}$$

(v) Relative based indexed :-

MOV AX, 5000 [BX][SI]

$$DS : [BX + SI + 5000]$$

$$\begin{array}{lcl} 10H * DS & \Rightarrow & 10000 \\ [BX] & \Rightarrow & 2000 \\ [SI] & \Rightarrow & 3000 \\ \text{offset} & \Rightarrow & 5000 \\ \hline & & 1A000 \rightarrow GA // \end{array}$$

## 7) MACHINE LANGUAGE INSTRUCTION FORMATS:-

- \* A machine language format has one (8) more no. of fields.
- \* The first field is called as Operation Code (Op) Op-Code field, which indicates type of operation to be performed by CPU.
- There are 6 general instruction formats in 8086.
- The length of instruction format may vary from 1 byte to 6 byte.

### 1.) One-byte instruction:-

This format is only 1-byte<sup>(8-bits)</sup> and may have the implied data (8) Register operands.

The least significant (3-bits) of Op-Code are used for specifying the register operand.

All the 8-bits from an opcode and the operands are implied.



one byte instructions - implicit operands

### 2) One byte instruction - Register mode:-



- ### 2) Register to Register:- This is 2-byte long.
- \* The 1<sup>st</sup> byte specifies the operation code and width of operand specified by 'W' bit.
  - \* The 2<sup>nd</sup> byte specifies the code shows the Register operands and Register/memory R/M field.



3.) Register to / from Memory with no Displacement.

This format is also 2-byte long and similar to the Register to Register format except for the MOD field.



The MOD field shows the Mode of addressing.

4.) Register to / from Memory with Displacement:

This type of instruction format contains 1 (or) 2 additional bytes for displacement along with 2-byte the format of register to / from memory without displacement.



(if 16-bit displacement is used).

Additional 1/2 bytes.

### 5) Immediate Operand to Register:-

(29)

In this first byte as well as the 6-bits from the 2<sup>nd</sup> byte which are used for REG field in case to register to register format are used for opcode.



### 6) Immediate Operand to memory with 16-bit Displacement:-

- \* This type of instruction requires 5 to 6 Bytes for coding.
- \* The first 2-bytes contains information regarding OPCODE, MOD, and R/M fields
- \* The remaining 4 bytes contains 2-byte of displacement and 2-byte of data



The OPCODEs have the single bit indicators:-

W-Bit :- Indicates whether the instruction is to operate over an 8-bit (8) 16-bit data/operands

If W=0, the operand is 8-bit indicates byte transfer

If W=1, the operand is 16-bit indicates 'Word' transfer

D-bit:- This is valid for all of Double Operand instructions. (30)

one of the operands must be register specified by the REG field.

If  $D=0$  " indicates from Register (Source operand)  
 $D=1$  " to Register (Destination operand).

S-Bit:- This bit is sign extension bit. The S-bit is along with W-bit to show the type of the operation.

8-bit operation with immediate operand is indicated by  
 $S=0 ; W=0$

16-bit operation with 16-bit immediate operand is indicated  $S=0 ; W=1$

16-bit " with sign extended immediate data is  $S=1 ; W=1$

$S,W = 01$  " 16-bit immediate data from operand".

$= 11$  " An immediate data type is sign extended to from 16-bit operand.

V-bit :- Used in cases of Shift and rotate instructions

$V=0$  indicates COUNT = 1  
" " in 'CL' register.

$V=1$  " "

Used by REP instruction to control the loop

Z-bit :- Used by REP instruction to control the loop  
Z=1 instruction with REP prefix is executed until zero flag  
matches the Z-bit.

| Code for MOD Field | Name of the Mode                 |
|--------------------|----------------------------------|
| 00                 | Memory Mode with no displacement |
| 01                 | " " " 8-bit signed "             |
| 10                 | " " " 16-bit unsigned "          |
| 11                 | Registered Mode                  |

# Register Codes

31

| 16-bit Address code | (W=1)<br>width | 8-bit Reg code | (W=0)<br>Reg code |
|---------------------|----------------|----------------|-------------------|
| 000                 | AX             | 000            | AL                |
| 001                 | CX             | 001            | CL                |
| 010                 | DX             | 010            | DL                |
| 011                 | BX             | 011            | BL                |
| 100                 | SP             | 100            | AH                |
| 101                 | BP             | 101            | CH                |
| 110                 | SI             | 110            | DH                |
| 111                 | DI             | 111            | BH                |

| Segment (16-bit) Register Code | Segment Register |
|--------------------------------|------------------|
| 00                             | ES               |
| 01                             | CS               |
| 10                             | SS               |
| 11                             | DS               |

| R/M MOD | 00                         | 01                  | 10                     | W=1 | 11 | W=0                                 |
|---------|----------------------------|---------------------|------------------------|-----|----|-------------------------------------|
| 000     | $[BX] + [SI]$              | $[BX] + [SI] + d_8$ | $[BX] + [SI] + d_{16}$ | AX  | AL |                                     |
| 001     | $[BX] + [DI]$              | $[BX] + [DI] + d_8$ | $[BX] + [SI] + d_{16}$ | CX  | CL | $d \rightarrow \text{displacement}$ |
| 010     | $[BP] + [DI]$              | $[BP] + [SI] + d_8$ | $[BP] + [SI] + d_{16}$ | DX  | DL |                                     |
| 011     | $[BP] + [DI]$              | $[BP] + [DI] + d_8$ | $[BP] = [SI] + d_{16}$ | BX  | BL |                                     |
| 100     | $[SI]$                     | $[SI] + d_8$        | $[SI] + d_{16}$        | SP  | AH |                                     |
| 101     | $[DI]$                     | $[DI] + d_8$        | $[DI] + d_{16}$        | BP  | CH |                                     |
| 110     | $d_{16}$<br>direct Address | $[BP] + d_8$        | $[BP] + d_{16}$        | SI  | DH |                                     |
| 111     | $[BX]$                     | $[BX] + d_8$        | $[BX] + d_{16}$        | DI  | BH |                                     |

(32)

To find out the MOD and R/M fields of particular instruction, one should first decide the addressing mode of the instruction. The A.M depends upon the opelands and suggests how the effective address may be computed for locating the operand, if it lies in memory.

Note:- usually all the addressing modes have DS as default data segment. However the A.M using BP and SP have SS as the default segment register.

e.g.- ① MOV AL, 20H



It is Immediate A.M

from above instruction the instruction code is

|      |   |     |      |
|------|---|-----|------|
| 1011 | W | REG | data |
|------|---|-----|------|

As the data given is not 16-bit, W=0 and the data is being transferred to AL and its code is "000".

∴ Code is 1011 0 000 20H

Now binary code is 1011 0000 20H is

Machine code = B0, 20H //.