| 8051 Overview and Instruction | n Set |
|-------------------------------|-------|
|                               |       |
| Curtis A. Nelson              |       |
| Engr 355                      |       |
|                               |       |
| Curt Nelson Engr355           | 1     |









Curt Nelson Engr355





|          | В          |      |        |          |     |     |      |
|----------|------------|------|--------|----------|-----|-----|------|
|          |            |      |        | 14 B     |     |     |      |
|          | ACC        |      |        |          |     |     |      |
|          |            |      |        |          |     |     |      |
| <b>)</b> | PSW        |      |        |          |     |     |      |
| 8        | T2CON      |      | RCAP2L | RCAP2H   | TL2 | TH2 |      |
| 0        |            |      |        |          |     |     |      |
| 8        | IP         |      |        |          |     |     |      |
| o [      | P3         |      |        |          |     |     |      |
| 8        | ΙE         |      |        |          |     |     |      |
| 0        | P2         |      |        |          |     |     |      |
| 8 [      | SCON       | SBUF |        |          |     |     |      |
| o [      | <b>P</b> 1 |      |        |          |     |     |      |
| 8 [      | TCON       | TMOD | TL0    | TL1      | THO | TH1 |      |
| 0        | P0         | SP   | DPL    | DPH      |     |     | PCON |
| -        | ↑<br>Bit   |      |        | Figure 5 |     |     |      |

| Symbol   | Name                         | Address | ] |
|----------|------------------------------|---------|---|
| *ACC     | Accumulator                  | 0E0H    |   |
| *B       | B Register                   | OFOH    |   |
| *PSW     | Program Status Word          | 0D0H    |   |
| SP       | Stack Pointer                | 81H     |   |
| DPTR     | Data Pointer 2 Bytes         |         |   |
| DPL      | Low Byte                     | 82H     |   |
| DPH      | High Byte                    | 83H     |   |
| *P0      | Port 0                       | 80H     |   |
| *P1      | Port 1                       | 90H     |   |
| *P2      | Port 2                       | OAOH    |   |
| *P3      | Port 3                       | OBOH    |   |
| *IP      | Interrupt Priority Control   | 0B8H    |   |
| *IE      | Interrupt Enable Control     | 0A8H    |   |
| TMOD     | Timer/Counter Mode Control   | 89H     |   |
| *TCON    | Timer/Counter Control        | 88H     |   |
| +T2CON   | Timer/Counter 2 Control      | 0C8H    |   |
| TH0      | Timer/Counter 0 High Byte    | 8CH     |   |
| TL0      | Timer/Counter 0 Low Byte     | 8AH     |   |
| TH1      | Timer/Counter 1 High Byte    | 8DH     |   |
| TL1      | Timer/Counter 1 Low Byte     | 8BH     |   |
| +TH2     | Timer/Counter 2 High Byte    | 0CDH    |   |
| + TL2    | Timer/Counter 2 Low Byte     | OCCH    |   |
| + RCAP2H | T/C 2 Capture Reg. High Byte | 0CBH    |   |
| +RCAP2L  | T/C 2 Capture Reg. Low Byte  | 0CAH    |   |
| *SCON    | Serial Control               | 98H     |   |
| SBUF     | Serial Data Buffer           | 99H     | 1 |
| PCON     | Power Control                | 87H     |   |







| Pro        | gram                        | Statu                            | us Wo                                  | ord                                      |                  |                   |                      |                     |           |
|------------|-----------------------------|----------------------------------|----------------------------------------|------------------------------------------|------------------|-------------------|----------------------|---------------------|-----------|
| PSW:       | Program<br>summa<br>PROGR/  | m status<br>rized in t<br>AM STA | word (PS<br>he follow<br><b>FUS WO</b> | W) at add<br>ing table<br><b>RD. BIT</b> | ress DO<br>ADDRE | ⊣ contai<br>SSABL | ins sta<br><b>E.</b> | tus bits as         |           |
| CY         | AC                          | F0                               | RS1                                    | RS0                                      | ov               | _                 | P                    | 7                   |           |
| CY<br>AC   | PSW.7<br>PSW.6              | Carry Fla<br>Auxiliary           | ig.<br>Carry Flag                      |                                          |                  |                   |                      | _                   |           |
| <b>F</b> 0 | PSW.5                       | Flag 0 av                        | ailable to th                          | e user for g                             | eneral purp      | ose.              |                      |                     |           |
| RS1        | PSW.4                       | Register 1                       | Bank selecte                           | or bit 1 (SEI                            | E NOTE 1)        |                   |                      |                     |           |
| RS0        | PSW.3                       | Register 1                       | Bank selecto                           | or bit 0 (SEI                            | E NOTE 1)        |                   |                      |                     |           |
| ov         | PSW.2                       | Overflow                         | Flag.                                  |                                          |                  |                   |                      |                     |           |
| _          | PSW.1                       | User defin                       | nable flag.                            |                                          |                  |                   |                      |                     |           |
| Р          | <b>PSW</b> .0               | Parity fla.<br>'1' bits in       | g. Set/clear<br>the accumi             | d by hardward<br>ulator.                 | are each in      | struction         | cycle to i           | ndicate an odd/even | number of |
| 1          | <b>NOTE:</b><br>1. The valu | e presente                       | d by RS0 a                             | und RS1 se                               | lects the c      | orrespor          | iding reg            | jister bank.        |           |
|            | RS1                         |                                  | RS0                                    |                                          | Register         | Bank              |                      | Address             |           |
|            | 0                           |                                  | 0                                      |                                          | 0                |                   |                      | 00H-07H             | 7         |
|            | 0                           |                                  | 1                                      |                                          | 1                |                   |                      | 08H-0FH             |           |
| 1          | 1                           |                                  | 0                                      |                                          | 2                |                   |                      | 10H-17H             |           |
|            | 1                           |                                  | 1                                      |                                          | 3                |                   |                      | 18H-1FH             |           |
| Cui        |                             |                                  | 1                                      |                                          | 3                |                   |                      | 18H-1FH             |           |

## **Program Status Word**

- Carry flag is also the "Boolean accumulator": 1 bit register for Boolean instructions
- Example: ANLC,25<sub>H</sub>
- AND's bit 25<sub>H</sub> with the carry flag and places the result back in the carry flag
- Auxiliary carry flag (AC): is set if a carry was generated out of bit 3 into bit 4 or if the result in the lower nibble is in the range  $0A_H$  to  $0F_H$
- AC is useful in arithmetic operations on binary coded decimal (BCD) values.

Curt Nelson Engr355















































| • | Example: Two 4-digit BCD numbers are in internal memory at locations $40_{H}$ , $41_{H}$ and $42_{H}$ , $43_{H}$ . The most                        |
|---|----------------------------------------------------------------------------------------------------------------------------------------------------|
|   | significant digits are in locations $40_{\rm H}$ and $42_{\rm H}$ . Add them and store the BCD result in locations $40_{\rm H}$ and $41_{\rm H}$ . |
|   | MOV A, $43_{\text{H}}$                                                                                                                             |
|   |                                                                                                                                                    |
|   | DAA                                                                                                                                                |
|   | MOV 41 <sub>H</sub> , A                                                                                                                            |
|   | MOV A, 42 <sub>H</sub>                                                                                                                             |
|   | ADDC A, 40 <sub>H</sub>                                                                                                                            |
|   | DA A                                                                                                                                               |
|   | MOV 40 <sub>H</sub> ,A                                                                                                                             |
|   | <ul> <li>An example of multi-precision arithmetic</li> </ul>                                                                                       |



























- There are two versions of the CALL instruction: ACALL and LCALL using absolute and long addressing
- Generic CALL may be used if the programmer does not care which way the address is coded
- Either instruction pushes the contents of the PC on the stack and loads the PC with the address specified in the instruction
- Note that the PC will contain the address of the instruction following the CALL instruction when it gets pushed on the stack
- The PC is pushed on the stack low-byte first, high-byte second

51

Curt Nelson Engr355







## Summary

- 8051 overview
- Hardware
- Instruction set

Curt Nelson Engr355

55