

## Gameboy CPU (LR35902) instruction set

|    | x0                               | x1                               | x2                               | x3                               | x4                               | x5                                | x6                                  | x7                                | x8                                    | x9                               | xA                                 | xB                                | xC                                | xD                               | xE                                  | xF                                |                                   |
|----|----------------------------------|----------------------------------|----------------------------------|----------------------------------|----------------------------------|-----------------------------------|-------------------------------------|-----------------------------------|---------------------------------------|----------------------------------|------------------------------------|-----------------------------------|-----------------------------------|----------------------------------|-------------------------------------|-----------------------------------|-----------------------------------|
| 0x | NOP<br>1 4<br>---                | LD BC,d16<br>3 12<br>---         | LD (BC),A<br>1 8<br>---          | INC BC<br>1 8<br>---             | INC B<br>1 4<br>Z 0 H -          | DEC B<br>1 4<br>Z 1 H -           | LD B,d8<br>2 8<br>---               | RLCA<br>1 4<br>0 0 0 C            | LD (a16),SP<br>3 20<br>---            | ADD HL,BC<br>1 8<br>- 0 H C      | LD A,(BC)<br>1 8<br>---            | DEC BC<br>1 8<br>---              | INC C<br>1 4<br>Z 0 H -           | DEC C<br>1 4<br>Z 1 H -          | LD C,d8<br>2 8<br>---               | RRCA<br>1 4<br>0 0 0 C            |                                   |
| 1x | STOP 0<br>2 4<br>---             | LD DE,d16<br>3 12<br>---         | LD (DE),A<br>1 8<br>---          | INC DE<br>1 8<br>---             | INC D<br>1 4<br>Z 0 H -          | DEC D<br>1 4<br>Z 1 H -           | LD D,d8<br>2 8<br>0 0 0 C           | RLA<br>1 4<br>---                 | JR r8<br>2 12<br>0 H C                | ADD HL,DE<br>1 8<br>- 0 H C      | LD A,(DE)<br>1 8<br>---            | DEC DE<br>1 8<br>---              | INC E<br>1 4<br>Z 0 H -           | DEC E<br>1 4<br>Z 1 H -          | LD E,d8<br>2 8<br>---               | RRA<br>1 4<br>0 0 0 C             |                                   |
| 2x | JR NZ,r8<br>2 12/8<br>---        | LD HL,d16<br>3 12<br>---         | LD (HL+),A<br>1 8<br>---         | INC HL<br>1 4<br>Z 0 H -         | INC H<br>1 4<br>Z 1 H -          | DEC H<br>1 4<br>Z 0 H -           | LD H,d8<br>2 8<br>Z - 0 C           | DAA<br>1 4<br>---                 | JR Z,r8<br>2 12/8<br>- 0 H C          | ADD HL,HL<br>1 8<br>- 0 H C      | LD A,(HL+)<br>1 8<br>---           | DEC HL<br>1 8<br>---              | INC L<br>1 4<br>Z 0 H -           | DEC L<br>1 4<br>Z 1 H -          | LD L,d8<br>2 8<br>---               | CPL<br>1 4<br>- 1 1 -             |                                   |
| 3x | JR NC,r8<br>2 12/8<br>---        | LD SP,d16<br>3 12<br>---         | LD (HL-),A<br>1 8<br>---         | INC SP<br>1 8<br>Z 0 H -         | INC (HL)<br>1 12<br>Z 1 H -      | DEC (HL)<br>1 12<br>Z 1 H -       | LD (HL),d8<br>2 12<br>- 0 0 1       | SCF<br>1 4<br>---                 | JR C,r8<br>2 12/8<br>- 0 H C          | ADD HL,SP<br>1 8<br>- 0 H C      | LD A,(HL-)<br>1 8<br>---           | DEC SP<br>1 8<br>---              | INC A<br>1 4<br>Z 0 H -           | DEC A<br>1 4<br>Z 1 H -          | LD A,d8<br>2 8<br>-                 | CCF<br>1 4<br>- 0 0 C             |                                   |
| 4x | LD B,B<br>1 4<br>---             | LD B,C<br>1 4<br>---             | LD B,D<br>1 4<br>---             | LD B,E<br>1 4<br>---             | LD B,H<br>1 4<br>---             | LD B,L<br>1 4<br>---              | LD B,(HL)<br>1 8<br>---             | LD B,A<br>1 4<br>---              | LD C,B<br>1 4<br>---                  | LD C,C<br>1 4<br>---             | LD C,D<br>1 4<br>---               | LD C,E<br>1 4<br>---              | LD C,H<br>1 4<br>---              | LD C,L<br>1 4<br>---             | LD C,(HL)<br>1 8<br>---             | LD C,A<br>1 4<br>---              |                                   |
| 5x | LD D,B<br>1 4<br>---             | LD D,C<br>1 4<br>---             | LD D,D<br>1 4<br>---             | LD D,E<br>1 4<br>---             | LD D,H<br>1 4<br>---             | LD D,L<br>1 4<br>---              | LD D,(HL)<br>1 8<br>---             | LD D,A<br>1 4<br>---              | LD E,B<br>1 4<br>---                  | LD E,C<br>1 4<br>---             | LD E,D<br>1 4<br>---               | LD E,E<br>1 4<br>---              | LD E,H<br>1 4<br>---              | LD E,L<br>1 4<br>---             | LD E,(HL)<br>1 8<br>---             | LD E,A<br>1 4<br>---              |                                   |
| 6x | LD H,B<br>1 4<br>---             | LD H,C<br>1 4<br>---             | LD H,D<br>1 4<br>---             | LD H,E<br>1 4<br>---             | LD H,H<br>1 4<br>---             | LD H,L<br>1 8<br>---              | LD H,(HL)<br>1 8<br>---             | LD H,A<br>1 4<br>---              | LD L,B<br>1 4<br>---                  | LD L,C<br>1 4<br>---             | LD L,D<br>1 4<br>---               | LD L,E<br>1 4<br>---              | LD L,H<br>1 4<br>---              | LD L,L<br>1 4<br>---             | LD L,(HL)<br>1 8<br>---             | LD L,A<br>1 4<br>---              |                                   |
| 7x | LD (HL),B<br>1 8<br>---          | LD (HL),C<br>1 8<br>---          | LD (HL),D<br>1 8<br>---          | LD (HL),E<br>1 8<br>---          | LD (HL),H<br>1 8<br>---          | HALT<br>---                       | LD (HL),A<br>1 4<br>---             | LD A,B<br>1 8<br>---              | LD A,C<br>1 4<br>---                  | LD A,D<br>1 4<br>---             | LD A,E<br>1 4<br>---               | LD A,H<br>1 4<br>---              | LD A,L<br>1 4<br>---              | LD A,(HL)<br>1 8<br>---          | LD A,A<br>1 4<br>---                |                                   |                                   |
| 8x | ADD A,B<br>1 4<br>Z 0 H C<br>--- | ADD A,C<br>1 4<br>Z 0 H C<br>--- | ADD A,D<br>1 4<br>Z 0 H C<br>--- | ADD A,E<br>1 4<br>Z 0 H C<br>--- | ADD A,H<br>1 4<br>Z 0 H C<br>--- | ADD A,L<br>1 4<br>Z 0 H C<br>---  | ADD A,(HL)<br>1 8<br>Z 0 H C<br>--- | ADD A,A<br>1 4<br>Z 0 H C<br>---  | ADC A,B<br>1 4<br>Z 0 H C<br>---      | ADC A,C<br>1 4<br>Z 0 H C<br>--- | ADC A,D<br>1 4<br>Z 0 H C<br>---   | ADC A,E<br>1 4<br>Z 0 H C<br>---  | ADC A,H<br>1 4<br>Z 0 H C<br>---  | ADC A,L<br>1 4<br>Z 0 H C<br>--- | ADC A,(HL)<br>1 8<br>Z 0 H C<br>--- | ADC A,A<br>1 4<br>Z 0 H C<br>---  |                                   |
| 9x | SUB B<br>1 4<br>Z 1 H C<br>---   | SUB C<br>1 4<br>Z 1 H C<br>---   | SUB D<br>1 4<br>Z 1 H C<br>---   | SUB E<br>1 4<br>Z 1 H C<br>---   | SUB H<br>1 4<br>Z 1 H C<br>---   | SUB L<br>1 4<br>Z 1 H C<br>---    | SUB (HL)<br>1 8<br>Z 1 H C<br>---   | SUB A<br>1 4<br>Z 1 H C<br>---    | SBC A,B<br>1 4<br>Z 1 H C<br>---      | SBC A,C<br>1 4<br>Z 1 H C<br>--- | SBC A,D<br>1 4<br>Z 1 H C<br>---   | SBC A,E<br>1 4<br>Z 1 H C<br>---  | SBC A,H<br>1 4<br>Z 1 H C<br>---  | SBC A,L<br>1 4<br>Z 1 H C<br>--- | SBC A,(HL)<br>1 8<br>Z 1 H C<br>--- | SBC A,A<br>1 4<br>Z 1 H C<br>---  |                                   |
| Ax | AND B<br>1 4<br>Z 0 1 0<br>---   | AND C<br>1 4<br>Z 0 1 0<br>---   | AND D<br>1 4<br>Z 0 1 0<br>---   | AND E<br>1 4<br>Z 0 1 0<br>---   | AND H<br>1 4<br>Z 0 1 0<br>---   | AND L<br>1 4<br>Z 0 1 0<br>---    | AND (HL)<br>1 8<br>Z 0 1 0<br>---   | AND A<br>1 4<br>Z 0 0 0<br>---    | XOR B<br>1 4<br>Z 0 0 0<br>---        | XOR C<br>1 4<br>Z 0 0 0<br>---   | XOR D<br>1 4<br>Z 0 0 0<br>---     | XOR E<br>1 4<br>Z 0 0 0<br>---    | XOR H<br>1 4<br>Z 0 0 0<br>---    | XOR L<br>1 4<br>Z 0 0 0<br>---   | XOR (HL)<br>1 8<br>Z 0 0 0<br>---   | XOR A<br>1 4<br>Z 0 0 0<br>---    |                                   |
| Bx | OR B<br>1 4<br>Z 0 0 0<br>---    | OR C<br>1 4<br>Z 0 0 0<br>---    | OR D<br>1 4<br>Z 0 0 0<br>---    | OR E<br>1 4<br>Z 0 0 0<br>---    | OR H<br>1 4<br>Z 0 0 0<br>---    | OR L<br>1 4<br>Z 0 0 0<br>---     | OR (HL)<br>1 8<br>Z 0 0 0<br>---    | OR A<br>1 4<br>Z 1 H C<br>---     | CP B<br>1 4<br>Z 1 H C<br>---         | CP C<br>1 4<br>Z 1 H C<br>---    | CP D<br>1 4<br>Z 1 H C<br>---      | CP E<br>1 4<br>Z 1 H C<br>---     | CP H<br>1 4<br>Z 1 H C<br>---     | CP L<br>1 4<br>Z 1 H C<br>---    | CP (HL)<br>1 8<br>Z 1 H C<br>---    | CP A<br>1 4<br>Z 1 H C<br>---     |                                   |
| Cx | RET NZ<br>1 20/8<br>---          | POP BC<br>1 12<br>---            | JPNZ,a16<br>3 16/12<br>---       | JPa16<br>3 16<br>---             | CALL NZ,a16<br>3 24/12<br>---    | PUSH BC<br>1 16<br>Z 0 H C<br>--- | ADD A,d8<br>2 8<br>Z 0 H C<br>---   | RST 00H<br>2 8<br>Z 0 H C<br>---  | RET Z<br>1 16<br>1 20/8<br>---        | RET<br>1 16<br>1 20/8<br>---     | RET<br>1 16<br>1 20/8<br>---       | RETI<br>1 16<br>1 20/8<br>---     | JP Z,a16<br>3 16/12<br>1 4<br>--- | PREFIX CB<br>1 4<br>---          | CALL Z,a16<br>3 24/12<br>---        | CALL a16<br>3 24<br>---           | ADC A,d8<br>2 8<br>Z 0 H C<br>--- |
| Dx | RET NC<br>1 20/8<br>---          | POP DE<br>1 12<br>---            | JPNCA16<br>3 16/12<br>---        |                                  | CALL NC,a16<br>3 24/12<br>---    | PUSH DE<br>1 16<br>Z 1 H C<br>--- | SUB d8<br>2 8<br>Z 1 H C<br>---     | RST 10H<br>2 8<br>Z 1 H C<br>---  | RET C<br>1 16<br>1 20/8<br>---        | RET C<br>1 16<br>1 20/8<br>---   | RETI<br>1 16<br>1 20/8<br>---      | JP C,a16<br>3 16/12<br>1 4<br>--- |                                   | CALL C,a16<br>3 24/12<br>---     |                                     | SBC A,d8<br>2 8<br>Z 1 H C<br>--- |                                   |
| Ex | LDH A,(a8),A<br>2 12<br>---      | POP HL<br>1 12<br>---            | LD (C),A<br>2 8<br>---           |                                  |                                  | PUSH HL<br>1 16<br>Z 0 1 0<br>--- | AND d8<br>2 8<br>Z 0 1 0<br>---     | RST 20H<br>2 8<br>Z 0 1 0<br>---  | ADD SP,r8<br>2 16<br>0 0 H C<br>---   | JP (HL)<br>2 16<br>1 4<br>---    | LD A,(a16),A<br>3 16<br>1 4<br>--- |                                   |                                   |                                  | XOR d8<br>2 8<br>Z 0 0 0<br>---     | RST 28H<br>1 16<br>Z 0 0 0<br>--- |                                   |
| Fx | LDH A,(a8)<br>2 12<br>---        | POP AF<br>1 12<br>Z N H C<br>--- | LD A,(C)<br>2 8<br>---           | DI<br>1 4<br>---                 |                                  | PUSH AF<br>1 16<br>Z 0 0 0<br>--- | OR d8<br>2 8<br>Z 0 0 0<br>---      | RST 30H<br>1 16<br>Z 0 0 0<br>--- | LD HL,SP+r8<br>2 12<br>0 0 H C<br>--- | LD SP,HL<br>1 8<br>---           | LD A,(a16)<br>3 16<br>1 4<br>---   | EI<br>1 4<br>---                  |                                   |                                  | CP d8<br>2 8<br>Z 1 H C<br>---      | RST 38H<br>1 16<br>Z 1 H C<br>--- |                                   |

