

# Instruction Sets: Addressing Modes

way / Technique to access the operand.



SANTOSH KUMAR VERMA  
Mentor  
GeeksforGeeks

# Addressing Modes





Figure 13.1 Addressing Modes



Table 13.1  
Basic Addressing Modes

5 bit  $\Rightarrow$  Unsigned  $\Rightarrow 0 - 2^5$   
 $00000$   
 $\vdots$   
 $1111$

Signed  $\Rightarrow -2^4, 0, +2^4 - 1$

(6)



| Mode              | Algorithm         | Principal Advantage | Principal Disadvantage     |
|-------------------|-------------------|---------------------|----------------------------|
| Immediate         | Operand = A       | No memory reference | Limited operand magnitude  |
| Direct            | EA = A            | Simple              | Limited address space      |
| Indirect          | EA = (A) @        | Large address space | Multiple memory references |
| Register          | EA = R            | No memory reference | Limited address space      |
| Register indirect | EA = (R)          | Large address space | Extra memory reference     |
| Displacement      | EA = A + (R)      | Flexibility         | Complexity                 |
| Stack             | EA = top of stack | No memory reference | Limited applicability      |

memory  
is limited  
in  
size.

# Immediate Addressing

- Simplest form of addressing
- Operand = A
- This mode can be used to define and use constants or set initial values of variables
  - Typically the number will be stored in two's complement form
  - The leftmost bit of the operand field is used as a sign bit
- Advantage:
  - No memory reference other than the instruction fetch is required to obtain the operand, thus saving one memory or cache cycle in the instruction cycle
- Disadvantage:
  - The size of the number is restricted to the size of the address field, which, in most instruction sets, is small compared with the word length

ADD R1, #123



$$\begin{aligned}
 R_1 &= R_1 + 123 \\
 &= 100 + 123
 \end{aligned}$$

$$R_1 = 223$$

# Direct Addressing



+

# Indirect Addressing

- Reference to the address of a word in memory which contains a full-length address of the operand
- $EA = (A) \rightarrow$  value at Address A
  - Parentheses are to be interpreted as meaning contents of
- Advantage:
  - For a word length of  $N$  an address space of  $2^N$  is now available
- Disadvantage:
  - Instruction execution requires two memory references to fetch the operand
    - One to get its address and a second to get its value
- A rarely used variant of indirect addressing is multilevel or cascaded indirect addressing
  - $EA = (\dots(A)\dots)$
  - Disadvantage is that three or more memory references could be required to fetch an operand



$R_1 + \$50H$

# Register Addressing



Address field  
refers to a  
register rather  
than a main  
memory address

$$EA = R$$

## Advantages:

- Only a small address field is needed in the instruction
- No time-consuming memory references are required

## Disadvantage:

- The address space is very limited

$MOV R_1, R_2$

$R_1 \leftarrow R_2$

+

# Register Indirect Addressing

- Analogous to indirect addressing
  - The only difference is whether the address field refers to a memory location or a register
- $EA = \underline{(R)} @$
- Address space limitation of the address field is overcome by having that field refer to a word-length location containing an address
- Uses one less memory reference than indirect addressing

*memory*

$MOV R_3, @R_2$   
 OR  
 $MOV R_3, (R_2) \quad 123H$   
 $R_3 \leftarrow (R_2)$

$R_2$  123H       $R_3$  #100H



# Displacement Addressing

- Combines the capabilities of direct addressing and register indirect addressing
- $EA = A + (R)$   
A
- Requires that the instruction have two address fields, at least one of which is explicit
  - The value contained in one address field (value = A) is used directly
  - The other address field refers to a register whose contents are added to A to produce the effective address
- Most common uses:
  - Relative addressing
  - Base-register addressing
  - Indexing

# Relative Addressing

The implicitly referenced register is the program counter (PC)

- The next instruction address is added to the address field to produce the EA
- Typically the address field is treated as a two's complement number for this operation
- Thus the effective address is a displacement relative to the address of the instruction

Exploits the concept of locality

Saves address bits in the instruction if most memory references are relatively near to the instruction being executed

+

# Base-Register Addressing



- The referenced register contains a main memory address and the address field contains a displacement from that address
- The register reference may be explicit or implicit
- Exploits the locality of memory references
- Convenient means of implementing segmentation
- In some implementations a single segment base register is employed and is used implicitly
- In others the programmer may choose a register to hold the base address of a segment and the instruction must reference it explicitly



