## Rozkazy mikrokontrolera 8051

|   | mini onomi otora oco i |   |    |
|---|------------------------|---|----|
| _ |                        | С | ΔC |

٥v

Operacje arytmetyczne

| Dodaj                  | A ← A + □                      | ADD               | A,Rr | A,direct   | A,@Ri        | A,#data |      | Χ | Χ | Χ |
|------------------------|--------------------------------|-------------------|------|------------|--------------|---------|------|---|---|---|
| Dodaj                  | $A \leftarrow A + \square + C$ | ADDC              | A,Rr | A,direct   | A,@Ri        | A,#data |      | Χ | Χ | Χ |
| Odejmij                | $A \leftarrow A - \square - C$ | SUBB              | A,Rr | A,direct   | A,@Ri        | A,#data |      | Χ | Χ | Χ |
| Zwiększ o jede         | en                             | INC               | Α    | Rr         | direct       | @Ri     | DPTR |   |   |   |
| Zmniejsz o jed         | DEC                            | Α                 | Rr   | direct     | @Ri          |         |      |   |   |   |
| Mnóż                   | A*B                            | MUL <sup>4)</sup> | AB   | wynik: A - | low B - high | ì       |      | 0 |   | Χ |
| Dziel                  | A/B                            | DIV <sup>4)</sup> | AB   | A - wynik  | B - reszta   |         |      | 0 |   | Χ |
| Poprawka dziesiętna DA |                                |                   | Α    |            |              |         |      | Χ |   |   |

Operacje logiczne

| _ ' ' '                 |      |      |     |          |        |            |             |                            |
|-------------------------|------|------|-----|----------|--------|------------|-------------|----------------------------|
| Iloczyn logiczny AND    | ANL  | A,Rr |     | A,direct | A,@Ri  | A,#data    | direct,A    | direct,#data <sup>2)</sup> |
| Suma logiczna OR        | ORL  | A,Rr |     | A,direct | A,@Ri  | A,#data    | direct,A    | direct,#data2)             |
| Suma modulo 2 XOR       | XRL  | A,Rr |     | A,direct | A,@Ri  | A,#data    | direct,A    | direct,#data2)             |
| Zeruj / Neguj           | CLR  | ·A   | CPL | A        |        |            |             |                            |
| Obrót w lewo / prawo    | RL   | Α    | RR  | Α        | Rr     | rejestry I | R0R7        |                            |
| Obrót przez C           | RLC  | Α    | RRC | A        | direct | wewnętr    | zny RAM (1  | 28 bajt) + SFR             |
| Zamień 4 bity (hi ↔ lo) | SWAP | Α    |     |          | @Ri    | adres po   | średni R0 l | ub R1                      |
|                         | •    |      |     |          | bit    | bity adres | sowalne RA  | M + SFR                    |

| Operacje logiczne na bitach |                   |       |                     | #data   | stała 8-bitowa                |
|-----------------------------|-------------------|-------|---------------------|---------|-------------------------------|
| Zeruj                       | CLR               | С     | bit                 | #data16 | stała 16-bitowa               |
| Ustaw                       | SETB              | С     | bit                 | addr16  | adres w 64k                   |
| Neguj                       | CPL               | С     | bit                 | addr11  | adres w stronie 2k            |
| Iloczyn logiczny            | ANL <sup>2)</sup> | C,bit | C,/bit              | rel     | adres względny -128+127       |
| Suma logiczna               | ORL <sup>2)</sup> | C,bit | C,/bit              | /bit    | negacja bitu                  |
| Kopiuj                      | MOV               | C,bit | bit,C <sup>2)</sup> | n)      | rozkaz wykonywany w n cyklach |

Przesyłanie danych

