A Gameboy emulator, in Rust
Let's be real here, I was bored one day and was interested in how the Gameboy (and emulation in general) works. I love writing Rust, and used this as an excuse to embark on a big long-term project that uses Rust. Nearly as soon as I dipped my toes into the water of emulation, however, I was dissatisifed with the learning materials at-hand.
While nearly all of them are of high-quality and I do dearly love them all, I didn't like having to build and manage an entire library of bookmarks in order to cross-reference and learn about the Gameboy hardware and how it worked. Moreover, several pages that talk about the DMG-01 link out to generic Zilog Z80 documentation, even though the Gameboy's CPU isn't a complete Z80. Several documents also assumed the reader was familiar with emulation and the status-quo of such, or thought the appropriate learning material was arcane C code. Personally, I don't think this is a good foundation for new developers or developers in other fields looking to learn about and join the emulation scene.
My personal goal here, other than the satisfaction of building something nearly from scratch, is to create a one-stop-shop for new learners to learn about emulation and DMG-01.
- Robust documentation
- DMG-01 Emulation
- SGB Emulation
- SGB2 Emulation
- Gameboy Camera Emulation
- Link Cable Emulation
- LAN-based multiplayer
- WAN-based multiplayer
- Unlicensed memory mappers
- One-off accessories (e.g. pocket sonar, Barcode Boy)
- CGB Emulation
- Maybe an eventual Ferroboy Color
- AGB-001/AGS-001/OXY-001
- Ferroboy Advance?
- Gameboy Player (DOL-017)
A Rust library that implements the emulation
A libretro core powered by Ferroboy
A disassembler for DMG-01 ROMs that attempts to output 6502 assembly.
A set of C bindings for Ferroboy. Eventually.
There are a few different comment blocks used throughout the code that you might encounter:
FIXME
directives are things that are known to be in need of cleanup workTODO
, as one might expect, are things that have yet to be done?
Indicates a question. This can range from a question about the state of code, or to elaborate an idea in another comment.
Wide
vsNarrow
This refers to the divide between 8-bit (narrow) and 16-bit (wide) interfaces. In cases where both are handled, the "narrow" prefix may be omitted.