

## Data transfer instructions

The following table lists out all the possible data transfer instructions along with other details like addressing mode, size occupied and number machine cycles it takes.

| Mnemonic | Instruction      | Description                                                       | Addressing Mode | # of Bytes | # of Cycles |
|----------|------------------|-------------------------------------------------------------------|-----------------|------------|-------------|
| MOV      | A, #Data         | $A \leftarrow \text{Data}$                                        | Immediate       | 2          | 1           |
|          | A, Rn            | $A \leftarrow Rn$                                                 | Register        | 1          | 1           |
|          | A, Direct        | $A \leftarrow (\text{Direct})$                                    | Direct          | 2          | 1           |
|          | A, @Ri           | $A \leftarrow @Ri$                                                | Indirect        | 1          | 1           |
|          | Rn, #Data        | $Rn \leftarrow \text{data}$                                       | Immediate       | 2          | 1           |
|          | Rn, A            | $Rn \leftarrow A$                                                 | Register        | 1          | 1           |
|          | Rn, Direct       | $Rn \leftarrow (\text{Direct})$                                   | Direct          | 2          | 2           |
|          | Direct, A        | $(\text{Direct}) \leftarrow A$                                    | Direct          | 2          | 1           |
|          | Direct, Rn       | $(\text{Direct}) \leftarrow Rn$                                   | Direct          | 2          | 2           |
|          | Direct1, Direct2 | $(\text{Direct1}) \leftarrow (\text{Direct2})$                    | Direct          | 3          | 2           |
|          | Direct, @Ri      | $(\text{Direct}) \leftarrow @Ri$                                  | Indirect        | 2          | 2           |
|          | Direct, #Data    | $(\text{Direct}) \leftarrow \#Data$                               | Direct          | 3          | 2           |
|          | @Ri, A           | $@Ri \leftarrow A$                                                | Indirect        | 1          | 1           |
|          | @Ri, Direct      | $@Ri \leftarrow \text{Direct}$                                    | Indirect        | 2          | 2           |
|          | @Ri, #Data       | $@Ri \leftarrow \#Data$                                           | Indirect        | 2          | 1           |
|          | DPTR, #Data16    | $DPTR \leftarrow \#Data16$                                        | Immediate       | 3          | 2           |
| MOVC     | A, @A+DPTR       | $A \leftarrow \text{Code Pointed by } A+DPTR$                     | Indexed         | 1          | 2           |
|          | A, @A+PC         | $A \leftarrow \text{Code Pointed by } A+PC$                       | Indexed         | 1          | 2           |
|          | A, @Ri           | $A \leftarrow \text{Code Pointed by } Ri \text{ (8-bit Address)}$ | Indirect        | 1          | 2           |
| MOVX     | A, @DPTR         | $A \leftarrow \text{External Data Pointed by DPTR}$               | Indirect        | 1          | 2           |
|          | @Ri, A           | $@Ri \leftarrow A \text{ (External Data 8-bit Addr)}$             | Indirect        | 1          | 2           |
|          | @DPTR, A         | $@DPTR \leftarrow A \text{ (External Data 16-bit Addr)}$          | Indirect        | 1          | 2           |
| PUSH     | Direct           | Stack Pointer SP $\leftarrow (\text{Direct})$                     | Direct          | 2          | 2           |
| POP      | Direct           | $(\text{Direct}) \leftarrow \text{Stack Pointer SP}$              | Direct          | 2          | 2           |
| XCH      | Rn               | Exchange ACC with Rn                                              | Register        | 1          | 1           |
|          | Direct           | Exchange ACC with Direct Byte                                     | Direct          | 2          | 1           |
|          | @Ri              | Exchange ACC with Indirect RAM                                    | Indirect        | 1          | 1           |
| XCHD     | A, @Ri           | Exchange ACC with Lower Order Indirect RAM                        | Indirect        | 1          | 1           |

# Arithmetic Instructions

All the possible Mnemonics associated with Arithmetic Instructions are mentioned in the following table.