| Kopiuj            | $A \leftarrow \square$      | MOV                |              | A,Rr                      | A,direct                 | A,@Ri        | A,#data        |
|-------------------|-----------------------------|--------------------|--------------|---------------------------|--------------------------|--------------|----------------|
| Kopiuj            | $Rr \leftarrow \square$     | MOV                | Rr,A         |                           | Rr,direct <sup>2)</sup>  |              | Rr,#data       |
| Kopiuj            | $direct \leftarrow \square$ | MOV                | direct,A     | direct,Rr2)               | direct, direct2)         | direct,@Ri2) | direct,#data2) |
| Kopiuj            | @Ri ← 🗖                     | MOV                | @Ri,A        |                           | @Ri,direct <sup>2)</sup> |              | @Ri,#data      |
| Kopiuj            | $DPTR \leftarrow \square$   | MOV <sup>2)</sup>  | DPTR,#data16 |                           |                          |              |                |
| Pamięć programu   |                             | MOVC <sup>2)</sup> | A,@A+DPTR    | A,@A+PC                   |                          |              |                |
| Zewn. pamięć dan  | ych                         | MOVX <sup>2)</sup> | A,@Ri        | A,@DPTR                   | @Ri,A                    | @DPTR,A      |                |
| Zamień            |                             | XCH                | A,Rr         | A,direct                  | A,@Ri                    |              |                |
| Zamień młod. 4 bi | ty                          | XCHD               | A,@Ri        |                           |                          |              |                |
| Zapisz na stos    |                             | PUSH <sup>2)</sup> | direct       | SP = SP + 1;              | (SP) ← direct            | •            | •              |
| Odczytaj ze stosu |                             | POP <sup>2)</sup>  | direct       | $direct \leftarrow (SP),$ | SP = SP - 1              |              |                |

## Skoki<sup>2)</sup>

|   | SKOKI                     |            |              |            |            |            |                         |              |           |
|---|---------------------------|------------|--------------|------------|------------|------------|-------------------------|--------------|-----------|
| 1 | Podprogramy               | LCALL      | addr16       | ACALL      | addr11     | RET        |                         | RETI         |           |
| ı | Skoki                     | LJMP       | addr16       | AJMP       | addr11     | SJMP       | rel                     | JMP          | @A+DPTR   |
| ı | Skok warunkowy            | JZ, JNZ, J | C, JNC '     | rel        | odpowiedn  | io dla: AC | CC = 0, ACC ≠           | 0, C = 1     | I, C = 0  |
| ı | Skok warunkowy od bitu    | JB, JNB, J | BC           | bit,rel    | odpowiedn  | io, gdy: b | it = 1, $bit = 0$ , $l$ | bit = 1 i    | zeruj bit |
| ı | Porównaj, skocz jeśli ≠   | CJNE       | A,direct,rel | A,#data,re | Rr,#data,r | el @Ri,#   | data,rel (O<            | <b>⊐</b> ⇒C= | :1)       |
| ı | Zmniejsz, skocz jeśli ≠ 0 | DJNZ       | Rr,rel       | direct,rel |            |            |                         |              |           |
| ı | Niczego nie rób           | NOP1)      |              |            |            |            |                         |              |           |

## Rejestry specjalne 8051