## Prefix CB

|    | x0                             | x1                             | x2                             | x3                             | x4                             | x5                             | x6                                | x7                             | x8                             | x9                             | xA                             | xB                             | xC                             | xD                             | xE                                | xF                             |
|----|--------------------------------|--------------------------------|--------------------------------|--------------------------------|--------------------------------|--------------------------------|-----------------------------------|--------------------------------|--------------------------------|--------------------------------|--------------------------------|--------------------------------|--------------------------------|--------------------------------|-----------------------------------|--------------------------------|
| 0x | RLC B<br>2 8<br>Z 0 0 C<br>--- | RLC C<br>2 8<br>Z 0 0 C<br>--- | RLC D<br>2 8<br>Z 0 0 C<br>--- | RLC E<br>2 8<br>Z 0 0 C<br>--- | RLC H<br>2 8<br>Z 0 0 C<br>--- | RLC L<br>2 8<br>Z 0 0 C<br>--- | RLC (HL)<br>2 8<br>Z 0 0 C<br>--- | RLC A<br>2 8<br>Z 0 0 C<br>--- | RRC B<br>2 8<br>Z 0 0 C<br>--- | RRC C<br>2 8<br>Z 0 0 C<br>--- | RRC D<br>2 8<br>Z 0 0 C<br>--- | RRC E<br>2 8<br>Z 0 0 C<br>--- | RRC H<br>2 8<br>Z 0 0 C<br>--- | RRC L<br>2 8<br>Z 0 0 C<br>--- | RRC (HL)<br>2 8<br>Z 0 0 C<br>--- | RRC A<br>2 8<br>Z 0 0 C<br>--- |
| 1x | RL B<br>2 8<br>Z 0 0 C<br>---  | RL C<br>2 8<br>Z 0 0 C<br>---  | RL D<br>2 8<br>Z 0 0 C<br>---  | RL E<br>2 8<br>Z 0 0 C<br>---  | RL H<br>2 8<br>Z 0 0 C<br>---  | RL L<br>2 8<br>Z 0 0 C<br>---  | RL (HL)<br>2 8<br>Z 0 0 C<br>---  | RL A<br>2 8<br>Z 0 0 C<br>---  | RR B<br>2 8<br>Z 0 0 C<br>---  | RR C<br>2 8<br>Z 0 0 C<br>---  | RR D<br>2 8<br>Z 0 0 C<br>---  | RR E<br>2 8<br>Z 0 0 C<br>---  | RR H<br>2 8<br>Z 0 0 C<br>---  | RR L<br>2 8<br>Z 0 0 C<br>---  | RR (HL)<br>2 8<br>Z 0 0 C<br>---  | RR A<br>2 8<br>Z 0 0 C<br>---  |
| 2x | SLA B<br>2 8<br>Z 0 0 C<br>--- | SLA C<br>2 8<br>Z 0 0 C<br>--- | SLA D<br>2 8<br>Z 0 0 C<br>--- | SLA E<br>2 8<br>Z 0 0 C<br>--- | SLA H<br>2 8<br>Z 0 0 C<br>--- | SLA L<br>2 8<br>Z 0 0 C<br>--- | SLA (HL)<br>2 8<br>Z 0 0 C<br>--- | SLA A<br>2 8<br>Z 0 0 C<br>--- | SRA B<br>2 8<br>Z 0 0 C<br>--- | SRA C<br>2 8<br>Z 0 0 C<br>--- | SRA D<br>2 8<br>Z 0 0 C<br>--- | SRA E<br>2 8<br>Z 0 0 C<br>--- | SRA H<br>2 8<br>Z 0 0 C<br>--- | SRA L<br>2 8<br>Z 0 0 C<br>--- | SRA (HL)<br>2 8<br>Z 0 0 C<br>--- | SRA A<br>2 8<br>Z 0 0 C<br>--- |

