#### Sega Game Gear on a Chip

Max Thrun | Samir Silbak

University of Cincinnati

Fall 2012

#### Agenda

- Problem Description
- Design Process
- Implementation Priority
- Requirements
- Assessment Metrics
- Test Plans
- Design Overview
- Project Limitations
- Demonstration

Reimplement all the digital components of a legacy computer system in a FPGA

- Maintainability You can no longer buy parts to service legacy computer systems
- Upgradability Reimplementation gives an opportunity to add additional features
- Portability Do not need all the original big clunky hardware.
   Reimplementation can be embedded in new designs



- Maintainability You can no longer buy parts to service legacy computer systems
- Upgradability Reimplementation gives an opportunity to add additional features
- Portability Do not need all the original big clunky hardware.
   Reimplementation can be embedded in new designs



- Maintainability You can no longer buy parts to service legacy computer systems
- Upgradability Reimplementation gives an opportunity to add additional features
- Portability Do not need all the original big clunky hardware.
   Reimplementation can be embedded in new designs



- Maintainability You can no longer buy parts to service legacy computer systems
- Upgradability Reimplementation gives an opportunity to add additional features
- Portability Do not need all the original big clunky hardware.
   Reimplementation can be embedded in new designs



- 1. Break down system components according to the original system architecture
- Implement each component in Verilog matching the original functionality described by official and non official documents
- Simulate each components functionality and compare it against the actual hardware (in our case an emulator)
- 4. Tie components together in a way that is better suited toward FPGA technology (*E.g.* avoid tri-state buses)

- 1. Break down system components according to the original system architecture
- 2. Implement each component in Verilog matching the original functionality described by official and non official documents
- Simulate each components functionality and compare it against the actual hardware (in our case an emulator)
- 4. Tie components together in a way that is better suited toward FPGA technology (*E.g.* avoid tri-state buses)

- 1. Break down system components according to the original system architecture
- 2. Implement each component in Verilog matching the original functionality described by official and non official documents
- 3. Simulate each components functionality and compare it against the actual hardware (in our case an emulator)
- 4. Tie components together in a way that is better suited toward FPGA technology (*E.g.* avoid tri-state buses)

- 1. Break down system components according to the original system architecture
- 2. Implement each component in Verilog matching the original functionality described by official and non official documents
- 3. Simulate each components functionality and compare it against the actual hardware (in our case an emulator)
- 4. Tie components together in a way that is better suited toward FPGA technology (*E.g.* avoid tri-state buses)

# Implementation Priority

- 1. Flash Memory Interface
- 2. Memory Management Unit (MMU)
- 3. Z80 + System RAM
- 4. Cartridge Mapper
- VGA Driver
- 6. Background Tiles + VRAM
- 7. Video Display Processor Logic (VDP)
- 8. Sprites
- 9. Controller Input
- 10. Sound

- 1. **VGA Output** Need to output video via VGA which is the most common video interface found on FPGA development boards.
- ROM Loading Need to be able to easily load in different game and test ROMs into the Flash memory chip on the dev board.
- 3. Accurate Re-implementation Overall goal of this project is to re-implement the Sega Game Gear as accurately as possible. User should not be able to tell its not the original hardware.
- 4. Accurate Architecture Overall system architecture should be as clean as possible and closely match that of the original Game Gear.

- VGA Output Need to output video via VGA which is the most common video interface found on FPGA development boards.
- ROM Loading Need to be able to easily load in different game and test ROMs into the Flash memory chip on the dev board.
- Accurate Re-implementation Overall goal of this project is to re-implement the Sega Game Gear as accurately as possible. User should not be able to tell its not the original hardware.
- 4. Accurate Architecture Overall system architecture should be as clean as possible and closely match that of the original Game Gear.

- 1. **VGA Output** Need to output video via VGA which is the most common video interface found on FPGA development boards.
- ROM Loading Need to be able to easily load in different game and test ROMs into the Flash memory chip on the dev board.
- 3. Accurate Re-implementation Overall goal of this project is to re-implement the Sega Game Gear as accurately as possible. User should not be able to tell its not the original hardware.
- 4. Accurate Architecture Overall system architecture should be as clean as possible and closely match that of the original Game Gear.

