**Chapter 4** 

#### 8051 Family Microcontrollers Instruction Set

#### Lesson 4

#### Boolean, Arithmetic and Logic Processing Instructions

#### Addresses of the Bit at Port

- Bit 5 port P0 bit address = 85H
- Bit 3 of A register address = E3H
- Bit 7 PSW (C bit) address = D7H

#### Bit-Address of Bits at Internal RAM

Bit-Address of Bit 5 at Internal RAM at 21H = 0DH



| Source or Destination of a bit |                                 |
|--------------------------------|---------------------------------|
| SFRs                           | Select bit addresses 80H-FFH    |
| <b>2FH</b>                     | Detween SFK at SUH to FFH       |
| 2EH                            | 128 bits at bit-addresses 00H-  |
|                                | 7FH in Internal RAM at 20H-     |
|                                | <b>2FH (8-bits at each RAM)</b> |
| 22H                            | bit                             |
| 20H                            |                                 |
|                                |                                 |

#### **Instruction Execution**

**Fetch STEP 1** opcode-bits **Fetch byte for STEP 2** bit address bit addressing Mode: clock • 1 cycle for MOV C, bit cycle (s) • CLR bit • SETB bit and • CPL bit else 2 cycles

ime







2011







CLRA; CPL A; RRA; RLA; RLC A; **RRC.A;** 









#### **Arithmetic Instructions**

ADD, ADDC, SBB, MUL and DIV
A is accumulator and is source-1 cum destination operand ADD A, @Ri; ADD A, Rn; ADD A, direct; ADD A, #data

#### C, AC and OV Flags at PSW also affect $A \leftarrow A + byte$ From Rn or direct or indirect or immediate

ADDC A, @Ri; ADDC A, Rn; ADDC A, direct; ADDC A, #data



From *Rn* or *direct* or *indirect* or *immediate* 

SBB A, @Ri; SBB A, Rn; SBB A, direct; SBB A, #data



From Rn or direct or indirect or immediate





C←0 and OV at PSW also affect

8051





#### C ←0 and OV at PSW also affect

8051







INC A; INC @Ri; INC direct; INC Rn



DEC A; DEC @Ri; DEC direct; DEC Rn



# ANL, ORL, XRL A or direct source-1 cum destination operand No flag affects in 8051 logic operations

ANL A, @Ri; ANL A, Rn; ANL A, direct; ANL A, #data;

#### No Flags at PSW affect A A AND. byte logical AND operation

From *Rn* or *direct* or *indirect* or *immediate* 

#### ANL direct, A;



#### ANL direct, #data;



ORL A, @Ri; ORL A, Rn; ORL A, direct; ORL A, #data;



#### **ORL direct, A;**



#### **ORL direct, #data;**



XRL A, @Ri; XRL A, Rn; XRL A, direct; XRL A, #data;

#### No Flags at PSW affect

A

A.XOR. byte logical XOR operation From Rn or direct or indirect or immediate

8051

#### 2011

#### **XRL direct, A;**



#### XRL direct, #data;



### Summary

## We learnt 8051 family processing instructions

- clear, complement, set bit
- clear and complement A
- Arithmetic and logical instructions
- Flags do not affect in logic operations and increment-decrement
- No instruction for subtract without borrow