

## Classic gaming porn: the Game Boy

---

Gabriel Duque



## Purpose of this project

- Explore how the Game Boy actually works
- Learn about emulation and low-level details
- Discover hardware
- Nostalgia

## Table of contents

- Quick history of the Game Boy
- Game Boy specifications
- CPU
- Graphics

## A quick history of the Game Boy

- First release: 1989 (until 2005)
- Code name: DMG-01
- About 118 M sales
- ~1500 Games

## Different types of Game Boy

Original series:

- Game Boy (DMG-01): 1989
- Game Boy Pocket (MGB-001): 1996
- Game Boy Light (MGB-101): 1998
- Game Boy Color (CGB-001): 1998

Arm CPU based Game Boy (backwards compatible) :

- Game Boy Advance (AGB-001): 2001
- Game Boy Advance SP (AGS-001): 2003
- Game Boy Advance SP (AGB-101): 2005

## Specifications

- CPU: 1Mhz - 8 bits
- RAM: 8KB
- VRAM: 8KB
- Resolution: 160 x 144
- 4 colors (shades of “gray”)
- 10 sprites per line

Probably the last used 8 bit system for video games.

## Interior





- CPU core
- Interrupt controller
- Timer
- Memory management unit
- Boot ROM
- Joypad input
- Serial data transfer (not implemented)
- Sound controller (not implemented)
- Pixel processing unit

- Sort of like an Intel 8080, but not really
- Sort of like an Zilog Z80, but not really

A f\*\*\*\*\* mess!





## The CPU: Sharp LR35902



# Registers

8 bit registers:

|   |   |
|---|---|
| A | F |
| B | C |
| D | E |
| H | L |

16 bit registers:

|    |
|----|
| SP |
| PC |

Flag register:

| Z | N | H | C | - | - | - | - |

# Instructions

