

# Gouldboy Color Project Checkpoint (1)

Maxwell J Svetlik - ms58323

March 21, 2016

## 1 Introduction

This is the first report on the Gouldboy Color gameboy emulator project. This brief overview will detail the progress seen over the last checkpoint (which is the proposal), some personal takeaways / gripes, and promised supporting material.

## 2 Progress

### 2.1 CPU Emulation

The CPU used by the Gameboy is a modified Zilog z80. Its modified in its instruction set somewhat, but also expands the amount of addressable memory by making the PC and SP registers 16-bit. It is still, however, an 8-bit CPU, though combinations of general purpose registers (which are 8-bit) can be combined to load an effective address.

Of the 255 operations described by the architecture, I've implemented all op-codes save the roughly 20 rotate and shift operations. Why have I left these out? Because I'm eager to see visual progress, and they're relatively trivial to implement but take time.

Though many of the operations defined are fairly straight forward (most if not all of the 8 and 16-bit ALU ops, etc) and require less thorough testing, some operations are vaguely specified, causing me to make an estimate on their behavior or implementation. Consequently, I've erred on the side of making general purpose functions to handle common aspects to these less understood operations, so if in the future I must correct the behavior, one fix will affect many operations. Some examples of these operations can be found in the project journal entries. In the long term, I expect this to impact performance.

In order to verify cases, I've written an interface that allows the user to place bytes in memory and directly specify the state of the CPU. While using this is tedious to verify instructions, and is by no means thorough, its been written so that it can easily be extended in the future to evaluate written test cases.

| GameBoy Memory Areas |                                                 |
|----------------------|-------------------------------------------------|
| \$FFFF               | Interrupt Enable Flag                           |
| \$FF80-\$FFFE        | Zero Page - 127 bytes                           |
| \$FF00-\$FF7F        | Hardware I/O Registers                          |
| \$FEAO-\$FEFF        | Unusable Memory                                 |
| \$FE00-\$FE9F        | OAM - Object Attribute Memory                   |
| \$E000-\$FDFF        | Echo RAM - Reserved, Do Not Use                 |
| \$D000-\$DFFF        | Internal RAM - Bank 1-7 (switchable - CGB only) |
| \$C000-\$CFFF        | Internal RAM - Bank 0 (fixed)                   |
| \$A000-\$BFFF        | Cartridge RAM (If Available)                    |
| \$9C00-\$9FFF        | BG Map Data 2                                   |
| \$9800-\$9BFF        | BG Map Data 1                                   |
| \$8000-\$97FF        | Character RAM                                   |
| \$4000-\$7FFF        | Cartridge ROM - Switchable Banks 1-xx           |
| \$0150-\$3FFF        | Cartridge ROM - Bank 0 (fixed)                  |
| \$0100-\$014F        | Cartridge Header Area                           |
| \$0000-\$00FF        | Restart and Interrupt Vectors                   |

Figure 1: A depiction of the gameboy memory map. Courtesy gameboy.mongenel.com

## 2.2 The Memory Map

The memory map of the Gameboy is defined in Figure 1. I talk below about my current interpretation of how the visual system works (which is what I hope to have partially achieved by the next checkpoint). In preparation for this, I've included skeletons of the hardware timers, and hardware interrupt systems. As such, I'm right where I predicted for this checkpoint, despite the gripes given in Section 3.2.

# 3 Takeaways and Knowledge Acquisition

## 3.1 Regarding the CPU

Implementing CPU operations was fairly straightforward. An interesting aspect, and the more challenging part of the implementation, is emulating Gameboy specific hardware. Among other things, this includes things like the Memory Controllers. The Memory Controllers are interesting in that, though there is 64kB of addressable memory, the game cartridge only has permanent access to 8kB. These 8kB are used for critical game routines that keep the whole thing running, while other 4kB and 8kB *banks* are swapped out in chunks as needed. This would hold sprites and other visual information relevant to where the player is in the game. The controllers facilitate swapping these banks.

What I've gleaned about visual output is that the screen buffer is contained within the memory map at specified addresses. This is actually an over simplification. There are a dozen visual registers contained in the memory map, double if its a Gameboy Color, since the color pallets must be specified. Writing to the screen then happens at about 60Hz and is communicated via interrupts.

### 3.2 Regarding old Specification Manuals

There exists only a single main, comprehensive resource for Gameboy emulation in the form of a fan-made manual <sup>1</sup>. Written in the early 2000s, it contains "everything you always wanted to know about the gameboy but were afraid to ask". Seemingly, other resource exist on the web, but these all seem to copy the main manual.

Though it's a valuable resource, and without it I'd be lost, I find some details lacking for more advanced functions (beyond the CPU). For instance, the details on sound emulation span a single page. Gleaning useful information on the visual or timing systems has proven to be a slow process, requiring more broad system knowledge than I expected.

## 4 Supporting Materials

### 4.1 Commit history

I couldn't get L<sup>A</sup>T<sub>E</sub>Xto play nice with the .csv, so the commit log is included as an auxillary file as **log.csv**.

### 4.2 Project Journal

Included below are notes taken in the course of implementing the z80 and (partially) the memory map.

---

<sup>1</sup><http://marc.rawer.de/Gameboy/Docs/GBCPUman.pdf>



Figure 2: Project entry 1

| SUBJECT<br>TO SHARE |                                                                                                                                                                                                                                                                                |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3/04                |                                                                                                                                                                                                                                                                                |
| 2/11                | <p>IMPLEMENTING ALU.<br/>     SHOULD LOOK AT HOW I'M SETTING HC + C FLAGS;<br/>     CONFUSION ON WHETHER CARRY FROM BCD<br/>     &amp; 17<sup>th</sup> BITS ARE ORDERED.</p>                                                                                                   |
|                     | <p><del>ADD A, n</del> ADC A, n<br/>     ADD THE CARRY BIT AFTER SETTING IT?<br/>     → OR ADD + THEN SET?<br/>     IMPLEMENTED AS, BUT [LOOK AT AGAIN!]!</p>                                                                                                                  |
| 00:05               | <p>IMPLEMENTED UPTO XOR FOR 8-BIT ALU<br/>     START W/ CMP.</p>                                                                                                                                                                                                               |
| 3/11                | <p>FINISHED ALU<br/>     MISC OPS; LIKELY PROBLEMS.<br/>     POTENTIALLY UNSAFE SWITCH IN (SWAP n).<br/>     MISC OPS SKIPPED: DAA (DECIMAL ADJUST) ???</p>                                                                                                                    |
| 4:26                | <p>ADDED BASIC ERROR HANDLING STRUCTURE.<br/>     SHOULD BREAK B80.C INTO ADDITIONAL FILES FOR STRUCT &amp; FUTURE.</p>                                                                                                                                                        |
|                     | <p>NEXT TO DO: • BUILD TEST CASE SUITE TO VERIFY OPS<br/>     IMPLEMENTED.<br/>     • Fix the errors<br/>     • Do hardware interrupt code<br/>     • Look into visualization library.<br/>     • What's needed to see the boot-up screen?<br/>     &amp; REST OF OP CODES</p> |

Figure 3: Project entry 2



Figure 4: Project entry 3



Figure 5: Project entry 4