## GAME BOY CPU INSTRUCTIONS

| Mnemonic                             | Symbolic Operation                                                      | Comments                     | CPU Clocks ×4       | $\mathbf{Z}$   | N | Н | C |
|--------------------------------------|-------------------------------------------------------------------------|------------------------------|---------------------|----------------|---|---|---|
| 8-Bit Tran                           | sfer                                                                    |                              |                     |                |   |   |   |
| LD r, s                              | $r \leftarrow s$                                                        | s = r, n, [HL]               | r: 1, n: 2, [HL]: 2 | T              |   |   |   |
| LD d, r                              | $d \leftarrow r$                                                        |                              | r: 1, [HL]: 2       |                |   |   |   |
| LD d, n                              | $d \leftarrow n$                                                        | d = r, [HL]                  | r: 2, [HL]: 3       |                |   |   |   |
| LD A, [ss]                           | A ← [ss]                                                                | ss = BC, DE, HL, nn          | DODE III o 4        |                |   |   |   |
| LD [dd], A                           | [dd] ← A                                                                | dd = BC, DE, HL, nn          | BC,DE,HL: 2, nn: 4  |                |   |   |   |
| LD A, [C]                            | A ← [\$FF00+C]                                                          |                              | 2                   |                |   |   |   |
| LD A, [HL-]                          | $A \leftarrow [HL], HL \leftarrow HL-1$                                 |                              | 2                   | -              | - | - | - |
| LD [HL-], A                          | $[HL] \leftarrow A, HL \leftarrow HL-1$                                 |                              | 2                   | 1              |   |   |   |
| LD A, [HL+]                          | $A \leftarrow [HL], HL \leftarrow HL+1$                                 |                              | 2                   |                |   |   |   |
| LD [HL+], A                          | $[HL] \leftarrow A, HL \leftarrow HL+1$                                 |                              | 2                   |                |   |   |   |
| LDH [n], A                           | [\$FF00+n] ← A                                                          |                              | 3                   |                |   |   |   |
| LDH A, [n]                           | $A \leftarrow [\$FF00+n]$                                               |                              | 3                   |                |   |   |   |
|                                      | ,                                                                       |                              |                     |                |   |   |   |
| $16	ext{-Bit Tra} \ 	ext{LD dd, nn}$ | $rac{	ext{nsier}}{	ext{dd} \leftarrow 	ext{nn}}$                       | dd = BC, DE, HL, SP          | 3                   |                |   |   |   |
| LD [nn], SP                          | $[nn] \leftarrow SP$                                                    |                              | 5                   | 1 _            | _ | _ | _ |
| LD SP, HL                            | SP ← HL                                                                 |                              | 2                   | -              |   |   |   |
| LD HL, [SP+e]                        |                                                                         |                              | 3                   | 0              | 0 | * | * |
| PUSH ss                              | $\begin{array}{ c c c c c c c c c c c c c c c c c c c$                  | ss = BC, DE, HL, AF          | 4                   |                |   |   |   |
| F USII 88                            | $ SP \leftarrow SP-2  \leftarrow SSL,$                                  | ss = BC, DE, IIE, AI         | 4                   |                |   |   |   |
| POP dd                               | $dd_L \leftarrow [SP], dd_H \leftarrow [SP+1],$<br>$SP \leftarrow SP+2$ | dd = BC, DE, HL, AF          | 3                   | -              | - | - | - |
| ADD s                                | c & Logical A ← A + s                                                   |                              |                     | *              | 0 | * | * |
| ADC s                                | $A \leftarrow A + s + CY$                                               |                              |                     |                |   |   |   |
| SUB s                                | $A \leftarrow A - s$                                                    | 077 : 11                     |                     | *              | 1 | * | * |
| SBC s                                | $A \leftarrow A + s - CY$                                               | CY is the carry flag.        | r: 1, n: 2, [HL]: 2 | *              |   |   |   |
| AND s                                | $A \leftarrow A \wedge s$                                               | s = r, n, [HL]               |                     | T              | 0 | 1 | 0 |
| OR s                                 | $A \leftarrow A \lor s$                                                 |                              |                     | *              | 0 | 0 | 0 |
| XOR s                                | $A \leftarrow A \oplus s$                                               |                              |                     | *              | - | * | * |
| CP s                                 | A - s                                                                   |                              |                     |                | 1 |   |   |
| INC s                                | $s \leftarrow s + 1$                                                    | s = r, [HL]                  | r: 1, [HL]: 3       | *              | 0 | * | - |
| DEC s                                | $s \leftarrow s - 1$                                                    |                              |                     |                | 1 | _ | - |
| 16-Bit Ari                           |                                                                         |                              |                     |                |   |   |   |
| ADD HL, ss                           | $HL \leftarrow HL + ss$                                                 |                              | 2                   | -              | 0 | * | * |
| ADD SP, e                            | $SP \leftarrow SP + e$                                                  | ss = BC, DE, HL, SP          | 4                   | 0              | 0 | * | * |
| INC ss                               | $ss \leftarrow ss + 1$                                                  | 55 50, 52, 112, 51           | 2                   | <u> </u>       | _ | _ | _ |
| DEC ss                               | $ss \leftarrow ss - 1$                                                  |                              | 2                   |                |   |   |   |
| Miscellane                           | eous                                                                    |                              |                     |                |   |   |   |
| SWAP s                               | 7 43 0                                                                  | Swap nibbles. $s = r$ , [HL] | r: 2, [HL]: 4       | *              | 0 | 0 | 0 |
| DAA                                  | Converts A into packed BCD                                              |                              | 1                   | *              | - | 0 | * |
| CPL                                  | $A \leftarrow \overline{A}$                                             |                              | 1                   | -              | 1 | 1 | - |
| CCF                                  | $CY \leftarrow \overline{CY}$                                           | CTT : 11                     | 1                   | -              | 0 | 0 | * |
| SCF                                  | CY ← 1                                                                  | CY is the carry flag.        | 1                   | -              | 0 | 0 | * |
| NOP                                  | No operation                                                            |                              | 1                   |                |   |   |   |
| HALT                                 | Enter HALT mode                                                         |                              | 1                   |                |   |   |   |
| STOP                                 | Enter STOP mode                                                         |                              | 1                   | † <sub>-</sub> | _ | _ | _ |
| DI                                   | Disable Interrupts                                                      |                              | 1                   |                |   |   |   |
| TO 1                                 | D 11 T .                                                                | }                            |                     | ┤              |   |   |   |