|    | 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>Z 0 H -         | INC B<br>1 4<br>Z 1 H -           | DEC B<br>1 4<br>Z 0 H -           | LD B,d8<br>2 8<br>0 0 0 C           | RCLA<br>1 4<br>0 0 0 C                | LD (a16),SP<br>3 20<br>0 0 0 C   | LD HL,BC<br>1 8<br>- 0 H C       | LD A,(BC)<br>1 8<br>- 0 H C      | DEC BC<br>1 4<br>- 0 H C         | 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>0 0 0 C         | RRCA<br>1 4<br>0 0 0 C |
| 1x | STOP 0<br>Z 4<br>---             | LD DE,d16<br>3 12<br>---         | LD (DE),A<br>1 8<br>---          | INC DE<br>1 4<br>Z 0 H -         | INC D<br>1 4<br>Z 1 H -           | DEC D<br>1 4<br>Z 0 H -           | LD D,d8<br>2 8<br>Z - 0 C           | RLA<br>1 4<br>-                       | JR r8<br>2 12/8<br>Z - 0 C       | ADD HL,DE<br>2 12<br>- 0 H C     | LD A,(DE)<br>1 8<br>- 0 H C      | DEC DE<br>1 4<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>0 0 0 C         | 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 8<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>-           | ADD HL,HL<br>2 12<br>- 0 H C     | LD A,(HL+)<br>1 8<br>- 0 H C     | DEC HL<br>1 4<br>-               | INC L<br>1 4<br>Z 0 H -           | DEC L<br>2 8<br>Z 1 H -          | CPL<br>1 4<br>-                   |                        |
| 3x | JR NC,r8<br>2 12/8<br>---        | LD SF,d16<br>3 12<br>---         | LD (HL),A<br>1 8<br>---          | INC SF<br>1 8<br>Z 0 H -         | INC (HL)<br>1 12<br>Z 1 H -       | DEC (HL)<br>1 12<br>Z 0 H -       | LD (HL),d8<br>2 12<br>-             | SCF<br>1 4<br>-                       | JR C,r8<br>2 12/8<br>-           | ADD HL,SP<br>2 12<br>- 0 H C     | LD A,(HL-)<br>1 8<br>- 0 H C     | DEC SP<br>1 8<br>-               | INC A<br>1 4<br>Z 0 H -           | DEC A<br>2 8<br>Z 1 H -          | LD A,d8<br>2 8<br>-               | CCF<br>1 4<br>-        |
| 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,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 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 4<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,(HL)<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 4<br>---              | LD H,(HL)<br>1 4<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,(HL)<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>---           | LD (HL),L<br>1 8<br>---           | HALT<br>1 4<br>-                    | LD (HL),A<br>1 8<br>-                 | LD A,B<br>1 4<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>-               |                                   |                        |
| 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 8<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 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 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 0 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 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 0 0 0<br>---         | CP F B<br>1 4<br>Z 0 0 0<br>---  | CP F C<br>1 4<br>Z 0 0 0<br>---  | CP F D<br>1 4<br>Z 0 0 0<br>---  | CP F E<br>1 4<br>Z 0 0 0<br>---  | CP F H<br>1 4<br>Z 0 0 0<br>---   | CP F L<br>1 4<br>Z 0 0 0<br>---  | CP A<br>1 4<br>Z 0 0 0<br>-       |                        |
| Cx | RET NZ<br>1 20/8<br>---          | POP BC<br>1 12<br>---            | JP NZ,a16<br>3 16/12<br>---      | JP a16<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>1 16<br>Z 0 H C<br>---     | RET Z<br>1 16<br>-               | RET<br>1 16<br>-                 | JP Z,a16<br>3 16/12<br>-         | PREFIX CB<br>1 4<br>-            | CALL Z,a16<br>3 24/12<br>-        | CALL a16<br>3 24<br>-            | RST 08H<br>2 8<br>Z 0 H C<br>-    |                        |
| Dx | RET NC<br>1 20/8<br>---          | POP DE<br>1 12<br>---            | JP NC,a16<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>1 16<br>Z 1 H C<br>---   | RET C<br>1 16<br>Z 1 H C<br>---       | RET I<br>1 16<br>Z 1 H C<br>---  | JP C,a16<br>3 16/12<br>-         | CALL C,a16<br>3 24/12<br>-       | CALL a16<br>3 24<br>-            | SBC A,d8<br>2 8<br>Z 1 H C<br>--- | RST 18H<br>1 16<br>Z 1 H C<br>-  |                                   |                        |
| Ey | LDB (a8),A<br>2 12<br>---        | POP HL<br>1 12<br>---            | LD (C),A<br>2 8<br>---           | DI<br>1 4<br>---                 | PUSH AF<br>1 16<br>Z 0 0 0<br>--- | OR d8<br>1 16<br>Z 0 0 0<br>---   | RST 20H<br>2 8<br>Z 0 0 0<br>---    | ADD SP,r8<br>2 16<br>0 0 H C<br>---   | JP (HL)<br>1 4<br>-              | LD A,(a16)<br>3 16<br>-          | EI<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 | LDB A,(a8)<br>2 12<br>---        | POP AF<br>1 12<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>1 16<br>Z 0 0 0<br>---   | RST 30H<br>2 8<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>-          | 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>-   |                                  |                                   |                        |

# CB-prefix