# Indexing

- The address field references a main memory address and the referenced register contains a positive displacement from that address
  - The method of calculating the EA is the same as for base-register addressing
  - An important use is to provide an efficient mechanism for performing iterative operations
  - Autoindexing
    - Automatically increment or decrement the index register after each reference to it
    - $EA = A + \underline{(R)}$
    - $(R) \leftarrow (R) + 1$
  - Postindexing
    - Indexing is performed after the indirection
    - $EA = (A) + (R)$
  - Preindexing
    - Indexing is performed before the indirection
    - $EA = (A + (R))$
- postincrement kind  
K++*
- pre increment kind  
++K*



+

# Stack Addressing

- A stack is a linear array of locations
  - Sometimes referred to as a *pushdown list* or *last-in-first-out queue*
- A stack is a reserved block of locations
  - Items are appended to the top of the stack so that the block is partially filled
    - SP
- Associated with the stack is a pointer whose value is the address of the top of the stack
  - The stack pointer is maintained in a register
  - Thus references to stack locations in memory are in fact register indirect addresses
- Is a form of implied addressing
- The machine instructions need not include a memory reference but implicitly operate on the top of the stack



*pUSH(#1234H)*  
*pop —*





Figure 13.2 x86 Addressing Mode Calculation

Table 13.2  
x86 Addressing Modes

Segment Register  
16 bit

| Mode                                    | Algorithm                            |
|-----------------------------------------|--------------------------------------|
| Immediate                               | <u>Operand</u> = A                   |
| Register Operand                        | <u>LA</u> = R                        |
| Displacement                            | <u>LA</u> = (SR) + A                 |
| Base                                    | <u>LA</u> = (SR) + (B)               |
| Base with Displacement                  | <u>LA</u> = (SR) + (B) + A           |
| Scaled Index with Displacement          | <u>LA</u> = (SR) + (I) ^ S + A       |
| Base with Index and Displacement        | <u>LA</u> = (SR) + (B) + (I) + A     |
| Base with Scaled Index and Displacement | <u>LA</u> = (SR) + (I) ^ S + (B) + A |
| Relative                                | <u>LA</u> = (PC) + A                 |

LA = linear address  
 (X) = contents of X  
 SR = segment register  
 PC = program counter  
 A = contents of an address field in the instruction  
 R = register  
 B = base register  
 I = index register  
 S = scaling factor

BA + SI + 2

STRB r0, [r1, #12]



(a) Offset

STRB r0, [r1, #12]!



(b) Preindex

STRB r0, [r1], #12



(c) Postindex

Figure 13.3 ARM Indexing Methods

# 8086 programmer's model

- Immediate AM
  - Direct/Memory AM
  - Register DM
  - Register indirect
  - Memory indirect
  - Base + Index
  - Relative Add.
- B+I+relative

GPR



Figure 6.1 The 8086 programmer's model.

-20 address lines  $\rightarrow (0 - 2^{20})$

- 1 MB memory capacity

- Memory space may be divided into 4 segments each of 64 kb.
- Segment register contains information on the starting address of segment in memory.

*Base add.  
of  
its respective  
segment*

CS – Code Segment Register

DS – Data Segment Register

ES – Extra Segment Register

SS – Stack Segment Register



Memory space of segment may overlap.

There may be more than one segment of a particular type.



## AX – Primary Acc. Unique in following way

- I/O operations pass through AX (or AL).
- Instructions using AX (or AL) take less time to execute.
- Many string instructions require one of the operands to be in AX(or AL)
- AX and AL used in multiply and divide instructions.

BX – GPR – also may be used as base register for memory address calculation.



CX – GPR – also may be used to hold count in multiiteration instructions. CX contains the loop count.

DX – GPR – also may be used in I/O. Instruction [DX stores the port address], multiply and divide instructions.



SI – Source Index – helps in indexed addressing

DI – Destination Index - helps in indexed addressing

BP – Base Pointer – used for indirect addressing and base relative addressing for stack operations.

IP – Instruction Pointer – contains offset address of next instruction to be executed. Serves as program counter.

## Operand addressing-

Segment Register – 16 bit

Memory Address – 20 bit

Segment register content are appended with 0000B to get starting address of segment in memory.

DS



xxxxH

DS $\times$ 10H + offset  
physical Add.



i.e Segment register content are

multiplied by 16(Decimal) or 10H to get starting address of segment in memory.

The starting add. of segment is added with offset to get effective memory address also called physical memory address. Offset is called logical address.

# Instruction Addressing

Starting address of code segment = (CS) X 10H

Offset address = (IP) i.e content of IP register

Effective address = (CS) X 10H + (IP)

## Operand Addressing

Addressing modes clearly specify the location of operand and how its location may be determined.

Following addressing modes are available-

- ✓ • Register Addressing Mode
- ✓ • Immediate Addressing Mode
- ✓ • Direct Addressing Mode
- ✓ • Register Indirect Addressing Mode
- ✓ • Base Plus Index Register Addressing Mode
- ✓ • Register Relative Addressing Mode
- ✓ • Base plus Index Register Relative Addressing Mode
- ✓ • String Addressing Mode.

Reg (AX,BX,CX,DX)  
Imm  
Direct  
Reg Indi



Figure 6.2 Instruction addressing.

## Register Addressing-

Both destination and source operand in registers.

MOV AL, AH      (AL)  $\leftarrow$  (AH)

MOV AX, DX      (AX)  $\leftarrow$  (DX)

AND AL BL      (AL)  $\leftarrow$  (AL) AND (BL)

MOV AL, BL  
MOV BL, CL  
MOV CH, BL

MOV CL, BX ??

8 bit  
register      16 bit

Valid  
with  
precision loss.

## Immediate Addressing

One of the operands is part of instruction as immediate data –

8/16 bit

C=5      Mov CX, 2346H      (CX)  $\leftarrow$  2346H  
*immediate data*

SUB AX , 7860H      (AX)  $\leftarrow$  (AX) - 7860H

MOV 1234H, AL  
5=C      Constant  
invalid

## Direct Memory Addressing

16 bit offset address is part of instruction as displacement field. It is stored as 16 bit unsigned or 8 bit sign extended number, following the instruction code.

Example

MOV [3725H], DX

*offset of memory*  
*square bracket*

(SS \* 10 + SP)

$\rightarrow ((DS) * 10H + 3725H) \leftarrow (DL)$

$((DS) * 10H + 3726H) \leftarrow (DH)$

Move the content of DL and DH registers to memory location calculated from DS register and displacement.

$\rightarrow OR AL, [3030H] \quad (DS * 10H + 3030H) OR AL$

OR the content of AL register with the content of memory location calculated with DS register and displacement and store the result in AL register.

$(AL) \leftarrow ((DS) * 10H + 3030H) OR (AL)$



Figure 6.3 Execution of direct memory addressed instruction `OR AL, (3030H)`.

In the figure

$$(AL) = 70H$$

$$(DS) = (3745H)$$

$$\text{Effective memory address} = 3745H * 10H + 3030H$$

$$= 37450H + 3030H$$

$$= 3A480H$$

## Register Indirect Addressing

Offset register is specified through pointer register(i.e BP or BX) or index register(SI or DI)

Mov AL, [BX]; offset is stored in BX

$(AL) \leftarrow ((DS) * 10H + (BX))$

XOR [DI], CL

$((DS) * 10H + (DI)) \leftarrow ((DS) * 10H + (DI)) \quad \underline{\text{XOR}} \underline{(CL)}$

Similarly MOV AL, [BX+4]

XOR [DI+6],CL

**Note:- memory to memory transfer is not allowed except in case of string.**

offset  
in  
memory



Figure 6.4 Execution of register indirect addressing mode instruction **XOR (DI), CL**.

## Register Indirect Addressing

MOV[DI], 30H → 8 bit  
; Offset in DI

✓ DSX10H + DI → for lower Byte  
✗ DSX10H + DI+1 → for higher Byte

Whether byte or word is to be transferred is not known

Assembler can't determine the size of data 30H

Modify to

MOV BYTE PTR [DI], 30H - or

MOV WORD PTR [DI], 30H

To find offset address of N1

MOV DI, OFFSET N1

MOV BYTE PTR[DI], 30H

N1 DB -

## Examples

### DIRECT

```
.DATA
```

N1 DB 5

N2 DB 7

N3 DB 8

N4 DB 0

```
.CODE
```

int c;

[ ]

```
MOV CL, N1
```

```
ADD CL, N2
```

```
ADD CL, N3
```

```
MOV N4, CL
```

*variable  
direct  
Add.  
value of N1*

### INDIRECT

```
.DATA
```

N1 DW 1234H

N2 DB 12H

```
.CODE
```

-----  
-----  
-----  
MOV BX, OFFSET N1

MOV [BX], 0333H

MOV BX, OFFSET N2

MOV [BX], 03H

Correct way to write is

MOV WORDPTR [BX], 0333H

OR

MOV BYTE PTR [BX], 03H

*Adresse of N1*

## Base Plus Index Register Addressing Mode

Main utility – for addressing an array of data.

Extension of register indirect addressing.

Base register (BX) and index register (SI or DI) used to indirectly address the memory location.

MOV [BX + DI], AL      -or

MOV [BX] [DI], AL

[BX + DI + Const  
Relative]

Offset address = (BX)+(DI)

BX - Base register    DI - Index Register

Copy the content of AL register to the memory location  
calculated by taking offset at = (BX)+(DI)

Starting address of data segment = (DS)x10H

Effective memory address = ((DS)x10H +(BX)+(DI))

((DS)x10H +(BX)+(DI)) < (AL)



Figure 6.5 Execution of base plus index register addressing mode instruction `MOV (BX + DI), AL`.

Base register may contain address to point to base of array i.e 0th location.

The value of DI may be changed to access different locations.



### Example – Array accessing

.DATA

ARRAY DB 75H, 3CH----

.CODE

-----  
-----  
MOV BX, OFFSET ARRAY  
MOV DI, 00H  
MOV AL, [BX+DI] (AL)  $\leftarrow$  75H

-----  
-----  
INC DI

**OFFSET** directive loads the offset address of a particular memory location.

**NOTE – MOV BX, ARRAY** will move two bytes 75 & 3CH of Array to BX

## Register Relative Addressing Mode

Similar to Base Plus Index Register Addressing Mode.

Offset is calculated by using one of the register- BX, BP, DI or SI and displacement specified as 8 bit or 16 bit number specified in the instruction.

MOV AX, [DI+06] / MOV AX, [DI + 06H] / MOV AX, 06[DI]

Effective memory address = (DS)\*10H+(DI)+06

(AL)  $\leftarrow$  ((DS)\*10H+(DI)+06)

(AH)  $\leftarrow$  ((DS)\*10H+(DI)+07)

These bytes may be part of array.

Base of array – (DS)\*10H+(DI)

By decreasing or increasing displacement we can access different elements of array.



Figure 6.6 Execution of register relative addressing mode instruction `MOV AX, (DI + 06)`.

## Addressing Array with Register Relative Addressing

### Example

.DATA

ARRAY DB 75, 3C, 9A ----

.CODE

-----

-----

-----

MOV DI, OFFSET ARRAY

MOV AL, [DI]; AL  $\leftarrow$  ARRAY[0]

MOV AL, [DI+1]; [AL]  $\leftarrow$  ARRAY[1]

MOV DI, 03

MOV AL, ARRAY[DI]

;Offset = Address of Array + [DI]

MOV ARRAY[DI], AL

## Base Plus Index Register Relative Addressing Mode- (Based indexed Addressing mode)

Combination of base + index register addressing and register relative addressing.

Suited for accessing the element of two dimensional array.

For calculating offset-

Base Register – BX

Index Register – SI or DI

And displacement specified in the instruction is used.

Base Register

BX → Starting memory location of array.

SI or DI → Starting of row.

Displacement → particular element in the row.

MOV [BX + DI + 2], CL

Or MOV [BX][DI+2], CL

MOV 2[BX][DI], CL

((DS)\*10H+(BX)+(DI)+2) ← (CL)





Which of the following addressing modes are suitable for program relocation at run time?

(1234H)

- A. Absolute addressing
- B. Based addressing
- C. Relative addressing
- D. Indirect addressing

Direct Addressing / Direct Memory Add.





Which of the following is not a form of memory?

- A. Instruction Cache
- B. Instruction Register
- C. Instruction Opcode
- D. Translation look aside buffer (TLB)

part of instruction format  
not a memory  
↳ paging



## In absolute addressing mode

- A. the operand is inside the instruction
- B. the address of the operand is inside the instruction
- C. the register containing the address of the operand is specified inside the instruction
- D. the location of the operand is implicit

immediate

X

Register Addressing





The most appropriate matching for the following pairs

X: Indirect addressing

Y: Immediate addressing

Z: Auto decrement addressing is

1: Loops

2: Pointers

3. Constants

CX

- A. X-3, Y-2, Z-1
- B. X-1, Y-3, Z-2
- C. X-2, Y-3, Z-1
- D. X-3, Y-1, Z-2

Consider the following program segment. Here R1, R2 and R3 are the general purpose registers

| Instruction        | Operation                      | Instruction size (no.of words) | Memory Ref. |
|--------------------|--------------------------------|--------------------------------|-------------|
| MOV R1, (3000)     | <u>R1</u> $\leftarrow$ m[3000] | 2                              | 1           |
| LOOP: MOV R2, (R3) | R2 $\leftarrow$ M[R3]          | 1                              |             |
| ADD R2, R1         | R2 $\leftarrow$ R1 + R2        | 1                              |             |
| MOV (R3), R2       | M[R3] $\leftarrow$ R2          | 1                              |             |
| INC R3             | R3 $\leftarrow$ R3 + 1         | 1                              |             |
| DEC R1             | R1 $\leftarrow$ R1 - 1         | 1                              |             |
| BNZ R1, LOOP       | Branch on not zero             | 2                              |             |
| HALT               | Stop                           | 1                              |             |

10 times  $\rightarrow 10 \times 2$

$20 + 1 = 21$

Assume that the content of memory location 3000 is 10 and the content of the register R3 is 2000. The content of each of the memory locations from 2000 to 2010 is 100. The program is loaded from the memory location 1000. All the numbers are in decimal. Assume that the memory is word addressable. The number of memory references for accessing the data in executing the program completely is:

- A. 10
- B. 11
- C. 20
- D. 21 ✓

+

Consider the C struct defines below:

```
struct data {  
    0 int marks [100] ;  
    1 char grade;  
    2 int cnumber;  
};  
struct data student;
```

The base address of **student** is available in register R1. The field student.grade can be accessed efficiently using

- A. Post-increment addressing mode.  $(R1) + \overbrace{\hspace{1cm}}$  → marks
- B. Pre-decrement addressing mode,  $-(R1)$  → garbage
- C. Register direct addressing mode,  $R1 \rightarrow \overbrace{\hspace{1cm}}$  marks
- D. Index addressing mode,  $X(R1)$ , where X is an offset represented in 2's complement 16-bit representation.



Consider a hypothetical processor with a instruction of type LW R1, 20(R2), which during execution reads a 32-bit word from memory and stores it in a 32-bit register R1. The effective address of the memory location is obtained by the addition of a constant 20 and the contents of register R2. Which of the following best reflects the addressing mode implemented by this instruction for the operand in memory?

- A. Immediate Addressing
- B. Base Indexed Addressing
- C. Register Indirect Scaled Addressing
- D. Register Addressing

Option C is  
correct

LW R1, R2 — Register

Load word

$(R_2)$  }  
 $[R_2]$  } Register indirect

+ Constant  
Absolute / Relative or  
scaled



Consider the following program segment for a hypothetical CPU having three user registers R1, R2 and R3.

Instruction; Operation ; Instruction Size (in words)

✓ **MOV R1, 5000 ; R1 ← Memory [5000]** 2  
**MOV R2, (R1) ; R2 ← Memory [(R1)]** 1  
**ADD R2, R3 ; R2 ← R2 + R3**, 1  
**MOV 6000, R2 ; Memory [6000] ← R2** 2  
**HALT ; Machine halts** 1



Consider that the memory is byte addressable with size 32 bits, and the program has been loaded starting from memory location 1000 (decimal). If an interrupt occurs while the CPU has been halted after executing the HALT instruction, the return address (in decimal) saved in the stack will be

- A. 1024
- B. 1020
- ✓ C. 1028
- D. 1007

The addressing mode / s, which uses the PC instead of a general-purpose register is:

- A. Indexed with offset
- B. Relative
- C. Direct
- D. Both Indexed with offset and direct



# Summary

## Chapter 13

- Addressing modes
  - Immediate addressing
  - Direct addressing
  - Indirect addressing
  - Register addressing
  - Register indirect addressing
  - Displacement addressing
  - Stack addressing
- Assembly language

## Instruction Sets: Addressing Modes and Formats

- x86 addressing modes
- ARM addressing modes
- Instruction formats
  - Instruction length
  - Allocation of bits
  - Variable-length instructions
- X86 instruction formats
- ARM instruction formats