

# Addressing Mode

## ① Immediate Addressing

Instruction



→ No memory Reference

$$\text{operand} = A$$

A ; Content of an address field in instruction

R ; Content of an address field in instruction that refers register

↪ Limitation of operand magnitude

## ② Direct Addressing

Instruction



$$EA = A \rightarrow \text{Simple address in memory}$$

$\downarrow$   
effective  
address

↪ Requires min. one memory reference

↪ provides limited address space

## ③ Indirect Addressing

Instruction

Memory



$$EA = (A)$$

In this address field refers to another address containing the operand

→ Gives advantage of large address space

↪ Multiple memory reference required

#### ④ Register Addressing



→ Only small address field needed in instruction

→ no time-consuming memory references

## ⑤ Register Indirect Addressing



~ analogous to  
indirect addressing

$$EA = (R)$$

→ Large address Space

Register gives memory reference economy compared to  
of Register addressing

## ⑥ Displacement Addressing



Very powerful mode  
of addressing

$$EA = A + (R)$$

~ Combines direct addressing &

## Registers

↳ Combines direct addressing & register indirect addressing

→ highly flexible mode of addressing

↳ high compatibility

most commonly used for

- Relative addressing
- Base register addressing
- Indexing

## ⑦ Stack Addressing

Instruction



Implicit

$EA = \text{Top of Stack}$



Top of Stack

(Stack pointer is maintained  
using register)

These refer to stack location  
is actually register indirect  
addressing

→ No memory ref required

↳ Limited applicability

# Processor Organization

Steps that processor must do :-

- ① Fetch Instruction ; The processor reads the instruction from the memory
  - ② Interpret Instruction ; Instruction is decoded to determine what action is required
  - ③ Fetch data ; The execution of instruction may require reading data from memory or I/O module
  - ④ Process data ; The execution of instruction may require performing some arithmetic or logical operation on data
  - ⑤ Write data ; The results of a execution may require writing data onto memory or I/O module
- To do these functions the processor needs to store some data temporarily in order to remember the location of last instruction, etc



## Simplified diag. of CPU

Control Data Address

Bus Bus

Bws Bw

Bw

# System Bee

omp

# Internal Structure of CPU not

# Register Organization



# General purpose Registers

|                | D15 | D8 D7 | D0 |
|----------------|-----|-------|----|
| A <sup>x</sup> | AH  | AL    |    |
| B <sup>x</sup> | BH  | BL    |    |
| C <sup>x</sup> | CH  | CL    |    |
| D <sup>x</sup> | DH  | DL    |    |

## General Purpose Registers

A<sup>x</sup> ; Accumulator ; 16-bit Register divided into two parts High & Low

AH (8-bit), AL (8-bit)

Generally used for arithmetic & logical instruction

ADD A<sup>x</sup>, A<sup>x</sup> (A<sup>x</sup> = A<sup>x</sup> + A<sup>x</sup>)

B<sup>x</sup> ; Base Registers ; 16-bit register, also divided into BH, BL

Used to store offset values MOU BL, 500H (BL = 500H)

C<sup>x</sup> ; Counter Register ;

Used in looping & rotation

MOU CX, 0009  
LOOP

D<sup>x</sup> ; Data Register ;

Used in multiplication, input/output port addressing

MUL BX (DX, AX = AX \* BX)

## Segment Register

It is a 20-bit wide physical address to access 1MB memory location.

As the microprocessor's register has only 16-bit registers, thus the memory is segmented



- ① **Data Segment (DS) :** Used to point to base address of data segment
- ② **Code Segment :** used to point to base address of code segment
- ③ **Stack Segment :** Stores the base address of stack memory segment
- ④ **Extra Segment :** Stores the base address of Extra Memory segment

## Pointer & Index Registers

These are 16-bit register, each of them is associated with with each segment register, in order to generate 20 bit physical address



① Stack pointer ; holds the address of Stack Top (Uppermost Stack location)

There is no direct access to the register, modifications are done depending contents of stack

② Base pointer ; primarily used in accessing parameters passed by the stack

③ Source Index ; Used as pointer addressing data as a source in some string related operation

④ Destination Index ; Used as pointer addressing data as a destination in some string related operation

⑤ Instruction pointer ; Gives the offset address of next instruction to be fetched from the code segment

When reset, it fetches the first instruction to