|    | 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   | RLC C<br>2 8<br>Z 0 0 C   | RLC D<br>2 8<br>Z 0 0 C   | RLC E<br>2 8<br>Z 0 0 C   | RLC F (HL)<br>2 8<br>Z 0 0 C   | RLC G (HL)<br>2 8<br>Z 0 0 C   | RLC H (HL)<br>2 8<br>Z 0 0 C | RLC I (HL)<br>2 8<br>Z 0 0 C   | RLC J (HL)<br>2 8<br>Z 0 0 C   | RLC K (HL)<br>2 8<br>Z 0 0 C   | RLC L (HL)<br>2 8<br>Z 0 0 C  | RRC A<br>2 8<br>Z 0 0 C   | RRC B<br>2 8<br>Z 0 0 C   | RRC C<br>2 8<br>Z 0 0 C   | RRC D<br>2 8<br>Z 0 0 C        | RRC E<br>2 8<br>Z 0 0 C       | RRC F (HL)<br>2 8<br>Z 0 0 C |
| 1x | RL B<br>2 8<br>Z 0 0 C    | RL C<br>2 8<br>Z 0 0 C    | RL D<br>2 8<br>Z 0 0 C    | RL E<br>2 8<br>Z 0 0 C    | RL F (HL)<br>2 8<br>Z 0 0 C    | RL G (HL)<br>2 8<br>Z 0 0 C    | RL H (HL)<br>2 8<br>Z 0 0 C  | RL I (HL)<br>2 8<br>Z 0 0 C    | RL J (HL)<br>2 8<br>Z 0 0 C    | RL K (HL)<br>2 8<br>Z 0 0 C    | RL L (HL)<br>2 8<br>Z 0 0 C   | RR B<br>2 8<br>Z 0 0 C    | RR C<br>2 8<br>Z 0 0 C    | RR D<br>2 8<br>Z 0 0 C    | RR E<br>2 8<br>Z 0 0 C         | RR F (HL)<br>2 8<br>Z 0 0 C   | RR A<br>2 16<br>Z 0 0 C      |
| 2x | SLA B<br>2 8<br>Z 0 0 C   | SLA C<br>2 8<br>Z 0 0 C   | SLA D<br>2 8<br>Z 0 0 C   | SLA E<br>2 8<br>Z 0 0 C   | SLA F (HL)<br>2 8<br>Z 0 0 C   | SLA G (HL)<br>2 8<br>Z 0 0 C   | SLA H<br>2 8<br>Z 0 0 C      | SLA I (HL)<br>2 8<br>Z 0 0 C   | SLA J (HL)<br>2 8<br>Z 0 0 C   | SLA K (HL)<br>2 8<br>Z 0 0 C   | SLA L (HL)<br>2 8<br>Z 0 0 C  | SRA B<br>2 8<br>Z 0 0 C   | SRA C<br>2 8<br>Z 0 0 C   | SRA D<br>2 8<br>Z 0 0 C   | SRA E<br>2 8<br>Z 0 0 C        | SRA F (HL)<br>2 8<br>Z 0 0 C  | SRA A<br>2 8<br>Z 0 0 C      |
| 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 F (HL)<br>2 8<br>Z 0 0 0  | SWAP G (HL)<br>2 8<br>Z 0 0 0  | SWAP H<br>2 8<br>Z 0 0 0     | SWAP I (HL)<br>2 8<br>Z 0 0 0  | SWAP J (HL)<br>2 8<br>Z 0 0 0  | SWAP K (HL)<br>2 8<br>Z 0 0 0  | SWAP L (HL)<br>2 8<br>Z 0 0 0 | SNAP A<br>2 8<br>Z 0 0 0  | SNAP B<br>2 8<br>Z 0 0 0  | SNAP C<br>2 8<br>Z 0 0 0  | SNAP D<br>2 8<br>Z 0 0 0       | SNAP E (HL)<br>2 8<br>Z 0 0 0 | SNAP A<br>2 8<br>Z 0 0 0     |
| 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,F (HL)<br>2 8<br>Z 0 1 - | BIT 0,G (HL)<br>2 8<br>Z 0 1 - | BIT 0,H<br>2 8<br>Z 0 1 -    | BIT 0,I (HL)<br>2 8<br>Z 0 1 - | BIT 0,J (HL)<br>2 8<br>Z 0 1 - | BIT 0,K (HL)<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,F (HL)<br>2 8<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,F (HL)<br>2 8<br>Z 0 1 - | BIT 2,G (HL)<br>2 8<br>Z 0 1 - | BIT 2,H<br>2 8<br>Z 0 1 -    | BIT 2,I (HL)<br>2 8<br>Z 0 1 - | BIT 2,J (HL)<br>2 8<br>Z 0 1 - | BIT 2,K (HL)<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,F (HL)<br>2 8<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,F (HL)<br>2 8<br>Z 0 1 - | BIT 4,G (HL)<br>2 8<br>Z 0 1 - | BIT 4,H<br>2 8<br>Z 0 1 -    | BIT 4,I (HL)<br>2 8<br>Z 0 1 - | BIT 4,J (HL)<br>2 8<br>Z 0 1 - | BIT 4,K (HL)<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,F (HL)<br>2 8<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,F (HL)<br>2 8<br>Z 0 1 - | BIT 6,G (HL)<br>2 8<br>Z 0 1 - | BIT 6,H<br>2 8<br>Z 0 1 -    | BIT 6,I (HL)<br>2 8<br>Z 0 1 - | BIT 6,J (HL)<br>2 8<br>Z 0 1 - | BIT 6,K (HL)<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,F (HL)<br>2 8<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,F (HL)<br>2 8<br>---     | RES 0,G (HL)<br>2 8<br>---     | RES 0,H<br>2 8<br>---        | RES 0,I (HL)<br>2 8<br>---     | RES 0,J (HL)<br>2 8<br>---     | RES 0,K (HL)<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,F (HL)<br>2 8<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,F (HL)<br>2 8<br>---     | RES 2,G (HL)<br>2 8<br>---     | RES 2,H<br>2 8<br>---        | RES 2,I (HL)<br>2 8<br>---     | RES 2,J (HL)<br>2 8<br>---     | RES 2,K (HL)<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,F (HL)<br>2 8<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,F (HL)<br>2 8<br>---     | RES 4,G (HL)<br>2 8<br>---     | RES 4,H<br>2 8<br>---        | RES 4,I (HL)<br>2 8<br>---     | RES 4,J (HL)<br>2 8<br>---     | RES 4,K (HL)<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,F (HL)<br>2 8<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,F (HL)<br>2 8<br>---     | RES 6,G (HL)<br>2 8<br>---     | RES 6,H<br>2 8<br>---        | RES 6,I (HL)<br>2 8<br>---     | RES 6,J (HL)<br>2 8<br>---     | RES 6,K (HL)<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,F (HL)<br>2 8<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,F (HL)<br>2 8<br>---     | SET 0,G (HL)<br>2 8<br>---     | SET 0,H<br>2 8<br>---        | SET 0,I (HL)<br>2 8<br>---     | SET 0,J (HL)<br>2 8<br>---     | SET 0,K (HL)<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,F (HL)<br>2 8<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,F (HL)<br>2 8<br>---     | SET 2,G (HL)<br>2 8<br>---     | SET 2,H<br>2 8<br>---        | SET 2,I (HL)<br>2 8<br>---     | SET 2,J (HL)<br>2 8<br>---     | SET 2,K (HL)<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,F (HL)<br>2 8<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,F (HL)<br>2 8<br>---     | SET 4,G (HL)<br>2 8<br>---     | SET 4,H<br>2 8<br>---        | SET 4,I (HL)<br>2 8<br>---     | SET 4,J (HL)<br>2 8<br>---     | SET 4,K (HL)<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,F (HL)<br>2 8<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,F (HL)<br>2 8<br>---     | SET 6,G (HL)<br>2 8<br>---     | SET 6,H<br>2 8<br>---        | SET 6,I (HL)<br>2 8<br>---     | SET 6,J (HL)<br>2 8<br>---     | SET 6,K (HL)<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,F (HL)<br>2 8<br>---     | SET 7,A<br>2 8<br>---         |                              |