| Mnemonic | Instruction | Description                                                                                                              | Addressing Mode | # of Bytes | # of Cycles |
|----------|-------------|--------------------------------------------------------------------------------------------------------------------------|-----------------|------------|-------------|
| ADD      | A, #Data    | $A \leftarrow A + \text{Data}$                                                                                           | Immediate       | 2          | 1           |
|          | A, Rn       | $A \leftarrow A + Rn$                                                                                                    | Register        | 1          | 1           |
|          | A, Direct   | $A \leftarrow A + (\text{Direct})$                                                                                       | Direct          | 2          | 1           |
|          | A, @Ri      | $A \leftarrow A + @Ri$                                                                                                   | Indirect        | 1          | 1           |
| ADDC     | A, #Data    | $A \leftarrow A + \text{Data} + C$                                                                                       | Immediate       | 2          | 1           |
|          | A, Rn       | $A \leftarrow A + Rn + C$                                                                                                | Register        | 1          | 1           |
|          | A, Direct   | $A \leftarrow A + (\text{Direct}) + C$                                                                                   | Direct          | 2          | 1           |
|          | A, @Ri      | $A \leftarrow A + @Ri + C$                                                                                               | Indirect        | 1          | 1           |
| SUBB     | A, #Data    | $A \leftarrow A - \text{Data} - C$                                                                                       | Immediate       | 2          | 1           |
|          | A, Rn       | $A \leftarrow A - Rn - C$                                                                                                | Register        | 1          | 1           |
|          | A, Direct   | $A \leftarrow A - (\text{Direct}) - C$                                                                                   | Direct          | 2          | 1           |
|          | A, @Ri      | $A \leftarrow A - @Ri - C$                                                                                               | Indirect        | 1          | 1           |
| MUL      | AB          | Multiply A with B<br>$(A \leftarrow \text{Lower Byte of } A * B \text{ and } B \leftarrow \text{Higher Byte of } A * B)$ | --              | 1          | 4           |
|          |             |                                                                                                                          |                 |            |             |
| DIV      | AB          | Divide A by B<br>$(A \leftarrow \text{Quotient and } B \leftarrow \text{Remainder})$                                     | --              | 1          | 4           |
|          |             |                                                                                                                          |                 |            |             |
| DEC      | A           | $A \leftarrow A - 1$                                                                                                     | Register        | 1          | 1           |
|          | Rn          | $Rn \leftarrow Rn - 1$                                                                                                   | Register        | 1          | 1           |
|          | Direct      | $(\text{Direct}) \leftarrow (\text{Direct}) - 1$                                                                         | Direct          | 2          | 1           |
|          | @Ri         | $@Ri \leftarrow @Ri - 1$                                                                                                 | Indirect        | 1          | 1           |
| INC      | A           | $A \leftarrow A + 1$                                                                                                     | Register        | 1          | 1           |
|          | Rn          | $Rn \leftarrow Rn + 1$                                                                                                   | Register        | 1          | 1           |
|          | Direct      | $(\text{Direct}) \leftarrow (\text{Direct}) + 1$                                                                         | Direct          | 2          | 1           |
|          | @Ri         | $@Ri \leftarrow @Ri + 1$                                                                                                 | Indirect        | 1          | 1           |
|          | DPTR        | $DPTR \leftarrow DPTR + 1$                                                                                               | Register        | 1          | 2           |
| DA       | A           | Decimal Adjust Accumulator                                                                                               | --              | 1          | 1           |

The arithmetic instructions have no knowledge about the data format i.e., signed, unsigned, ASCII, BCD, etc. Also, the operations performed by the arithmetic instructions affect flags like carry, overflow, zero, etc. in the PSW Register.

## Logical Instructions.

The following table shows all the possible Mnemonics of the Logical Instructions.

| Mnemonic | Instruction   | Description                                                      | Addressing Mode | # of Bytes | # of Cycles |
|----------|---------------|------------------------------------------------------------------|-----------------|------------|-------------|
| ANL      | A, #Data      | $A \leftarrow A \text{ AND Data}$                                | Immediate       | 2          | 1           |
|          | A, Rn         | $A \leftarrow A \text{ AND } Rn$                                 | Register        | 1          | 1           |
|          | A, Direct     | $A \leftarrow A \text{ AND (Direct)}$                            | Direct          | 2          | 1           |
|          | A, @Ri        | $A \leftarrow A \text{ AND } @Ri$                                | Indirect        | 1          | 1           |
|          | Direct, A     | $(\text{Direct}) \leftarrow (\text{Direct}) \text{ AND } A$      | Direct          | 2          | 1           |
|          | Direct, #Data | $(\text{Direct}) \leftarrow (\text{Direct}) \text{ AND } \#Data$ | Direct          | 3          | 2           |
| ORL      | A, #Data      | $A \leftarrow A \text{ OR Data}$                                 | Immediate       | 2          | 1           |
|          | A, Rn         | $A \leftarrow A \text{ OR } Rn$                                  | Register        | 1          | 1           |
|          | A, Direct     | $A \leftarrow A \text{ OR (Direct)}$                             | Direct          | 2          | 1           |
|          | A, @Ri        | $A \leftarrow A \text{ OR } @Ri$                                 | Indirect        | 1          | 1           |
|          | Direct, A     | $(\text{Direct}) \leftarrow (\text{Direct}) \text{ OR } A$       | Direct          | 2          | 1           |
|          | Direct, #Data | $(\text{Direct}) \leftarrow (\text{Direct}) \text{ OR } \#Data$  | Direct          | 3          | 2           |
| XRL      | A, #Data      | $A \leftarrow A \text{ XRL Data}$                                | Immediate       | 2          | 1           |
|          | A, Rn         | $A \leftarrow A \text{ XRL } Rn$                                 | Register        | 1          | 1           |
|          | A, Direct     | $A \leftarrow A \text{ XRL (Direct)}$                            | Direct          | 2          | 1           |
|          | A, @Ri        | $A \leftarrow A \text{ XRL } @Ri$                                | Indirect        | 1          | 1           |
|          | Direct, A     | $(\text{Direct}) \leftarrow (\text{Direct}) \text{ XRL } A$      | Direct          | 2          | 1           |
|          | Direct, #Data | $(\text{Direct}) \leftarrow (\text{Direct}) \text{ XRL } \#Data$ | Direct          | 3          | 2           |
| CLR      | A             | $A \leftarrow 00H$                                               | --              | 1          | 1           |
| CPL      | A             | $A \leftarrow A$                                                 | --              | 1          | 1           |
| RL       | A             | Rotate ACC Left                                                  | --              | 1          | 1           |
| RLC      | A             | Rotate ACC Left through Carry                                    | --              | 1          | 1           |
| RR       | A             | Rotate ACC Right                                                 | --              | 1          | 1           |
| RRC      | A             | Rotate ACC Right through Carry                                   | --              | 1          | 1           |
| SWAP     | A             | Swap Nibbles within ACC                                          | --              | 1          | 1           |

