

L #2

- 8051 has CPU: The CPU contains two types of Registers

① 8-bit registers : A, B, R<sub>0</sub>, R<sub>1</sub>, R<sub>2</sub>, R<sub>3</sub>, R<sub>4</sub>, R<sub>5</sub>, R<sub>6</sub>, R<sub>7</sub>, S<sup>P</sup>,  
PSW.



Range of values:

|      | min    | max         |
|------|--------|-------------|
| 0000 | 0000 B | 1111 1111 B |
| 00 H |        | FF H        |
| 0    |        | 255 D       |

② 16-bit registers : PC, DPTR



Range of values

|       | min | max     |
|-------|-----|---------|
| 0000H |     | FFFF H  |
| 0 D   |     | 65535 D |

- All previous registers are called the most widely used registers. ②

---

\* A = ACC = Accumulator (8bit)

- It is must be used in all arithmetic operations  
 $(+, -, \times, \div)$

- In general, it is used in logical operations (AND, OR, ...)

- Must be used in external data transmission.

---

\* B → Auxiliary register

- It is used as auxiliary register with A in arithmetic operation.

① Multiplication ( $\times$ )  before → hold second operand  
after → hold high part of result.

② Division  before → hold second operand  
after → hold the remainder  
 $\underline{\quad}$

\*  $R_0 \rightarrow R_7$  : general purpose registers

\* PC : Program counter (16 bit)

- Is used to points to the address of the next instruction that should be fetched from (ROM) memory to be executed in CPU.

\* DPTR : Data pointer (16 bit)

- Is used to point to the address of data that should be fetched from memory to the CPU



- The max size of memory that can be connected with ④

8051: 64KB

$$2^{16} = 2^6 \times 2^{10} = \underline{64\text{ KB}}$$

PC → 16 bit

**address (ROM) opcode program**

PC →

|   | 0000 | 7D25       | ORG 0H ;start at location 0        |
|---|------|------------|------------------------------------|
| 1 | 0000 | 7D25       | MOV R5, #25H ;load 25H into R5     |
| 2 | 0000 | 7D25       | MOV R7, #34H ;load 34H into R7     |
| 3 | 0002 | 7F34       | MOV A, #0 ;load 0 into A           |
| 4 | 0004 | 7400       | ADD A, R5 ;add contents of R5 to A |
| 5 | 0006 | 2D         | ;now A = A + R5                    |
| 6 | 0007 | 2F         | ADD A, R7 ;add contents of R7 to A |
| 7 | 0008 | 2412       | ;now A = A + R7                    |
| 8 | 000A | 80FE HERE: | ADD A, #12H ;add to A value 12H    |
| 9 | 000C |            | ;now A = A + 12H                   |
|   |      |            | SJMP HERE ;stay in this loop       |
|   |      |            | END ;end of asm source file        |

(5)

\* PSW : program status Register ( 8 bit)

- Is used to reflects the status of CPU after executing some instructions.
- Each bit in PSW is called flag bit.



$$\textcircled{1} \quad \text{PSW.7} = C = \text{Cy}$$

- Is carry flag

- Is set (1) when there is carry out from D7.  
 ↓  
 addition

subtraction : carry in D7  
 borrow

MOV A, #93H

ADD A, #0E2H

$$\text{PSW.7} = C = 1$$

$$\text{PSW.6} = AC = 0$$

$$\begin{array}{r}
 & D_7 & D_6 & D_5 & D_4 & D_3 & D_2 & D_1 & D_0 \\
 & 1 & 0 & 0 & 1 & 0 & 0 & 1 & 1 \\
 + & 1 & 1 & 1 & 0 & 0 & 0 & 1 & 0 \\
 \hline
 & 0 & 1 & 1 & 1 & 1 & 0 & 1 & 0
 \end{array}$$

(6)

② PSW. 6 = AC

- is called auxiliary carry flag (half carry)
  - is set (1) when there is carry from D<sub>3</sub> to D<sub>4</sub>
  - is used only for BCD addition
- 

③ PSW. 2 = OV

- is called overflow flag
  - is set (1) to indicate that the result of signed arithmetic operation is error (out of the range). Does not fit in the range.
- 

$OV = 1 \rightarrow$  ① when there is carry from D<sub>6</sub> to D<sub>7</sub> and no carry from D<sub>7</sub> to out.

② when there is carry from D<sub>7</sub> to out and no carry from D<sub>6</sub> to D<sub>7</sub>.

Mov A, # 93H  
Add A, # 8EH

## Different

$$psw.7 = cy = 1$$

$$PSU.G = AC = 1$$

PSW.2 = OV = 1

$$PSW_{\cdot 0} = P = 0$$

Handwritten diagram illustrating a 4-bit adder with carry lookahead. The addends are 1001 and 1011. The sum is 00100001. A green circle highlights the first bit of the addend 1001. Red annotations show the propagation paths for bits D7, D6, D4, and D3, and the final sum bit D0.

$$\textcircled{4} \quad PSW. o = P$$

is parity flag

is used to detect errors

is used to reflect number of ones (1's) in A (Accumulator).

show me the content of PSW ( CY, AC, OV, P ) ⑥  
after executing the following

MOV A, #0C8H

ADD A, #78H



ADD A, source ; A = A + source

destination  
8 bit

- affects psr flags ( CY, AC, P, OV )

ADD B, #25H X

ADD A, B ←

ADD B, A X

## \* 8051 features

**Table 1-4: Comparison of 8051 Family Members**

| Feature                              | 8051    | 8052 | 8031                |
|--------------------------------------|---------|------|---------------------|
| ROM (on-chip program space in bytes) | 4K Byte | 8K   | 0K <sup>o Rom</sup> |
| RAM (bytes)                          | 128     | 256  | 128                 |
| Timers                               | 2       | 3    | 2                   |
| I/O pins ( 4 I/O ports)              | 32      | 32   | 32                  |
| Serial port                          | 1       | 1    | 1                   |
| Interrupt sources                    | 6       | 8    | 6                   |

each part is 8 pins

$$8 \times 4 = 32 \text{ pins}$$



- 8051 is an 8-bit microcontroller



- Up on reset (power on) all registers ( $R_0 \rightarrow R_7$ )

will be in bank 0 ( $00H \rightarrow 07H$ )

- programmer can move ( $R_0 - R_7$ ) from bank 0 to bank 1, 2, or 3, using PSW.4 (RS1) and PSW.3 (RS0)

| $RS_1$<br>PSW.4 | $RS_0$<br>PSW.3 | Bank         |
|-----------------|-----------------|--------------|
| 0               | 0               | 0 by default |
| 0               | 1               | 1            |
| 1               | 0               | 2            |
| 1               | 1               | 3            |

- Move ( $R_0 - R_7$ ) from bank 0 to bank 3.

SETB PSW.4 ;  $PSW.4 = RS_1 = 1$

SETB PSW.3 ;  $PSW.3 = RS_0 = 1$

in bank 3

SETB Bit ; Bit = 1

CLR Bit ; Bit = 0

Write a program to move the content of R1 from  
bank 3 to R7 in to bank 1

ORG 0000H

SETB PSW.3

SETB PSW.4 ; in bank 3

MOV A,R1

SETB PSW.3

CLR PSW.4 ; in bank 3

MOV R7,A

SJMP \$

END