# Gameboy CPU (LR35902) instruction set

|          | x0         | x1        | x2         | x3        | х4          | x5        | х6         | x7        |      |
|----------|------------|-----------|------------|-----------|-------------|-----------|------------|-----------|------|
|          | NOP        | LD BC,d16 | LD (BC),A  | INC BC    | INC B       | DEC B     | LD B,d8    | RLCA      | LD ( |
| 0x       | 1 4        | 3 12      | 1 8        | 1 8       | 1 4         | 1 4       | 2 8        | 1 4       | 2    |
|          |            |           |            |           | Z 0 H -     | Z 1 H -   |            | 000C      | -    |
|          | STOP 0     | LD DE,d16 | LD (DE),A  | INC DE    | INC D       | DEC D     | LD D,d8    | RLA       |      |
| 1x       | 2 4        | 3 12      | 1 8        | 1 8       | 1 4         | 1 4       | 2 8        | 1 4       | - 1  |
|          |            |           |            |           | Z 0 H -     | Z 1 H -   |            | 000C      | -    |
|          | JR NZ,r8   | LD HL,d16 | LD (HL+),A | INC HL    | INC H       | DEC H     | LD H,d8    | DAA       | JF   |
| 2x       | 2 12/8     | 3 12      | 1 8        | 1 8       | 1 4         | 1 4       | 2 8        | 1 4       | 2    |
|          |            |           |            |           | Z 0 H -     | Z 1 H -   |            | Z - 0 C   | -    |
|          | JR NC,r8   | LD SP,d16 | LD (HL-),A | INC SP    | INC (HL)    | DEC (HL)  | LD (HL),d8 | SCF       | JF   |
| 3x       | 2 12/8     | 3 12      | 1 8        | 1 8       | 1 12        | 1 12      | 2 12       | 1 4       | 2    |
|          |            |           |            |           | Z 0 H -     | Z 1 H -   |            | -001      | -    |
|          | LD B,B     | LD B,C    | LD B,D     | LD B,E    | LD B,H      | LD B,L    | LD B,(HL)  | LD B,A    | L    |
| 4x       | 1 4        | 1 4       | 1 4        | 1 4       | 1 4         | 1 4       | 1 8        | 1 4       |      |
|          |            |           |            |           |             |           |            |           | -    |
|          | LD D,B     | LD D,C    | LD D,D     | LD D,E    | LD D,H      | LD D,L    | LD D,(HL)  | LD D,A    | L    |
| 5x       | 1 4        | 1 4       | 1 4        | 1 4       | 1 4         | 1 4       | 1 8        | 1 4       |      |
|          |            |           |            |           |             |           |            |           | -    |
|          | LD H,B     | LD H,C    | LD H,D     | LD H,E    | LD H,H      | LD H,L    | LD H,(HL)  | LD H,A    | L    |
| 6x       | 1 4        | 1 4       | 1 4        | 1 4       | 1 4         | 1 4       | 1 8        | 1 4       |      |
|          |            |           |            |           |             |           |            |           | _    |
|          | LD (HL),B  | LD (HL),C | LD (HL),D  | LD (HL),E | LD (HL),H   | LD (HL),L | HALT       | LD (HL),A | L    |
| 7x       | 1 8        | 1 8       | 1 8        | 1 8       | 1 8         | 1 8       | 1 4        | 1 8       |      |
|          |            |           |            |           |             |           |            |           | _    |
|          | ADD A,B    | ADD A,C   | ADD A,D    | ADD A,E   | ADD A,H     | ADD A,L   | ADD A,(HL) | ADD A,A   | ΑI   |
| 8x       | 1 4        | 1 4       | 1 4        | 1 4       | 1 4         | 1 4       | 1 8        | 1 4       |      |
|          | z 0 н с    | Z Ø Н С   | Z 0 Н С    | z ø н с   | Z 0 Н С     | z ø н с   | Z Ø Н С    | z ø н с   | z    |
|          | SUB B      | SUB C     | SUB D      | SUB E     | SUB H       | SUB L     | SUB (HL)   | SUB A     | SI   |
| 9x       | 1 4        | 1 4       | 1 4        | 1 4       | 1 4         | 1 4       | 1 8        | 1 4       |      |
|          | Z 1 H C    | Z 1 H C   | Z 1 H C    | Z 1 H C   | Z 1 H C     | Z 1 H C   | Z 1 H C    | Z 1 H C   | Z    |
|          | AND B      | AND C     | AND D      | AND E     | AND H       | AND L     | AND (HL)   | AND A     |      |
| Ax       | 1 4        | 1 4       | 1 4        | 1 4       | 1 4         | 1 4       | 1 8        | 1 4       |      |
|          | Z 0 1 0    | Z 0 1 0   | Z 0 1 0    | Z 0 1 0   | Z 0 1 0     | Z 0 1 0   | Z 0 1 0    | Z 0 1 0   | Z    |
|          | OR B       | OR C      | OR D       | OR E      | OR H        | OR L      | OR (HL)    | OR A      | _    |
| Bx       | 1 4        | 1 4       | 1 4        | 1 4       | 1 4         | 1 4       | 1 8        | 1 4       |      |
|          | Z 0 0 0    | Z 0 0 0   | Z 0 0 0    | Z 0 0 0   | Z 0 0 0     | Z 0 0 0   | Z 0 0 0    | Z 0 0 0   | Z    |
| $\Box$   | RET NZ     | POP BC    | JP NZ,a16  | JP a16    | CALL NZ,a16 | PUSH BC   | ADD A,d8   | RST 00H   | F    |
| Cx       | 1 20/8     | 1 12      | 3 16/12    | 3 16      | 3 24/12     | 1 16      | 2 8        | 1 16      | 1    |
|          |            |           |            |           |             |           | z ø н с    |           | _    |
|          | RET NC     | POP DE    | JP NC,a16  |           | CALL NC,a16 | PUSH DE   | SUB d8     | RST 10H   | -    |
| Dx       | 1 20/8     | 1 12      | 3 16/12    |           | 3 24/12     | 1 16      | 2 8        | 1 16      | 1    |
|          |            |           |            |           |             |           | Z 1 H C    |           | _    |
| $\Box$   | LDH (a8),A | POP HL    | LD (C),A   |           |             | PUSH HL   | AND d8     | RST 20H   | ADI  |
| Ex       | 2 12       | 1 12      | 2 8        |           |             | 1 16      | 2 8        | 1 16      | :    |
|          |            |           |            |           |             |           | Z 0 1 0    |           | 0    |
| $\vdash$ | LDH A,(a8) | POP AF    | LD A,(C)   | DI        |             | PUSH AF   | OR d8      | RST 30H   | LD I |
| Fx       | 2 12       | 1 12      | 2 8        | 1 4       |             | 1 16      | 2 8        | 1 16      |      |
| ` ^      |            | ZNHC      |            |           |             |           | Z 0 0 0    |           | oʻ   |
| $\vdash$ |            | 2 14 11 0 |            |           |             |           | 2000       |           |      |

### **Prefix CB**

|    | х0      | x1      | x2      | x3      | x4      | x5      | х6         | x7      |    |
|----|---------|---------|---------|---------|---------|---------|------------|---------|----|
|    | RLC B   | RLC C   | RLC D   | RLC E   | RLC H   | RLC L   | RLC (HL)   | RLC A   | F  |
| 0x | 2 8     | 2 8     | 2 8     | 2 8     | 2 8     | 2 8     | 2 16       | 2 8     |    |
|    | Z 0 0 C | Z 0 0 C | Z 0 0 C | Z 0 0 C | Z 0 0 C | Z 0 0 C | Z 0 0 C    | Z 0 0 C | Z  |
|    | RL B    | RL C    | RL D    | RL E    | RL H    | RL L    | RL (HL)    | RL A    |    |
| 1x | 2 8     | 2 8     | 2 8     | 2 8     | 2 8     | 2 8     | 2 16       | 2 8     |    |
|    | Z 0 0 C | Z 0 0 C | Z 0 0 C | Z 0 0 C | Z 0 0 C | Z 0 0 C | Z 0 0 C    | Z 0 0 C | Z  |
|    | SLA B   | SLA C   | SLA D   | SLA E   | SLA H   | SLA L   | SLA (HL)   | SLA A   | 5  |
| 2x | 2 8     | 2 8     | 2 8     | 2 8     | 2 8     | 2 8     | 2 16       | 2 8     | :  |
|    | Z 0 0 C | Z 0 0 C | Z 0 0 C | Z 0 0 C | Z 0 0 C | Z 0 0 C | Z 0 0 C    | Z 0 0 C | Z  |
|    | SWAP B  | SWAP C  | SWAP D  | SWAP E  | SWAP H  | SWAP L  | SWAP (HL)  | SWAP A  | 5  |
| 3x | 2 8     | 2 8     | 2 8     | 2 8     | 2 8     | 2 8     | 2 16       | 2 8     |    |
|    | Z 0 0 0 | Z 0 0 0 | Z 0 0 0 | Z 0 0 0 | Z 0 0 0 | Z 0 0 0 | Z 0 0 0    | Z 0 0 0 | Z  |
|    | BIT 0,B | BIT 0,C | BIT 0,D | BIT 0,E | BIT 0,H | BIT 0,L | BIT 0,(HL) | BIT 0,A | BI |
| 4x | 2 8     | 2 8     | 2 8     | 2 8     | 2 8     | 2 8     | 2 16       | 2 8     |    |
|    | Z 0 1 - | Z 0 1 - | Z 0 1 - | Z 0 1 - | Z 0 1 - | Z 0 1 - | Z 0 1 -    | Z 0 1 - | Z  |
|    | BIT 2,B | BIT 2,C | BIT 2,D | BIT 2,E | BIT 2,H | BIT 2,L | BIT 2,(HL) | BIT 2,A | BI |
| 5x | 2 8     | 2 8     | 2 8     | 2 8     | 2 8     | 2 8     | 2 16       | 2 8     |    |
|    | Z 0 1 - | Z 0 1 - | Z 0 1 - | Z 0 1 - | Z 0 1 - | Z 0 1 - | Z 0 1 -    | Z 0 1 - | Z  |
| 6x | BIT 4,B | BIT 4,C | BIT 4,D | BIT 4,E | BIT 4,H | BIT 4,L | BIT 4,(HL) | BIT 4,A | BI |
|    | 2 8     | 2 8     | 2 8     | 2 8     | 2 8     | 2 8     | 2 16       | 2 8     |    |
| 1  |         | 1       |         | l       |         | l       |            |         | l  |

#### Gameboy (LR35902) OPCODES

| 1  | Z 0 1 -            | Z 0 1 -            | Z 0 1 -            | Z 0 1 -            | Z 0 1 -            | Z 0 1 -            | Z 0 1 -                | Z 0 1 -            | Z       |
|----|--------------------|--------------------|--------------------|--------------------|--------------------|--------------------|------------------------|--------------------|---------|
| 7x | BIT 6,B<br>2 8     | BIT 6,C<br>2 8     | BIT 6,D<br>2 8     | BIT 6,E<br>2 8     | BIT 6,H<br>2 8     | BIT 6,L<br>2 8     | BIT 6,(HL)<br>2 16     | BIT 6,A<br>2 8     | BI      |
| -  | Z 0 1 -<br>RES 0.B | Z 0 1 -<br>RES 0,C | Z 0 1 -<br>RES 0.D | Z 0 1 -<br>RES 0,E | Z 0 1 -<br>RES 0.H | Z 0 1 -<br>RES 0.L | Z 0 1 -<br>RES 0,(HL)  | Z 0 1 -<br>RES 0,A | Z<br>RE |
| 8x | 2 8                | 2 8                | 2 8                | 2 8                | 2 8                | 2 8                | 2 16                   | 2 8                | -       |
| 9x | RES 2,B<br>2 8     | RES 2,C<br>2 8     | RES 2,D<br>2 8     | RES 2,E<br>2 8     | RES 2,H<br>2 8     | RES 2,L<br>2 8     | RES 2,(HL)<br>2 16     | RES 2,A<br>2 8     | RE      |
| Ax | RES 4,B<br>2 8     | RES 4,C<br>2 8     | RES 4,D<br>2 8     | RES 4,E<br>2 8     | RES 4,H<br>2 8     | RES 4,L<br>2 8     | RES 4,(HL)<br>2 16<br> | RES 4,A<br>2 8     | RE      |
| Вх | RES 6,B<br>2 8     | RES 6,C<br>2 8     | RES 6,D<br>2 8     | RES 6,E<br>2 8<br> | RES 6,H<br>2 8     | RES 6,L<br>2 8     | RES 6,(HL)<br>2 16     | RES 6,A<br>2 8     | RE      |
| Сх | SET 0,B<br>2 8<br> | SET 0,C<br>2 8<br> | SET 0,D<br>2 8<br> | SET 0,E<br>2 8<br> | SET 0,H<br>2 8<br> | SET 0,L<br>2 8     | SET 0,(HL)<br>2 16<br> | SET 0,A<br>2 8<br> | SE<br>- |
| Dx | SET 2,B<br>2 8     | SET 2,C<br>2 8     | SET 2,D<br>2 8     | SET 2,E<br>2 8     | SET 2,H<br>2 8     | SET 2,L<br>2 8     | SET 2,(HL)<br>2 16<br> | SET 2,A<br>2 8     | SE      |
| Ex | SET 4,B<br>2 8     | SET 4,C<br>2 8     | SET 4,D<br>2 8     | SET 4,E<br>2 8     | SET 4,H<br>2 8     | SET 4,L<br>2 8     | SET 4,(HL)<br>2 16<br> | SET 4,A<br>2 8     | SE<br>- |
| Fx | SET 6,B<br>2 8     | SET 6,C<br>2 8     | SET 6,D<br>2 8     | SET 6,E<br>2 8     | SET 6,H<br>2 8     | SET 6,L<br>2 8     | SET 6,(HL)<br>2 16     | SET 6,A<br>2 8     | SE      |

Misc/control instructions

Jumps/calls

8bit load/store/move instructions

16bit load/store/move instructions

8bit arithmetic/logical instructions 16bit arithmetic/logical instructions

8bit rotations/shifts and bit instructions

INS reg ← Instruction mne Length in bytes → 2 8 ← Duration in cyc ZNHC ← Flags affected

Instruction STOP has according to manuals opcode 10 00 and thus is 2 bytes long. Anyhow it seems there is no reason for it Flags affected are always shown in Z H N C order. If flag is marked by "0" it means it is reset after the instruction. If i "C" corresponding flag is affected as expected by its function.

d8 means immediate 8 bit data

d16 means immediate 16 bit data

a8 means 8 bit unsigned data, which are added to \$FF00 in certain instructions (replacement for missing IN and OUT instruc a16 means 16 bit address

r8 means 8 bit signed data, which are added to program counter

LD A,(C) has alternative mnemonic LD A,(\$FF00+C)

LD C,(A) has alternative mnemonic LD (\$FF00+C),A

LDH A, (a8) has alternative mnemonic LD A, (\$FF00+a8) LDH (a8),A has alternative mnemonic LD (\$FF00+a8),A

LD A, (HL+) has alternative mnemonic LD A, (HLI) or LDI A, (HL)

LD (HL+), A has alternative mnemonic LD (HLI), A or LDI (HL), A

LD A,(HL-) has alternative mnemonic LD A,(HLD) or LDD A,(HL)

LD (HL-),A has alternative mnemonic LD (HLD),A or LDD (HL),A

LD HL,SP+r8 has alternative mnemonic LDHL SP,r8

## Registers

| 15 8            | 7 0       |
|-----------------|-----------|
| A (accumulator) | F (flags) |
| В               | С         |
| D               | Е         |
| Н               | L         |

| 15 0                 |
|----------------------|
| SP (stack pointer)   |
| PC (program counter) |
| <u> </u>             |

### Flag register (F) bits:

| I | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---|---|---|---|---|---|---|---|---|
|   | Z | N | Н | С | 0 | 0 | 0 | 0 |

Z - Zero Flag

N - Subtract Flag

H - Half Carry Flag

C - Carry Flag

O - Not used, always zero