- VGA Output Need to output video via VGA which is the most common video interface found on FPGA development boards.
- ROM Loading Need to be able to easily load in different game and test ROMs into the Flash memory chip on the dev board.
- 3. Accurate Re-implementation Overall goal of this project is to re-implement the Sega Game Gear as accurately as possible. User should not be able to tell its not the original hardware.
- 4. **Accurate Architecture** Overall system architecture should be as clean as possible and closely match that of the original Game Gear.

#### **Assessment Metrics**

| Function                             | Requirement Specification                                              | Design<br>Verified | Device<br>Validated |
|--------------------------------------|------------------------------------------------------------------------|--------------------|---------------------|
| VGA Output                           | Design must output video at 640x480 to a VGA monitor                   | Yes                | Yes                 |
| Sega Mapper                          | Design must implement the Sega Memory Mapper                           | Yes                | Yes                 |
| Video Display<br>Processor           | Design must implement the TMS9918                                      | Partly             | Partly              |
| Game ROM stored in flash             | Design must be able to load game ROMs from flash                       | Yes                | Yes                 |
| Controller Input                     | Design must implement a single controller                              | No                 | No                  |
| Game Gear<br>system<br>functionality | Design must implement the same functionality as the original Game Gear | Partly             | Partly              |

#### Test Plans

Test plan split up into 4 areas:

- Z80, RAM, Cartridge
- VDP Background Tile Rendering
- System Simulation vs Emulator
- Custom test ROMs

# Z80, RAM, Cartridge Test

Ensures basic code execution and memory/IO interfaces are working properly

- 1. Connect 8 LEDs to Z80 IO port 1
- 2. Write simple Z80 test program that increments IO port 1
- 3. Load test program into flash
- 4. Divide Z80 clock down to 10Hz
- Verify LEDs incrementing on development board

```
1 __sfr __at (0x01) debug;
2 int main() {
3    debug = 0x38;
4    while (1) {}
5    return 0;
6 }
```

# VDP Background Tile Rendering Test

Ensures VDP background tile rendering works correctly without worrying about Z80 or interface logic

- Obtain VRAM dump from the Osmose emulator
- Verify dump integrity using rendering program on computer
- Transfer dump to FPGA VRAM via the 'MemSend' tool
- 4. Verify that the resulting image on screen matches the emulator



Ensures that our system functionally matches a known good one

- 1. Insert print statements on all memory and IO accesses in emulator
- 2. Do the same for the Verilog system level simulation
- 3. Run emulator and simulation on same ROM
- 4. Diff the print logs
- 5. Verify that the memory and IO accesses match between the emulator and simulation

| /tmp/sim.log ▼ Browse                                                                                                                                                                                                                                                                                                                                                 | /tmp/emu.log ▼ Browse                                                                                                                                                                                                                                                                                                                                                 |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 26 car_r: 0267 (000267) 27 ram_w: fffd <- 00 28 [mem] Bank 0 set to 00 29 car_r: 0268 (000268) 30 car_r: 0269 (000269) 31 car_r: 026a (00026a) 32 car_r: 026b (00026b) 33 car_r: 026c (00026c) 34 ram_w: fffe <- 01 35 [mem] Bank 1 set to 01 36 car_r: 026d (00026d) 37 car_r: 026d (00026d) 38 car_r: 026d (00026f) 39 car_r: 0270 (000270) 40 car_r: 0271 (000271) | 26 car_r: 0267 (000267) 27 ram_w: fffd <- 00 28 [mem] Bank 0 set to 00 29 car_r: 0268 (000268) 30 car_r: 0269 (000269) 31 car_r: 026a (00026a) 32 car_r: 026b (00026b) 33 car_r: 026c (00026c) 34 ram_w: fffe <- 01 35 [mem] Bank 1 set to 01 36 car_r: 026d (00026d) 37 car_r: 026e (00026e) 38 car_r: 026f (00026f) 39 car_r: 0270 (000270) 40 car_r: 0271 (000271) |
| 41 ram_w: ffff <- 02 42 [mem] Bank 2 set to 02 43 car_r: 0272 (000272) 44 car_r: 0273 (000273) 45 car_r: 0274 (000274)                                                                                                                                                                                                                                                | 41 ram_w: ffff <- 02<br>42 [mem] Bank 2 set to 02<br>43 car_r: 0272 (000272)<br>44 car_r: 0273 (000273)<br>45 car_r: 0274 (000274)                                                                                                                                                                                                                                    |





