Skip to content

nand2mario/gbatang

Repository files navigation

GBATang - GBA for Sipeed Tang FPGA boards

This is a Game Boy Advance FPGA core for Sipeed Tang Mega 60K, Tang Mega 138K, Mega 138K Pro and the upcoming Tang Console 60K.

The core outputs 720p HDMI video, accepts DS2 controller input, and supports all ROM sizes (up to 32MB). An open source BIOS is used so it can be used out of the box. ROMs are loaded from the SD card through a convenient menu system.

Things-to-do on my list include SNES controller input, and further game compatibility fixes (currently 90 out of top 100 games work).

Follow me on X to get updates. Also check out other cores in the series: SNESTang and NESTang, and MDTang.

Instructions

You need the Tang Mega 60K, Tang Mega 138K or Tang Mega 138K Pro board. You also need a Tang DS2 Pmod, a Tang SDRAM Pmod, a DS2 controller, and finally a MicroSD card. Then assemble the parts as shown in the picture above.

Then follow these steps to install the core (for detailed instructions, for now refer to SNESTang installation),

  1. Download and install Gowin IDE 1.9.9.

  2. Download a GBATang release.

  3. Use Gowin programmer to program firmware.bin to on-board flash, at starting address 0x500000.

  4. Again use Gowin programmer. Program gbatang_*.fs to on-board flash at starting address 0x000000.

  5. Put GBA roms and GBA BIOS on the MicroSD card. The 16KB GBA BIOS ROM should be named gba_bios.bin and placed at the root dir. Then insert the card into the on-board MicroSD slot and power up the board.

  6. Game progress saving is implemented in version 0.5. It is off by default and can be turned on in options.

About this project

The project started as a port of the MiSTer GBA core to Tang FPGAs in June 2024. However, it quickly turned into a half-rewrite. By September 2024 it finally reached a usable state and about half of the code is different. Here are the main differences.

  • The overall design is a more traditional "FPGA replica" approach, as opposed to the "cycle counting" approach in the MiSTer core. Most modules work at 16Mhz, the GBA main frequency. The MiSTer main frequency is 100Mhz.
  • The CPU is replaced, with missing features like 16-bit instructions added. The processor uses a similar pipelined design as the original GBA CPU.
  • The memory system is also completely rewritten, as required by the overall design change.
  • Timing accuracy could use a lot of improvements. However, as a more "modern" console, GBA mostly uses interrupts and timers to keep time. So cycle-accuracy is not as important as previous consoles.
  • A softcore-based menu system is provided, similar to SNESTang and NESTang.

Documentation

Acknowledgements