|    |                           |                           |                           |                           |                           |                           |                               |                           |                           |                           |                           |                           |                           |                           |                               |                           |
|----|---------------------------|---------------------------|---------------------------|---------------------------|---------------------------|---------------------------|-------------------------------|---------------------------|---------------------------|---------------------------|---------------------------|---------------------------|---------------------------|---------------------------|-------------------------------|---------------------------|
| 3x | SWAP B<br>2 8<br>Z 0 0 0  | SWAP C<br>2 8<br>Z 0 0 0  | SWAP D<br>2 8<br>Z 0 0 0  | SWAP E<br>2 8<br>Z 0 0 0  | SWAP H<br>2 8<br>Z 0 0 0  | SWAP L<br>2 8<br>Z 0 0 0  | SWAP (HL)<br>2 16<br>Z 0 0 0  | SWAP A<br>2 8<br>Z 0 0 0  | SRL B<br>2 8<br>Z 0 0 C   | SRL C<br>2 8<br>Z 0 0 C   | SRL D<br>2 8<br>Z 0 0 C   | SRL E<br>2 8<br>Z 0 0 C   | SRL H<br>2 8<br>Z 0 0 C   | SRL L<br>2 8<br>Z 0 0 C   | SRL (HL)<br>2 16<br>Z 0 0 C   | SRL A<br>2 8<br>Z 0 0 C   |
| 4x | BIT 0,B<br>2 8<br>Z 0 1 - | BIT 0,C<br>2 8<br>Z 0 1 - | BIT 0,D<br>2 8<br>Z 0 1 - | BIT 0,E<br>2 8<br>Z 0 1 - | BIT 0,H<br>2 8<br>Z 0 1 - | BIT 0,L<br>2 8<br>Z 0 1 - | BIT 0,(HL)<br>2 16<br>Z 0 1 - | BIT 0,A<br>2 8<br>Z 0 1 - | BIT 1,B<br>2 8<br>Z 0 1 - | BIT 1,C<br>2 8<br>Z 0 1 - | BIT 1,D<br>2 8<br>Z 0 1 - | BIT 1,E<br>2 8<br>Z 0 1 - | BIT 1,H<br>2 8<br>Z 0 1 - | BIT 1,L<br>2 8<br>Z 0 1 - | BIT 1,(HL)<br>2 16<br>Z 0 1 - | BIT 1,A<br>2 8<br>Z 0 1 - |
| 5x | BIT 2,B<br>2 8<br>Z 0 1 - | BIT 2,C<br>2 8<br>Z 0 1 - | BIT 2,D<br>2 8<br>Z 0 1 - | BIT 2,E<br>2 8<br>Z 0 1 - | BIT 2,H<br>2 8<br>Z 0 1 - | BIT 2,L<br>2 8<br>Z 0 1 - | BIT 2,(HL)<br>2 16<br>Z 0 1 - | BIT 2,A<br>2 8<br>Z 0 1 - | BIT 3,B<br>2 8<br>Z 0 1 - | BIT 3,C<br>2 8<br>Z 0 1 - | BIT 3,D<br>2 8<br>Z 0 1 - | BIT 3,E<br>2 8<br>Z 0 1 - | BIT 3,H<br>2 8<br>Z 0 1 - | BIT 3,L<br>2 8<br>Z 0 1 - | BIT 3,(HL)<br>2 16<br>Z 0 1 - | BIT 3,A<br>2 8<br>Z 0 1 - |
| 6x | BIT 4,B<br>2 8<br>Z 0 1 - | BIT 4,C<br>2 8<br>Z 0 1 - | BIT 4,D<br>2 8<br>Z 0 1 - | BIT 4,E<br>2 8<br>Z 0 1 - | BIT 4,H<br>2 8<br>Z 0 1 - | BIT 4,L<br>2 8<br>Z 0 1 - | BIT 4,(HL)<br>2 16<br>Z 0 1 - | BIT 4,A<br>2 8<br>Z 0 1 - | BIT 5,B<br>2 8<br>Z 0 1 - | BIT 5,C<br>2 8<br>Z 0 1 - | BIT 5,D<br>2 8<br>Z 0 1 - | BIT 5,E<br>2 8<br>Z 0 1 - | BIT 5,H<br>2 8<br>Z 0 1 - | BIT 5,L<br>2 8<br>Z 0 1 - | BIT 5,(HL)<br>2 16<br>Z 0 1 - | BIT 5,A<br>2 8<br>Z 0 1 - |
| 7x | BIT 6,B<br>2 8<br>Z 0 1 - | BIT 6,C<br>2 8<br>Z 0 1 - | BIT 6,D<br>2 8<br>Z 0 1 - | BIT 6,E<br>2 8<br>Z 0 1 - | BIT 6,H<br>2 8<br>Z 0 1 - | BIT 6,L<br>2 8<br>Z 0 1 - | BIT 6,(HL)<br>2 16<br>Z 0 1 - | BIT 6,A<br>2 8<br>Z 0 1 - | BIT 7,B<br>2 8<br>Z 0 1 - | BIT 7,C<br>2 8<br>Z 0 1 - | BIT 7,D<br>2 8<br>Z 0 1 - | BIT 7,E<br>2 8<br>Z 0 1 - | BIT 7,H<br>2 8<br>Z 0 1 - | BIT 7,L<br>2 8<br>Z 0 1 - | BIT 7,(HL)<br>2 16<br>Z 0 1 - | BIT 7,A<br>2 8<br>Z 0 1 - |
| 8x | RES 0,B<br>2 8<br>- - -   | RES 0,C<br>2 8<br>- - -   | RES 0,D<br>2 8<br>- - -   | RES 0,E<br>2 8<br>- - -   | RES 0,H<br>2 8<br>- - -   | RES 0,L<br>2 8<br>- - -   | RES 0,(HL)<br>2 16<br>- - -   | RES 0,A<br>2 8<br>- - -   | RES 1,B<br>2 8<br>- - -   | RES 1,C<br>2 8<br>- - -   | RES 1,D<br>2 8<br>- - -   | RES 1,E<br>2 8<br>- - -   | RES 1,H<br>2 8<br>- - -   | RES 1,L<br>2 8<br>- - -   | RES 1,(HL)<br>2 16<br>- - -   | RES 1,A<br>2 8<br>- - -   |
| 9x | RES 2,B<br>2 8<br>- - -   | RES 2,C<br>2 8<br>- - -   | RES 2,D<br>2 8<br>- - -   | RES 2,E<br>2 8<br>- - -   | RES 2,H<br>2 8<br>- - -   | RES 2,L<br>2 8<br>- - -   | RES 2,(HL)<br>2 16<br>- - -   | RES 2,A<br>2 8<br>- - -   | RES 3,B<br>2 8<br>- - -   | RES 3,C<br>2 8<br>- - -   | RES 3,D<br>2 8<br>- - -   | RES 3,E<br>2 8<br>- - -   | RES 3,H<br>2 8<br>- - -   | RES 3,L<br>2 8<br>- - -   | RES 3,(HL)<br>2 16<br>- - -   | RES 3,A<br>2 8<br>- - -   |
| Ax | RES 4,B<br>2 8<br>- - -   | RES 4,C<br>2 8<br>- - -   | RES 4,D<br>2 8<br>- - -   | RES 4,E<br>2 8<br>- - -   | RES 4,H<br>2 8<br>- - -   | RES 4,L<br>2 8<br>- - -   | RES 4,(HL)<br>2 16<br>- - -   | RES 4,A<br>2 8<br>- - -   | RES 5,B<br>2 8<br>- - -   | RES 5,C<br>2 8<br>- - -   | RES 5,D<br>2 8<br>- - -   | RES 5,E<br>2 8<br>- - -   | RES 5,H<br>2 8<br>- - -   | RES 5,L<br>2 8<br>- - -   | RES 5,(HL)<br>2 16<br>- - -   | RES 5,A<br>2 8<br>- - -   |
| Bx | RES 6,B<br>2 8<br>- - -   | RES 6,C<br>2 8<br>- - -   | RES 6,D<br>2 8<br>- - -   | RES 6,E<br>2 8<br>- - -   | RES 6,H<br>2 8<br>- - -   | RES 6,L<br>2 8<br>- - -   | RES 6,(HL)<br>2 16<br>- - -   | RES 6,A<br>2 8<br>- - -   | RES 7,B<br>2 8<br>- - -   | RES 7,C<br>2 8<br>- - -   | RES 7,D<br>2 8<br>- - -   | RES 7,E<br>2 8<br>- - -   | RES 7,H<br>2 8<br>- - -   | RES 7,L<br>2 8<br>- - -   | RES 7,(HL)<br>2 16<br>- - -   | RES 7,A<br>2 8<br>- - -   |
| Cx | 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<br>- - -   | SET 0,(HL)<br>2 16<br>- - -   | SET 0,A<br>2 8<br>- - -   | SET 1,B<br>2 8<br>- - -   | SET 1,C<br>2 8<br>- - -   | SET 1,D<br>2 8<br>- - -   | SET 1,E<br>2 8<br>- - -   | SET 1,H<br>2 8<br>- - -   | SET 1,L<br>2 8<br>- - -   | SET 1,(HL)<br>2 16<br>- - -   | SET 1,A<br>2 8<br>- - -   |
| Dx | SET 2,B<br>2 8<br>- - -   | SET 2,C<br>2 8<br>- - -   | SET 2,D<br>2 8<br>- - -   | SET 2,E<br>2 8<br>- - -   | SET 2,H<br>2 8<br>- - -   | SET 2,L<br>2 8<br>- - -   | SET 2,(HL)<br>2 16<br>- - -   | SET 2,A<br>2 8<br>- - -   | SET 3,B<br>2 8<br>- - -   | SET 3,C<br>2 8<br>- - -   | SET 3,D<br>2 8<br>- - -   | SET 3,E<br>2 8<br>- - -   | SET 3,H<br>2 8<br>- - -   | SET 3,L<br>2 8<br>- - -   | SET 3,(HL)<br>2 16<br>- - -   | SET 3,A<br>2 8<br>- - -   |
| Ex | SET 4,B<br>2 8<br>- - -   | SET 4,C<br>2 8<br>- - -   | SET 4,D<br>2 8<br>- - -   | SET 4,E<br>2 8<br>- - -   | SET 4,H<br>2 8<br>- - -   | SET 4,L<br>2 8<br>- - -   | SET 4,(HL)<br>2 16<br>- - -   | SET 4,A<br>2 8<br>- - -   | SET 5,B<br>2 8<br>- - -   | SET 5,C<br>2 8<br>- - -   | SET 5,D<br>2 8<br>- - -   | SET 5,E<br>2 8<br>- - -   | SET 5,H<br>2 8<br>- - -   | SET 5,L<br>2 8<br>- - -   | SET 5,(HL)<br>2 16<br>- - -   | SET 5,A<br>2 8<br>- - -   |
| Fx | SET 6,B<br>2 8<br>- - -   | SET 6,C<br>2 8<br>- - -   | SET 6,D<br>2 8<br>- - -   | SET 6,E<br>2 8<br>- - -   | SET 6,H<br>2 8<br>- - -   | SET 6,L<br>2 8<br>- - -   | SET 6,(HL)<br>2 16<br>- - -   | SET 6,A<br>2 8<br>- - -   | SET 7,B<br>2 8<br>- - -   | SET 7,C<br>2 8<br>- - -   | SET 7,D<br>2 8<br>- - -   | SET 7,E<br>2 8<br>- - -   | SET 7,H<br>2 8<br>- - -   | SET 7,L<br>2 8<br>- - -   | SET 7,(HL)<br>2 16<br>- - -   | SET 7,A<br>2 8<br>- - -   |

