**Chapter 4** 

# 8051 Family Microcontrollers Instruction Set

Lesson 2

# **Addressing Modes**

# **Execution of Instruction**



An addressing mode specifies, how will an operand(s) is obtained from the fetched bits before performing the operation(s) using it. Microcontrollers-... 2nd Ed. Raj Kamal 2011 4

# Immediate Addressing Mode



Immediate addressing mode specifies that an operand is same as the fetched bits. Operand is immediate succeeding bits after the opcode.

| Example-Imme             | diate Addressin                    | g clock          |
|--------------------------|------------------------------------|------------------|
| For adding<br>08H into A | Fetch bits<br>for getting the      | <u>cycle (s)</u> |
| register                 | operand for                        | Time             |
|                          | addition                           | <b>STEP 2</b>    |
| ADD A, #08H              | Format- AD                         | DA, #data        |
| Sign # specifies         | that 08H is                        | Codes 24H, 08H   |
| the immediate s          | succeeding                         | in Memory-       |
| byte is the open         | rand                               |                  |
| 2011 N                   | Aicrocontrollers 2nd Ed. Raj Kamal | 7                |

# **Register Addressing Mode**

# Register Addressing $\underline{cl}$ STEP 2 Fetch bits $\underline{cy}$ coexisting with the opcode



Addressing mode specifies that fetch bits (coexisting with opcode of 5 bits) specify a register, operand is at that register.



MOVA, R1

**3 lower bits specifies that register is R1 for the operand during this operation**  Code bits in Memory-1110 1001

2011



#### **Direct Addressing** clock cycle (s) **STEP 2** $\longrightarrow$ Fetch byte(s) after the opcode

**Addressing mode specifies** that fetch byte(s) (coexisting after the opcode of 8 bits) specify an address, the operand is at that address.

ime

# **Example-Direct Addressing**

STEP 2 For transferring addressed byte into A register

Fetch 8 bits
 for getting the
 operand
 address



MOV A, 90H . 8 bits directly specify the address for the operand



**Example-Direct Addressing** 

STEPS 2-3 → For transferring addressed byte into another address MOV 80H, 90H

→ Fetch 16 bits for getting the operand addresses

............



Code bits in Memory-85H 80H 90H

# 16 bits directly specify the addresses for two operands

8051 family three type of instructions

using direct addressing mode

- *direct* for SFR or
- *direct* for Internal RAM in between 00H to 7FH
- *direct* for a bit at bit addressable SFR or RAM

### **Direct Addressing Mode**

**IO and internal devices Control and Status** 80H-FFH Registers SP and DPTR, IP, IE,... **Internal RAM 00H-00H-7FH 7**FH

# Indirect (Index) Addressing Mode

# Internal Memory Indirect Addressing Mode **Internal Program** Memory (4kB) **Internal Data** Memory •128 B 8051 •256 B 8052

Always Indirect Addressing mode Internal/External **Program Memory** (max. 64 kB)**External Data** Memory and Ports  $(\max 64 \text{ kB})$ 





Addressing mode specifies that fetch bits (coexisting after the opcode bits) specify a register (or address), the operand address is pointed by that

### **Example-Indirect Addressing**

STEP 2<br/>ForForforfortransferringforfrom a pointed<br/>address byte<br/>into A registeropA registeracMOV A, @R

Fetch 3 bits for getting the operand address

3 bits specifies a register, byte at that points indirectly specify the address for the Operand Microcontrollers-... 2nd Ed. Raj Kamal clock cycle (s) Time

Code bits in Memory-11100 111 Sign @ means R1 is a pointer

Example-Indirect Addressing STEPS 2-3 For transferring addressed code byte into A clock cycle (s)

MOVC A, @A + DPTR 1 bit (bit4) indirectly specify DPTR,16-bits at that adds in 8-bits at A register and then 16-bits point to code at that address 2011 Microcontrollers-...2nd Ed. Raj Kamal Pearson Education

Code bits in Memory-10010011 Three types of instructions using indirect addressing mode

- for internal RAM 00H-FFH using R0 or R1 at a bank
- for External RAM address by R0 or R1 at a register bank at a bank
- for code memory address using PC or DPTR along with A register

# Indirect Addressing

1. Only indirect addressing in 8051 instruction for a byte in external data memory

2. Only indirect addressing in 8051 instruction for a code in internal/external program memory
3. Only indirect addressing in 8052 instruction Internal RAM between 80H-FFH

#### No Indirect Addressing

# For 8051 instruction for an SFR

# Summary

#### We learnt

8051 family addressing modes

- immediate
- register
- direct for SFR
- direct for internal RAM in between 00H to 7FH

#### We learnt

#### 8051 family addressing modes

- Indirect internal RAM using R0 or R1 at a bank
- Indirect External RAM address by R0 or R1 at a register bank at a bank
- Indirect code memory address using PC or DPTR along with A register