be performed.

8086 has 20bit memory which cannot be accessed via 16 bit segment Registers alone.

In order to access memory, 16-bit address is offset with respect to segment

So, physical address + offset

Suppose data segment holds the base address as 1000h & the data you need is present in 0020H memory (location offset) of data segment, the calculations are

- Left shift 16-bit address present in segment by 4-bits

0001 0000 0000 0000 (0000)

- Add 16-bit offset address to shifted base address

$$\begin{array}{r} 0001\ 0000\ 0000\ 0000\ 0000 \\ + \quad 0000\ 0000\ 0010\ 0000 \\ \hline \end{array}$$

$$0001\ 0000\ 0000\ 0010\ 0000$$

So the actual address turns out to be 10020h

## Flags in 8086

Flags are special purpose Registers which depending upon value of result after Arithmetic or logical operation the flag bit becomes either (0) or (1)



- ① Sign Flag (S)
- ② Zero flag (Z)
- ③ Auxiliary Carry flag (AC)
- ④ Parity flag (P)
- ⑤ Carry flag (CY)
- ⑥ Overflow flag (O)

- ① Directional flag (D)
- ② Interrupt flag (I)
- ③ Trap flag (T)

16-Bit flag Register



{ Empty Spot ; Undefined }

6 Status flag

3 Control flag

Status flag

① Sign flag ; 0) MSB is 1 then number is -ve (1) [Set]  
as four +ve, MSB 0 (0) [Reset]

② Zero flag ; After any arithmetical or logical operation  
if result  $\Rightarrow 0 \text{ (00)H}$   
then, zero flag [Set] (1)

③ Auxiliary Carry flag ; Used in BCD number System

after arith/logical operation D(3) generates any carry  
it passes onto D(4) then the flag is [Set]

only flag not accessible by programmer

④ Parity flag ; If the result is even parity  
i.e.

even number of 1's, then the  
flag is [Set]

⑤ Carry flag ; Parity is generated when performing n-bit  
operation, the result is more than n bits  
if so then the flag is [Set]  
also called borrow flag

⑥ Overflow flag ; Flag is set when, result of signed  
operation is too large to  
fit in available no. of bits

Control flags

① Directional flags ; used in string Instructions

o If Set=1 ; access memory from higher memory  
location towards lower memory  
location

vice versa

② Interrupt flag ; This flag is for interrupt

o If Set=1 ; processor will recognise interrupt

request from peripherals  
~vice versa

③ Trap flag : Used for On-chip debugging

• If Set = 1 ; puts processor into single step mode for debugging

Ø

generate automatic internal interrupt after each instruction

~vice versa.

# 8086 Instruction Set

- ① Data transfer instruction
- ② Arithmetic instructions
- ③ Bit manipulation instruction
- ④ String instruction
- ⑤ Program execution transfer instruction
- ⑥ Processor Control Instruction
- ⑦ Iteration Control Instruction

## Data Transfer Instruction

Used to transfer data from source operand to destination operand

; MOV, POP, PUSHL, PUSHF, POPA (for word)

; IN, OUT (Instruction for Input/output port transfer)

; LEA, LDS, LES (Ins. for address transfer)

; LAHF, SAHF, PUSHF, POPF (Ins. for flag transfer)

## Arithmetic Instructions

ADD SUB MUL DIV

Used to perform arithmetic operations like addition, subtraction, multiplication, division

; ADD, ADC, INC, AAA, DAC (Addition operation)

; SUB, SBB, DEC, NPG, AAS (Subtraction operations)

; MUL, IMUL, AAM (Multiplication operations)

; DIV, IDIV, AAD (Division operations)

## Bit Manipulation Instructions

Used to perform operation where data bits are involved

; NOT, AND, OR, XOR, TEST (for logical operations)

; SHL, SHR, SAL, SAR (for shift operations)

; ROL, ROR, RCR, RCL (for rotate operations)

## String Instruction

Basically all operations involving strings

; REP, MOVS, COMS, INS, OUTS, SCAS, LODS

## Program Execution & Transfer Instruction

(or Branch & Loop Instruction)

Used to transfer/Branch instruction during execution

o transfer the instruction during execution without condition

; CALL, RET, JMP

o transfer the instruction during execution with condition

; JAE/JBE, JC/JNC, JE/JZ, JGE/JGNE,  
etc.