- Jumps to fixed location in RAM
- You jump there by using special instructions

---

|      |       |
|------|-------|
| CPU  | 4 MHz |
| RAM  | 1 MHz |
| PPU  | 4 MHz |
| VRAM | 2 MHz |

---

1 machine cycle @ 1MHz

# The bootup sequence

Boot ROM

Init RAM

Init Sound

addr\_0027:

```
ld a,(de)
call $0095
call $0096
inc de
ld a,e
cp $34
jr nz, addr_0027
ld de,$00d8
ld b,$08
```

addr\_0039:

```
ld a,(de)
inc de
ld (hl),a
dec b
jr nz, addr_0039
ld a,$19
ld ($9910),a
ld hl,$992f
addr_0048:
ld c,$0c
addr_004a:
dec a
jr nz, addr_0055
ld (hl),a
dec c
jr nz, addr_004a
ld l,$0f
jr addr_0048
```

Set up Logo

addr\_0055:
ld h,a
ld a,\$64
ld d,a
ld (\$ff00+\$42),a
ld a,\$91
ld (\$ff00+\$40),a
inc b
addr\_0060:
ld e,\$02
addr\_0062:
ld c,\$0c
addr\_0064:

```
ld a,$00
ld e,$04
jr nz, addr_0064
dec c
jr nz, addr_0064
dec e
jr nz, addr_0062
ld c,$13
inc h
ld a,h
ld e,$03
cp $62
jr z, addr_0080
ld e,$01
cp $64
jr nz, addr_0086
addr_0080:
ld a,e
ld ($ff00+$42),a
addr_0086:
ld a,$ff00+$42
sub b
ld ($ff00+$42),a
dec d
```

Play Sound

addr\_0086:
ld a,\$ff00+\$42
sub b
ld (\$ff00+\$42),a
dec d
jr nz, addr\_00e0
ld d,\$20
jr addr\_0060

Scroll logo

addr\_0098:
ld c,a
ld b,\$04
push bc
rl c
rla
pop bc
addr\_00a8:
ld a,(hl),a
inc hl
ld (hl),a
inc hl
ret