## Boolean or Bit Manipulation Instructions

These instructions can perform set, clear, and, or, complement etc. at bit level. All the possible mnemonics of the Boolean Instructions are specified in the following table.

| Mnemonic | Instruction | Description                                        | # of Bytes | # of Cycles |
|----------|-------------|----------------------------------------------------|------------|-------------|
| CLR      | C           | $C \leftarrow 0$ (C = Carry Bit)                   | 1          | 1           |
|          | Bit         | Bit $\leftarrow 0$ (Bit = Direct Bit)              | 2          | 1           |
| SET      | C           | $C \leftarrow 1$                                   | 1          | 1           |
|          | Bit         | Bit $\leftarrow 1$                                 | 2          | 1           |
| CPL      | C           | $C \leftarrow \overline{C}$                        | 1          | 1           |
|          | Bit         | Bit $\leftarrow \overline{\text{Bit}}$             | 2          | 1           |
| ANL      | C, /Bit     | $C \leftarrow C \cdot \overline{\text{Bit}}$ (AND) | 2          | 1           |
|          | C, Bit      | $C \leftarrow C \cdot \text{Bit}$ (AND)            | 2          | 1           |
| ORL      | C, /Bit     | $C \leftarrow C + \overline{\text{Bit}}$ (OR)      | 2          | 1           |
|          | C, Bit      | $C \leftarrow C + \text{Bit}$ (OR)                 | 2          | 1           |
| MOV      | C, Bit      | $C \leftarrow \text{Bit}$                          | 2          | 1           |
|          | Bit, C      | Bit $\leftarrow C$                                 | 2          | 2           |
| JC       | rel         | Jump if Carry (C) is Set                           | 2          | 2           |
| JNC      | rel         | Jump if Carry (C) is Not Set                       | 2          | 2           |
| JB       | Bit, rel    | Jump if Direct Bit is Set                          | 3          | 2           |
| JNB      | Bit, rel    | Jump if Direct Bit is Not Set                      | 3          | 2           |
| JBC      | Bit, rel    | Jump if Direct Bit is Set and Clear Bit            | 3          | 2           |

# Program Branching Instructions

The following table shows all the mnemonics with respect to the program branching instructions.