## Processor Control Instruction

Used to control processor by setting/resetting carry flag values

; STC, STD, STI , CLC, CLD, CLI  


## Iteration Control flag

Used to control the number of times the instruction is executed

; LOOP , LOOPE/LOOPZ , JCXZ  


## Interrupt Instructions

These are used to call Interrupt during program execution

∴ INT, INTO , RET

## Instruction Cycle

Instruction cycle consists of

- ① Fetch ; Reading the instructions from memory onto processor
- ② Execute ; Interpret the opcode & perform the indicated operation
- ③ Interrupt ; If Interrupt is enabled and an interrupt occurs then save the current process state & service the interrupt

Execution of an instruction may involve one or more operands in memory

Each of which required memory access

Thus Indirect cycle / Addressing is required



Indirect is just another step in which required operands are fetched through indirect addressing

~~Fetch cycle~~

- Instruction is read from memory
- The program counter contains the next instruction to be fetched
- Then this address is moved to MAR and placed on address bus
- The control unit requests a memory read, and the result is placed on data bus & copied into MBR (Memory Buffer Register) then moved to IR (Instruction register)
- Meanwhile the PC (program counter) is incremented by 1

Then next fetch cycle is prepared  
(Control Unit)



- Once the fetch cycle is over CU examines the contents of the IR (Instruction Register) using indirect addressing if so then an indirect cycle is performed

~~Execute cycle~~

- The execute cycle takes many forms
- The forms depend on various machine instructions in the IR (Instruction Register)
- The cycle involves transferring data among registers, read or write from memory or I/O, and/or the invocation of ALU.



- The cycle involves transferring data among register, read or write from memory or I/O, and/or the invocation of ALU.



~~Interrupt Cycle~~

- Similar to fetch cycle. Interrupt cycle is simple & predictable in nature.
- The current content of PC (Program Counter) must be saved so that the processor can resume normal activity after the interrupt.
  - Then the content of PC are transferred to the MBR to be written into memory.
  - Special memory location reserved for this purpose is loaded into the MAR from the control unit.



# Instruction pipelining

Instruction processor can be divided into

- ① Instruction fetch
- ② Instruction execute

In pipelining, suppose first half of instruction (fetch) is done while the second half is being done during that time can be saved if during this time first half of another instruction can be done.



Due to Instruction prefetch, more buffer / registers are required.

As more data for storage is required

If instruction fetch & instruction decode required same time the execution time would be halved but that is not the case.

As, Execution requires more time than fetch

If there are more stages the process can be speed up

## ① 6 Stage Instruction pipelining

- 1) Instruction fetch (IF): Read the next expected instruction into buffer
- 2) Decode Instruction (DE): Determine opcode & operand specifier

- 3) Calculate Operands (CO) : Calculate effective address of each source  
 4) Fetch Operands (FO) : fetch each operand from memory  
 5) Execute Instruction (EI) : Perform indicated operation  
 6) Write Operation (WO) : Store the result in memory

|                | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 |
|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Instruction 1  | FI | DI | CO | FO | EI | WO |    |    |    |    |    |    |    |    |
| Instruction 2  |    | FI | DI | CO | FO | EI | WO |    |    |    |    |    |    |    |
| Instruction 3  |    |    | FI | DI | CO | FO | EI | WO |    |    |    |    |    |    |
| Instruction 4  |    |    |    | FI | DI | CO | FO | EI | WO |    |    |    |    |    |
| Instruction 5  |    |    |    |    | FI | DI | CO | FO | EI | WO |    |    |    |    |
| Instruction 6  |    |    |    |    |    | FI | DI | CO | FO | EI | WO |    |    |    |
| Instruction 7  |    |    |    |    |    |    | FI | DI | CO | FO | EI | WO |    |    |
| Instruction 8  |    |    |    |    |    |    |    | FI | DI | CO | FO | EI | WO |    |
| Instruction 9  |    |    |    |    |    |    |    |    | FI | DI | CO | FO | EI | WO |
| Instruction 10 |    |    |    |    |    |    |    |    |    | FI | DI | CO | FO | EI |

Time →

## ① 5 Stage Instruction pipelining

- 1) Instruction fetch (IF)
- 2) Instruction decode (ID)
- 3) Instruction Execute (IE)
- 4) Memory Access (MA)
- 5) Write back (WB)