Skip to content
/ rugby Public

Cycle-accurate Game Boy emulation

License

Apache-2.0, MIT licenses found

Licenses found

Apache-2.0
LICENSE-APACHE
MIT
LICENSE-MIT
Notifications You must be signed in to change notification settings

kaplanz/rugby

Rugby

A cycle accurate emulator of the original 1989 Nintendo Game Boy.

dependencies cli frontend web frontend

Important

Consider this to be pre-alpha software. I make no guarantee of the stability of any documented APIs until the first official release.

Goal

This project aims to provide high-accuracy emulation of all major components in the SM83-based Nintendo Game Boy family of consoles. Each component is modular, enabling them to be easily substituted for one another. In turn, this leads to emulator instances supporting multiple implementations of core components with different accuracy/performance margins.

Note

At this time, there are no plans to support the later Game Boy Advance, which has an entirely different architecture.

Organization

In accordance with the preference for modularity outlined above, the project is partitioned into the core, the debugger, and various emulator frontends. Useful supporting crates are independently available as well. Also packaged in this repository are several open-source ROMs. These are used internally for testing and to demo project functionality.

Workspace

Cargo — Rust's package manager — allows for a workspace of several crates to be specified within its manifest. Within this project, workspace crates are used with the structure as follows:

./
├── Cargo.lock       # cargo lockfile
├── Cargo.toml       # cargo manifest
├── Justfile         # useful dev commands
├── README.md        # this document
├── ...
├── apis/            # app interfaces
│  ├── cfg/          # app configuration
│  └── gbd/          # game boy debugger
├── apps/            # frontend apps
│  ├── cli/          # command-line app
│  └── web/          # web assembly app
├── arch/            # arch primitives
├── core/            # emulation core
├── crates/          # support crates
│  ├── chex/         # color hex parser
│  ├── hexd/         # hex dump printer
│  └── wrange/       # wrapping ranges
├── docs/            # documentation
├── lib/             # library frontends
│  └── retro/        # libretro port
├── roms/            # open-source ROMs
│  ├── boot/         # boot ROM images
│  ├── games/        # playable demos
│  └── test/         # test ROM images
├── src/             # top-level library
└── tests/           # integration tests

Tip

For downstream library users, I recommend using the top-level rugby crate rather than directly using rugby-core, as it better structured for end users and includes useful supporting modules.

Components

Main components of rugby are outlined below.

  • rugby: is the high-level library that provides the public API.
  • rugby-arch: defines the architecture primitives for emulation.
  • rugby-core: contains the implementation of emulator cores.

Interfaces

  • rugby-cfg: definition of application configuration options.
  • rugby-gbd: provides an interactive prompt debugging interface.

Frontends

  • rugby-cli: a command-line interface application with rich configuration support and comprehensive debugging options.
  • rugby-web: an online web application powered by Wasm.

Several additional frontends are planned for the future:

  • rugby-ios: a native iOS application built with SwiftUI.
  • rugby-sdl: a cross-platform application based upon the SDL framework.

    note: no longer planned, use rugby-cli or libretro instead.

Libraries

  • libretro: implementation of the libretro API.

Rigorous integration testing is provided to validate the implementation and prevent regressions in future versions.

Suite Passed Failed
Acid2 17 0
Blargg 23 22
Mealybug 0 24
Mooneye 30 39

References

This project would not have been possible without the countless Game Boy community resources. Of these, I would like to specifically recognize the Game Boy Development community.

See the list of resources (in no particular order) used as research for this project below.

Documentation

Hardware

Attribution

This project uses and distributes the following open-source software under the conditions of their respective licenses:

Firmware

Games

Testing

License

This project is dual-licensed under both MIT License and Apache License 2.0. You have permission to use this code under the conditions of either license pursuant to the rights granted by the chosen license.

About

Cycle-accurate Game Boy emulation

Topics

Resources

License

Apache-2.0, MIT licenses found

Licenses found

Apache-2.0
LICENSE-APACHE
MIT
LICENSE-MIT

Code of conduct

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published