Misc/control instructions  
 Jumps/calls  
 8bit load/store/move instructions  
 16bit load/store/move instructions  
 8bit arithmetic/logical instructions  
 16bit arithmetic/logical instructions  
 8bit rotationsshifts and bit instructions

Length in bytes → INS reg  
2 8  
Z N H C ← Instruction mnemonic  
 ← Duration in cycles  
 ← Flags affected

Duration of conditional calls and returns is different when action is taken or not. This is indicated by two numbers separated by "/". The higher number (on the left side of "/") means duration of instruction when action is taken, the lower number (on the right side of "/") means duration of instruction when action is not taken.

Instruction STOP has according to manuals opcode **10 00** and thus is 2 bytes long. Anyhow it seems there is no reason for it so some assemblers code it simply as one byte instruction **10**. 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 it is marked by "1" it is set. If it is marked by "-" it is not changed. If it is marked by "Z", "N", "H" or "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 instructions)  
 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) |
| B               | C         |
| D               | E         |
| H               | L         |

| 15 . . . 0           |
|----------------------|
| SP (stack pointer)   |
| PC (program counter) |

**Flag register (F) bits:**

|   |   |   |   |   |   |   |   |
|---|---|---|---|---|---|---|---|
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Z | N | H | C | 0 | 0 | 0 | 0 |

**Z** - Zero Flag

**N** - Subtract Flag

**H** - Half Carry Flag

**C** - Carry Flag

**0** - Not used, always zero