| Adres | Symbol | Bit 7 | Bit 6   | Bit 5 | Bit 4 | Bit 3 | Bit 2   | Bit 1 | Bit 0 |
|-------|--------|-------|---------|-------|-------|-------|---------|-------|-------|
| F0    | В      |       |         |       |       |       |         |       |       |
| E0    | Acc    |       |         |       |       |       |         |       |       |
| D0    | PSW    | CY    | AC      | F0    | RS1   | RS0   | OV      | _     | Р     |
| B8    | IP     | _     | -       | -     | PS    | PT1   | PX1     | PT0   | PX0   |
| B0    | P3     | /RD   | /WR     | T1    | T0    | /INT1 | /INT0   | TxD   | RxD   |
| A8    | IE     | EA    | -       | -     | ES    | ET1   | EX1     | ET0   | EX0   |
| A0    | P2     |       |         |       |       |       |         |       |       |
| 99    | SBUF   |       |         |       |       |       |         |       |       |
| 98    | SCON   | SM0   | SM1     | SM2   | REN   | TB8   | RB8     | TI    | RI    |
| 90    | P1     |       |         |       |       |       |         |       |       |
| 8D    | TH1    |       |         |       |       |       |         |       |       |
| 8C    | TH0    |       |         |       |       |       |         |       |       |
| 8B    | TL1    |       |         |       |       |       |         |       |       |
| 8A    | TL0    |       |         |       |       |       |         |       |       |
| 89    | TMOD   | GATE  | C/T     | M1    | M0    | GATE  | C/T     | M1    | M0    |
|       |        |       | Timer 1 |       |       |       | Timer 0 |       |       |
| 88    | TCON   | TF1   | TR1     | TF0   | TR0   | IE1   | IT1     | IE0   | IT0   |
| 87    | PCON   | SMOD  | -       | -     | -     | GF1   | GF0     | PD    | IDL   |
| 83    | DPH    |       |         |       |       |       |         |       |       |
| 82    | DPL    |       |         |       |       |       |         |       |       |
| 81    | SP     |       |         |       |       |       |         |       |       |
| 80    | P0     |       |         |       |       |       |         |       |       |

## Przerwania

| Γ | Zródło        | Poziom(0)  |         | Obsługa  | Adres   |            | Poziom     |           |
|---|---------------|------------|---------|----------|---------|------------|------------|-----------|
|   | przerwania    | /zbocze(1) | Flaga   | flagi    | obsługi | Zezwolenie | priorytetu | Priorytet |
| Ī | Linia INT0    | IT0        | IE0     | hardware | 03H     | EX0        | PX0        | najwyższy |
|   | Timer 0       | -          | TF0     | hardware | 0BH     | ET0        | PT0        |           |
|   | Linia INT1    | IT1        | IE1     | hardware | 13H     | EX1        | PX1        |           |
|   | Timer 1       | -          | TF1     | hardware | 1BH     | ET1        | PT1        |           |
|   | Transm. szer. | _          | R1 i T1 | software | 23H     | ES         | PS         | najniższy |

Timery

|    | ,  |      |                       |                     |
|----|----|------|-----------------------|---------------------|
| M1 | MO | Tryb | Opis                  | Flagi               |
| 0  | 0  | 0    | 8 bit THx + 5 bit TLx | TRx, TFx, GATE, C/T |
| 0  | 1  | 1    | 16 bit THx + TLx      | TRx, TFx, GATE, C/T |
| 1  | 0  | 2    | 8 bit TLx, reload THx | TRx, TFx, GATE, C/T |
| 1  | 1  | 3    | 8 bit TL0             | TR0, TF0, GATE, C/T |
|    |    |      | 8 bit TH0             | TR1, TF1, GATE, C/T |
|    |    |      | Timer 1 STOP          |                     |

|       | C/T     |    |  |  |  |
|-------|---------|----|--|--|--|
| _     | 0       | 1  |  |  |  |
| INPUT | fosc/12 | Tx |  |  |  |

|       | GA  | TE         |
|-------|-----|------------|
|       | 0   | 1          |
| START | TRx | TRx & INTx |

Transmisia szeregowa

| Han | onnoja o | zcicgowa |                      |                             |  |
|-----|----------|----------|----------------------|-----------------------------|--|
| SM1 | SM0      | Tryb     | Opis                 | Prędkość                    |  |
| 0   | 0        | 0        | synchroniczna        | fosc/12                     |  |
| 0   | 1        | 1        | asynchroniczna 8 bit | ustawiona                   |  |
| 1   | 0        | 2        | asynchroniczna 9 bit | 2 <sup>SMOD</sup> * fosc/64 |  |
| 1   | 1        | 3        | asynchroniczna 9 bit | ustawiona                   |  |

| Przykładowe ustawienie – Tryb 1, 3            |
|-----------------------------------------------|
| f = 11.0592 MHz, Timer 1 - Mod 2              |
|                                               |
| TH1 = 256 * ( 2 <sup>SMOD</sup> * 28800 / V ) |
|                                               |