1

ΕI

Enable Interrupts

## GAME BOY CPU INSTRUCTIONS

| Mnemonic Symbolic Operation | Comments | CPU Clocks ×4 | $\mathbf{Z}$ | N | Н | C |  |
|-----------------------------|----------|---------------|--------------|---|---|---|--|
|-----------------------------|----------|---------------|--------------|---|---|---|--|

## Rotates & Shifts

| RLCA  | CY 4 7 4 0 4                         |                 |                |   |   |   |   |
|-------|--------------------------------------|-----------------|----------------|---|---|---|---|
| RLA   |                                      |                 | 1              | 0 | 0 | 0 | * |
| RRCA  | <b>▶</b> 7 <b>→</b> 0 <b>▶</b> CY    |                 | 1              | 0 | 0 | 0 |   |
| RRA   | <b>▶</b> 7 <b>→</b> 0 <b>▶</b> CY    |                 |                |   |   |   |   |
| RLC s | CY 4 7 4 0 4                         |                 |                |   |   |   |   |
| RL s  |                                      | s = A, r, [HL]  | r: 2, [HL]: 4  |   |   |   |   |
| RRC s | <b>▶</b> 7 <b>→</b> 0 <b>▶</b> CY    | s = A, 1, [IID] | 1. 2, [110]. 4 |   |   |   |   |
| RR s  | <b>▶</b> 7 <b>→</b> 0 <b>▶</b> CY    |                 |                | * | 0 | 0 | * |
| SLA s | CY ← 7 ← 0 ← 0                       |                 |                |   |   |   |   |
| SRA s | <b>▶</b> [7 <b>→</b> 0 <b>→</b> [CY] | s = r, [HL]     | r: 2, [HL]: 4  |   |   |   |   |
| SRL s | 0 → [7 → 0] → [CY]                   |                 |                |   |   |   |   |

# **Bit Operations**

| BIT b, s | $Z \leftarrow \overline{s_b}$ |                                | r: 2, [HL]: 3 | * | 0 | 1 | - |
|----------|-------------------------------|--------------------------------|---------------|---|---|---|---|
| SET b, s | $s_b \leftarrow 1$            | Z is zero flag. $s = r$ , [HL] | r: 2, [HL]: 4 | _ |   |   |   |
| RES b, s | $s_b \leftarrow 0$            |                                |               | _ | _ | _ | _ |

# Jumps

| JP nn     | PC ← nn                               | 4                       |   |   |   |   |
|-----------|---------------------------------------|-------------------------|---|---|---|---|
| JP cc, nn | If cc is true, PC ← nn                | If cc is true, 4 else 3 |   |   |   |   |
| JP HL     | $PC \leftarrow HL$                    | 1                       | - | - | - | - |
| JR e      | $PC \leftarrow PC + e$                | 3                       |   |   |   |   |
| JR cc, e  | If cc is true, $PC \leftarrow PC + e$ | If cc is true, 3 else 2 |   |   |   |   |

## Calls & Returns

| CALL nn     | $[SP-1] \leftarrow PC_H, [SP-2] \leftarrow PC_L,$                                 | 6                       |   |   |   |   |
|-------------|-----------------------------------------------------------------------------------|-------------------------|---|---|---|---|
|             | $SP \leftarrow SP-2$                                                              |                         |   |   |   |   |
| CALL cc, nn | If cc is true, same as CALL nn                                                    | If cc is true, 6 else 3 |   |   |   |   |
| RST f       | $[SP-1] \leftarrow PC_H, [SP-2] \leftarrow PC_L, SP$                              | 4                       |   |   |   |   |
|             | $\leftarrow$ SP-2, PC <sub>H</sub> $\leftarrow$ 0, PC <sub>L</sub> $\leftarrow$ f |                         | - | - | - | - |
| RET         | $PC_L \leftarrow [SP], PC_H \leftarrow [SP+1],$                                   | 4                       |   |   |   |   |
|             | $SP \leftarrow SP+2$                                                              |                         |   |   |   |   |
| RET cc      | If cc is true, same as RET                                                        | If cc is true, 5 else 2 |   |   |   |   |
| RETI        | RET then enable interrupts                                                        | 4                       |   |   |   |   |
|             |                                                                                   |                         |   |   |   |   |

#### Terminology

| -              | Flag is not affected by this operation.                |
|----------------|--------------------------------------------------------|
| *              | Flag is affected according to result of operation.     |
| b              | A bit number in any 8-bit register or memory location. |
| СС             | Flag condition code: C, NC, Z, NZ                      |
| d              | Any 8-bit destination register or memory location.     |
| dd             | Any 16-bit destination register or memory location.    |
| е              | 8-bit signed offset (-128 to 127).                     |
| f              | Special call location in page zero (00h, 08h 38h).     |
| n              | Any 8-bit integer constant.                            |
| nn             | Any 16-bit integer constant.                           |
| r              | Any 8-bit register (A, B, C, D, E, H or L).            |
| S              | Any 8-bit source register or memory location.          |
| s <sub>b</sub> | A bit in a specific 8-bit register or memory location. |
| SS             | Any 16-bit source register or memory location.         |
|                |                                                        |

#### Flags

| riags |            |  |  |  |  |
|-------|------------|--|--|--|--|
| Z     | Zero       |  |  |  |  |
| N     | Subtract   |  |  |  |  |
| Н     | Half Carry |  |  |  |  |
| С     | Carry      |  |  |  |  |