

# 8051 Addressing Mode and Instruction Set



1

# **8051 Instruction Set**

- Addressing Modes
  - Register addressing
  - Direct addressing
  - Indirect addressing
  - Immediate constant addressing
  - Relative addressing
  - Absolute addressing
  - Long addressing
  - Indexed addressing
- Instruction Types
  - Arithmetic operations
  - Logical operations
  - Data transfer instructions
  - Boolean variable instructions
  - Program branching instructions



#### Introduction

- A computer instruction is made up of an operation code (opcode) followed by either zero, one or two bytes of operands
- The op-code identifies the type of operation to be performed while the operands identify the source and destination of the data
- The operand can be:
  - The data value itself
  - > A CPU register
  - > A memory location
  - > An I/O port
- If the instruction is associated with more than one operand, the format is always:

Instruction Destination, Source



# **Memory Organization**



- The memory organization of C8051F020 is similar to that of a standard 8051
- Program and data memory share the same address space but are accessed via different instruction types



#### **Internal Data Memory**



|     | Byte<br>Address | Bit Address                       |                      |        |      |          |    |    |    |  |  |
|-----|-----------------|-----------------------------------|----------------------|--------|------|----------|----|----|----|--|--|
| [   | 7F              |                                   |                      |        |      |          |    |    |    |  |  |
| 1   |                 |                                   |                      |        |      |          |    |    |    |  |  |
|     |                 |                                   |                      |        |      |          |    |    |    |  |  |
| 1   |                 | General<br>Purpose                |                      |        |      |          |    |    |    |  |  |
| [   | 1               | RAM                               |                      |        |      |          |    |    |    |  |  |
| [   |                 |                                   |                      |        |      |          |    |    |    |  |  |
| [   |                 |                                   |                      |        |      |          |    |    |    |  |  |
|     | 30              |                                   |                      |        |      |          |    |    |    |  |  |
| 9 [ | 2F              | 7F                                | 7E                   | 7D     | 70   | 7B       | 7A | 79 | 78 |  |  |
| 4   | 2E              | 77                                | 76                   | 75     | 74   | 73       | 72 | 71 | 70 |  |  |
| ŧ١, | 2D              | 6F                                | 6E                   | 6D     | 60   | 6B       | 6A | 69 | 68 |  |  |
|     | 20              | 67                                | 66                   | 65     | 64   | 63       | 62 | 61 | 60 |  |  |
| 4   | 28              | 5F                                | 5E                   | 50     | 50   | 5B       | 5A | 59 | 58 |  |  |
| 1   | 2A              | 57                                | 56                   | 55     | 54   | 53       | 52 | 51 | 50 |  |  |
| 1   | 29              | 4F                                | 4E                   | 4D     | 40   | 4B       | 4A | 49 | 48 |  |  |
| ા   | 28              | 47                                | 46                   | 45     | 44   | 43       | 42 | 41 | 40 |  |  |
| ା   | 27              | 3F                                | 3E                   | 3D     | 30   | 3B       | ЗA | 39 | 38 |  |  |
| 1   | 26              | 37                                | 36                   | 35     | 34   | 33       | 32 | 31 | 30 |  |  |
| 1   | 25              | 2F                                | 2F 2E 2D 2C 2B 2A 29 |        |      |          |    |    | 28 |  |  |
| 1   | 24              | 27                                | 26                   | 25     | 24   | 23       | 22 | 21 | 20 |  |  |
| 1   | 23              | 1F                                | 1E                   | 1D     | 10   | 1B       | 1A | 19 | 18 |  |  |
| 1   | 22              | 17                                | 16                   | 15     | 14   | 13       | 12 | 11 | 10 |  |  |
|     | 21              | OF                                | 0E                   | OD     | 0C   | 0B       | 0A | 09 | 08 |  |  |
|     | 20              | 07                                | 06                   | 05     | 04   | 03       | 02 | 01 | 00 |  |  |
|     | 1F              |                                   |                      |        |      |          |    |    |    |  |  |
| ſ   | 18              |                                   |                      |        | Bar  | IK 3     |    |    |    |  |  |
| ſ   | 17              |                                   |                      |        | 1000 |          |    |    |    |  |  |
| 1   | 10              |                                   |                      |        | Bar  | ik 2     |    |    |    |  |  |
| ſ   | OF              |                                   |                      |        |      | 1992     |    |    |    |  |  |
|     | 08              |                                   |                      |        | Bar  | IK 1     |    |    |    |  |  |
| ľ   | 07              |                                   | Defe                 | JA D - |      | n ante e |    | ം  | 2  |  |  |
| ſ   | 00              | Default Register Bank for R0 – R7 |                      |        |      |          |    |    |    |  |  |



# **Special Function Registers**

|        |                                     | ADDRESS SPACE                          | F8 | SPIOCN                     | PCA0H       | PCA0CPH0 | PCA0CPH1 | PCA0CPH2 | PCA0CPH3     | PCA0CPH4     | WDTCN |
|--------|-------------------------------------|----------------------------------------|----|----------------------------|-------------|----------|----------|----------|--------------|--------------|-------|
| F      | Upper 128 RAM                       | Special Function                       | F0 | В                          | SCON1       | SBUF1    | SADDR1   | TL4      | TH4          | EIP1         | EIP2  |
| 80     | (Indirect Addressing<br>Only)       | Register's<br>(Direct Addressing Only) | E8 | ADC0CN                     | PCA0L       | PCA0CPL0 | PCA0CPL1 | PCA0CPL2 | PCA0CPL3     | PCA0CPL4     | RSTSR |
| TF     | 1122010-0107-01172-0100             |                                        | E0 | ACC                        | XBR0        | XBR1     | XBR2     | RCAP4L   | RCAP4H       | EIE1         | EIE2  |
| 0<br>F | (Direct and Indirect<br>Addressing) | Lowe 128 RAM<br>(Dire t and Indirect   | D8 | PCA0CN                     | PCA0MD      | PCA0M0   | PCA0CPM1 | PCA0CPM2 | PCA0CPM<br>3 | PCA0CPM<br>4 |       |
| F      | Bit Addressable                     | Addr ssing)                            | D0 | PSW                        | REF0CN      | DAC0L    | DAC0H    | DAC0CN   | DAC1L        | DAC1H        | DAC1C |
| 0      | General Purpose<br>Registers        | 1                                      | C8 | T2CON                      | T4CON       | RCAP2L   | RCAP2H   | TL2      | TH2          |              | SMB0C |
|        | . ingligente                        | 1/                                     | C0 | SMB0CN                     | SMB0ST<br>A | SMB0DAT  | SMB0ADR  | ADC0GTL  | ADC0GTH      | ADC0LTL      | ADCOL |
|        |                                     |                                        | B8 | IP                         | SADEN0      | AMX0CF   | AMX0SL   | ADC0CF   | P1MDIN       | ADC0L        | ADC0  |
|        |                                     |                                        | B0 | P3                         | OSCXCN      | OSCICN   |          |          | P74OUT       | FLSCL        | FLACI |
|        |                                     |                                        | A8 | IE                         | SADDR0      | ADC1CN   | ADC1CF   | AMX1SL   | P3IF         | SADEN1       | EMIOC |
|        |                                     |                                        | A0 | P2                         | EMIOTC      |          | EMIOCF   | P0MDOUT  | P1MDOUT      | P2MDOUT      | P3MDO |
|        |                                     |                                        | 98 | SCON0                      | SBUF0       | SPI0CFG  | SPIODAT  | ADC1     | SPIOCKR      | CPT0CN       | CPT1C |
|        |                                     |                                        | 90 | P1                         | TMR3CN      | TMR3RLL  | TMR3RLH  | TMR3L    | TMR3H        | P7           |       |
|        |                                     |                                        | 88 | TCON                       | TMOD        | TL0      | TL1      | TH0      | TH1          | CKCON        | PSCTI |
|        |                                     |                                        | 80 | P0                         | SP          | DPL      | DPH      | P4       | P5           | P6           | PCON  |
|        |                                     |                                        |    | 0(8)<br>Bit<br>addressable | 1(9)        | 2(A)     | 3(B)     | 4(C)     | 5(D)         | 6(E)         | 7(F)  |



# **Addressing Modes**

- Eight modes of addressing are available with the C8051F020
- The different addressing modes determine how the operand byte is selected

| Addressing Modes   | Instruction    |
|--------------------|----------------|
| Register           | MOV A, B       |
| Direct             | MOV 30H,A      |
| Indirect           | ADD A,@R0      |
| Immediate Constant | ADD A,#80H     |
| Relative*          | SJMP AHEAD     |
| Absolute*          | AJMP BACK      |
| Long*              | LJMP FAR_AHEAD |
| Indexed            | MOVC A,@A+PC   |



\* Related to program branching instructions

# **Register Addressing**

 The register addressing instruction involves information transfer between registers



MOV RO, A

 The instruction transfers the accumulator content into the R0 register. The register bank (Bank 0, 1, 2 or 3) must be specified prior to this instruction.



## **Direct Addressing**

 This mode allows you to specify the operand by giving its actual memory address (typically specified in hexadecimal format) or by giving its abbreviated name (e.g. P3)

Note: Abbreviated SFR names are defined in the "C8051F020.inc" header file

• Example:

| MOV | A, P3 | ;Transfer the contents of<br>;Port 3 to the accumulator |
|-----|-------|---------------------------------------------------------|
| MOV | -     | ;Transfer the contents of RAM<br>20H to the accumulator |



## **Indirect Addressing**

- This mode uses a pointer to hold the effective address of the operand
- Only registers R0, R1 and DPTR can be used as the pointer registers
- The R0 and R1 registers can hold an 8-bit address, whereas DPTR can hold a 16-bit address

#### • Examples:

MOV @RO, A ;Store the content of ;accumulator into the memory ;location pointed to by ;register RO. RO could have an ;8-bit address, such as 60H.
MOVX A, @DPTR ;Transfer the contents from ;the memory location ;pointed to by DPTR into the ;accumulator. DPTR could have a ;16-bit address, such as 1234H.



#### **Immediate Constant Addressing**

- This mode of addressing uses either an 8- or 16-bit constant value as the source operand
- This constant is specified in the instruction, rather than in a register or a memory location
- The destination register should hold the same data size which is specified by the source operand
- Examples:

| ADD A,#030H      | ;Add 8-bit value of 30H to<br>;the accumulator register<br>;(which is an 8-bit register). |
|------------------|-------------------------------------------------------------------------------------------|
| MOV DPTR,#OFEOOH | ;Move 16-bit data constant<br>;FEOOH into the 16-bit Data<br>;Pointer Register.           |



#### **Relative Addressing**

- This mode of addressing is used with some type of jump instructions, like SJMP (short jump) and conditional jumps like JNZ
- These instructions transfer control from one part of a program to another
- The destination address must be within -128 and +127 bytes from the current instruction address because an 8-bit offset is used (2<sup>8</sup> = 256)
- Example:

GoBack:DECA; Decrement AJNZGoBack; If A is not zero, loop back



### **Absolute Addressing**

- Two instructions associated with this mode of addressing are ACALL and AJMP instructions
- These are 2-byte instructions where the 11-bit absolute address is specified as the operand
- The upper 5 bits of the 16-bit PC address are not modified. The lower 11 bits are loaded from this instruction. So, the branch address must be within the current 2K byte page of program memory (2<sup>11</sup> = 2048)

• Example:

ACALL **PORT\_INIT** ; PORT\_INIT should be ; located within 2k bytes.



# Long Addressing

- This mode of addressing is used with the LCALL and LJMP instructions
- It is a 3-byte instruction and the last 2 bytes specify a 16-bit destination location where the program branches
- It allows use of the full 64 K code space
- The program will always branch to the same location no matter where the program was previously
- Example:

LCALL TIMER\_INIT ;TIMER\_INIT address (16-bits ;long) is specified as the ;operand; In C, this will be a ;function call: Timer\_Init(). TIMER\_INIT: ORL TMOD,#01H ;TIMER\_INIT subroutine



# **Indexed Addressing**

- The Indexed addressing is useful when there is a need to retrieve data from a look-up table
- A 16-bit register (data pointer) holds the base address and the accumulator holds an 8-bit displacement or index value
- The sum of these two registers forms the effective address for a JMP or MOVC instruction

| rt                   |
|----------------------|
|                      |
| m the table<br>ts it |
|                      |

 After the execution of the above instructions, the program will branch to address 1F08H (1F00H+08H) and transfer into the accumulator the data byte retrieved from that location (from the look-up table)