```
34874 car r: 05e6 (0005e6)
                                      34707 car r: 05e6 (0005e6)
34875 car r: 05e7 (0005e7)
                                      34708 car r: 05e7 (0005e7)
34876 car r: 05e8 (0005e8)
                                      34709 car r: 05e8 (0005e8)
34877 car r: 05e9 (0005e9)
                                      34710 car r: 05e9 (0005e9)
34878 car r: 05ea (0005ea)
                                      34711 car r: 05ea (0005ea)
34879 car r: 05eb (0005eb)
                                      34712 car r: 05eb (0005eb)
34880 ram w: xxxx <- ff
                                → ← 34713 car w: 0003 <- ff
34881 car_r: 05ec (0005ec)
                                      34714 car_r: 05ec (0005ec)
34882 ram r: dfdd
                                      34715 ram r: dfdd
34883 ram r: dfde
                                      34716 ram r: dfde
34884 car r: 0099 (000099)
                                     34717 car r: 0099 (000099)
34885 car r: 009a (00009a)
                                      34718 car r: 009a (00009a)
34886 car r: 009b (00009b)
                                      34719 car r: 009b (00009b)
```

#### **Custom Test ROMs**

Allows unit testing of specific features of the system

- Write program that performs a certain task (ex. scroll screen left 5 pixels)
- 2. Verify ROM in emulator
- 3. Flash ROM onto the dev board
- 4. Verify expected output is achived on FPGA



# **Custom Test ROM Code Library**

We ended up building a library of high level functions to quickly allow new tests to be written

```
1 void vdp_write_control(uint8_t value);
2 void vdp_write_data(uint8_t value);
3 void vdp_set_register(uint8_t reg, uint8_t value);
4 void vdp_set_vram_addr(uint16_t addr);
5 void vdp_set_palette(uint8_t id, uint16_t color);
6 void set_pattern_fill(uint16_t id, uint8_t color);
7 void set_tile_to_pattern(uint8_t x, uint8_t y, uint16_t pattern);
8 void delay(uint16_t x);
9 void set_debug(uint8_t x);
```

# **Custom Test ROM Example**

```
#include <stdint.h>
1
    #include <gg.h>
3
    int main() {
4
5
      uint8_t x = 0;
7
      while (1) {
           // set register 1 bit 6 to enable display
8
           vdp_set_register(1, (1<<6));</pre>
9
10
           // set color palette (0x0BGR)
11
           vdp_set_palette(0, 0x0CCC); // gray
12
           vdp_set_palette(1, 0x000F); // red
13
           vdp_set_palette(2, 0x00F0); // green
14
15
           // update the debug leds
16
           set_debug(x++);
17
      }
18
19
20
      return 0:
    }
21
```

# Design Overview

Black Box Diagram



# Design Overview

#### Internal Functional Diagram



# Design Overview

'Memsend' tool used to write ROMs to the flash chip on the FPGA development board





Write

Read

# **Project Limitations**

- Tile Corruption Some tiles are fliped or are the wrong tile ID. Not sure if timing or logic issue yet. Haven't been able to reproduce with a test ROM yet.
- Missing Features Currently missing some core functionality such as sprites, controller input, and sound. Each will be added with time.
- Cumbersome ROM Loading The current process to load a new ROM is cumbersome and takes a long time. It can take 5-10 minutes to flash a multi-megabyte ROM. Loading off an SD card would be much nicer.

# **Project Limitations**

- Tile Corruption Some tiles are fliped or are the wrong tile ID. Not sure if timing or logic issue yet. Haven't been able to reproduce with a test ROM yet.
- Missing Features Currently missing some core functionality such as sprites, controller input, and sound. Each will be added with time.
- Cumbersome ROM Loading The current process to load a new ROM is cumbersome and takes a long time. It can take 5-10 minutes to flash a multi-megabyte ROM. Loading off an SD card would be much nicer.

# **Project Limitations**

- Tile Corruption Some tiles are fliped or are the wrong tile ID. Not sure if timing or logic issue yet. Haven't been able to reproduce with a test ROM yet.
- Missing Features Currently missing some core functionality such as sprites, controller input, and sound. Each will be added with time.
- Cumbersome ROM Loading The current process to load a new ROM is cumbersome and takes a long time. It can take 5-10 minutes to flash a multi-megabyte ROM. Loading off an SD card would be much nicer.

# Demonstration

# Questions?