| Mnemonic | Instruction     | Description                                            | # of Bytes | # of Cycles |
|----------|-----------------|--------------------------------------------------------|------------|-------------|
| ACALL    | ADDR11          | Absolute Subroutine Call<br>PC + 2 → (SP); ADDR11 → PC | 2          | 2           |
| LCALL    | ADDR16          | Long Subroutine Call<br>PC + 3 → (SP); ADDR16 → PC     | 3          | 2           |
| RET      | --              | Return from Subroutine<br>(SP) → PC                    | 1          | 2           |
| RETI     | --              | Return from Interrupt                                  | 1          | 2           |
| AJMP     | ADDR11          | Absolute Jump<br>ADDR11 → PC                           | 2          | 2           |
| LJMP     | ADDR16          | Long Jump<br>ADDR16 → PC                               | 3          | 2           |
| SJMP     | rel             | Short Jump<br>PC + 2 + rel → PC                        | 2          | 2           |
| JMP      | @A + DPTR       | A + DPTR → PC                                          | 1          | 2           |
| JZ       | rel             | If A=0, Jump to PC + rel                               | 2          | 2           |
| JNZ      | rel             | If A ≠ 0, Jump to PC + rel                             |            |             |
| CJNE     | A, Direct, rel  | Compare (Direct) with A. Jump to PC + rel if not equal | 3          | 2           |
|          | A, #Data, rel   | Compare #Data with A. Jump to PC + rel if not equal    | 3          | 2           |
|          | Rn, #Data, rel  | Compare #Data with Rn. Jump to PC + rel if not equal   | 3          | 2           |
|          | @Ri, #Data, rel | Compare #Data with @Ri. Jump to PC + rel if not equal  | 3          | 2           |
| DJNZ     | Rn, rel         | Decrement Rn. Jump to PC + rel if not zero             | 2          | 2           |
|          | Direct, rel     | Decrement (Direct). Jump to PC + rel if not zero       | 3          | 2           |
| NOP      |                 | No Operation                                           | 1          | 1           |

### **Instructions Affecting Flags**

The C, AC, and OV flags are arithmetic flags. They are set to 1 or cleared to 0 automatically, depending upon the outcomes of the following instructions. The following instruction set includes all instructions that modify the flags and is not confined to arithmetic instructions:

| INSTRUCTION MNEMONIC | FLAGS AFFECTED |
|----------------------|----------------|
| ADD                  | C AC ov        |
| ADDC                 | C AC ov        |
| ANL C,direct         | C              |
| CJNE                 | C              |
| CLR C                | C=0            |
| CPL C                | C=C            |
| DA A                 | C              |
| DIV                  | C=0 OV         |
| MOV C,direct         | C              |
| MUL                  | C=0 OV         |
| ORL C,direct         | C              |
| RLC                  | C              |
| RRD                  | C              |
| SETB C               | C = 1          |
| SUBB                 | C AC OV        |

### **8051 Instruction set manual for add**

#### **Example**

Sketch the PSW format and Show the affected bit values of PSW register for following operation

- i) Select register bank2
- ii) Mov A, #35h
- iii) Mov A, #25h
- iv) Mov A, #27h

Add A, #0FDh      Mov B, #00h      INC A

Div AB

# ADD

[Home](#) » [Instructions](#) » ADD

The **ADD** instruction adds a byte value to the accumulator and stores the results back in the accumulator. Several of the flag registers are affected.

See Also: [ADDC](#), [SUBB](#)

---

## ADD A, #immediate

|   |    |    |     |     |    |  |   |
|---|----|----|-----|-----|----|--|---|
| C | AC | F0 | RS1 | RS0 | OV |  | P |
|---|----|----|-----|-----|----|--|---|

**Bytes** 2

**Cycles** 1

**Encoding**

|          |           |
|----------|-----------|
| 00100100 | immediate |
|----------|-----------|

### Operation

A = A + immediate

---

## Example

ADD A, #03h

---

## ADD A, @Ri

|   |    |    |     |     |    |  |   |
|---|----|----|-----|-----|----|--|---|
| C | AC | F0 | RS1 | RS0 | OV |  | P |
|---|----|----|-----|-----|----|--|---|

**Bytes** 1

**Cycles** 1

**Encoding**

|          |
|----------|
| 0010011i |
|----------|

### Operation

A = A + (Ri)

---

## Example

ADD A, @R1

---

## ADD A, direct

---

|          |           |           |            |            |           |  |          |
|----------|-----------|-----------|------------|------------|-----------|--|----------|
| <b>C</b> | <b>AC</b> | <b>F0</b> | <b>RS1</b> | <b>RS0</b> | <b>OV</b> |  | <b>P</b> |
|----------|-----------|-----------|------------|------------|-----------|--|----------|

**Bytes** 2

**Cycles** 1

**Encoding** 00100101 direct

**Operation**  $A = A + \text{(direct)}$

**Example**

ADD A, 20h

---

**ADD A, Rn**

|          |           |           |            |            |           |  |          |
|----------|-----------|-----------|------------|------------|-----------|--|----------|
| <b>C</b> | <b>AC</b> | <b>F0</b> | <b>RS1</b> | <b>RS0</b> | <b>OV</b> |  | <b>P</b> |
|----------|-----------|-----------|------------|------------|-----------|--|----------|

**Bytes** 1

**Cycles** 1

**Encoding** 00101nnn

**Operation**  $A = A + Rn$

**Example**

ADD A, R0

**Example-2**

Determine the single or pair of instructions to do the following and explain with an example.

- a) The number is added with itself and result is zero.
- b) To access the Look up table.
- c)To perform addition of BCD numbers.
- d)To read and write to the ports.
- e) to check whether MSB bit is 0 or 1.