```
.db $ce,$ed,$66,$66,$cc,$0d,$00,$0b
.db $03,$73,$00,$03,$00,$0c,$00,$0d
.db $01,$08,$11,$1f,$00,$0b,$00,$0e
.db $d0,$00,$00,$00,$00,$00,$00,$00
.db $bb,$0b,$0d,$0d,$0e,$0d,$0d,$0c
.db $dd,$dc,$99,$9f,$bb,$b9,$33,$3e
addr_00d8:
.db $3c,$42,$b9,$a3,$b9,$a5,$42,$3c
addr_00e0:
ld hl,$0104
ld de,$00a8
addr_00e1:
ld a,(de)
inc de
jr nz,re
inc hl
ld a,l
cp $34
jr nz, addr_00e6
ld b,$19
ld a,b
```

addr\_00e6:
ld hl,\$0104
dec b
jr nz,re
add l,(hl)
jr nz,\$fe
ld a,\$01
ld l,\$00

addr\_00e0:
ld hl,\$0104
dec b
jr nz,re
add l,(hl)
jr nz,\$fe
ld a,\$01
ld l,\$00

Decode logo

Logo data

Compare logo

Checksum header

Turn off ROM



| ROM Header         |                         |                                   |
|--------------------|-------------------------|-----------------------------------|
| <b>0100 - 0103</b> | Entry Point             | nop, jp \$0150                    |
| <b>0104 - 0133</b> | Nintendo Logo           | \$CE, \$ED, \$66, \$66, \$CC, ... |
| <b>0134 - 0143</b> | Title                   | “SUPER MARIO LAND”                |
| <b>013F - 0142</b> | Manufacturer Code       | \$00                              |
| <b>0143</b>        | CGB Flag                | \$00                              |
| <b>0144 - 0145</b> | New Licensee Code       | \$00, \$00                        |
| <b>0146</b>        | SGB Flag                | \$00                              |
| <b>0147</b>        | Cartridge Type          | \$01                              |
| <b>0148</b>        | ROM Size                | \$01                              |
| <b>0149</b>        | RAM Size                | \$00                              |
| <b>014A</b>        | Destination Code        | \$00                              |
| <b>014B</b>        | Old Licensee Code       | \$01                              |
| <b>014C</b>        | Mask ROM Version number | \$00                              |
| <b>014D</b>        | Header Checksum         | \$9E                              |
| <b>014E - 014F</b> | Global Checksum         | \$41, \$6B                        |

## Memory map



0KB

64KB

## Memory map



## Memory map



## Memory map



0KB

64KB

## Memory map



## Memory map



## Memory map



0KB

64KB

## Memory map



0KB

64KB

**ROM**

**ROM  
Bank 0**

**ROM  
Bank 1**

## Memory map



0KB

64KB

## Pixel processing unit

- 160x144 pixels
- 4 shades of “gray”
- 8x8 tiles
- 20x18 tiles
- 40 sprites (10 per line)
- 8 KB VRAM

3 grounds in graphics:

- Background
- Window
- Sprites (Nintendo calls them objects)

## Pixel processing unit



## Pixel processing unit



## Pixel processing unit



## Pixel processing unit



## Pixel processing unit



## Pixel processing unit



## Pixel processing unit



## Pixel processing unit

Actually the background is just a view of a bigger surface which is 32x32 tiles.



## Pixel processing unit



## Pixel processing unit



## Pixel processing unit



| OAM Entry          |                          |
|--------------------|--------------------------|
| <b>Position X</b>  | 0x4D                     |
| <b>Position Y</b>  | 0x78                     |
| <b>Tile Number</b> | 0x__                     |
| <b>Priority</b>    | —                        |
| <b>Flip X</b>      | <input type="checkbox"/> |
| <b>Flip Y</b>      | <input type="checkbox"/> |
| <b>Palette</b>     | —                        |

## Pixel processing unit



## Pixel processing unit



## Pixel processing unit



## Pixel processing unit



It's meme time



Just for the lulz



Just for the lulz



Just for the lulz



## Source code

If you want to check the code out:

<https://git.zuh0.com/boi>

You can send patches by mail!

It is **commented**.

Resources:

<https://github.com/gbdev/awesome-gbdev>

<http://marc.rawer.de/Gameboy/Docs/GBCPUMan.pdf>

<https://gbdev.gg8.se/files/roms/blargg-gb-tests/>