drhelius

Gearboy

Built by drhelius 1,095 stars

What is Gearboy?

Game Boy / Gameboy Color emulator, debugger and embedded MCP server for macOS, Windows, Linux, BSD and RetroArch.

How to use Gearboy?

1. Install a compatible MCP client (like Claude Desktop). 2. Open your configuration settings. 3. Add Gearboy using the following command: npx @modelcontextprotocol/gearboy 4. Restart the client and verify the new tools are active.
🛡️ Scoped (Restricted)
npx @modelcontextprotocol/gearboy --scope restricted
🔓 Unrestricted Access
npx @modelcontextprotocol/gearboy

Key Features

Native MCP Protocol Support
Real-time Tool Activation & Execution
Verified High-performance Implementation
Secure Resource & Context Handling

Optimized Use Cases

Extending AI models with custom local capabilities
Automating system workflows via natural language
Connecting external data sources to LLM context windows

Gearboy FAQ

Q

Is Gearboy safe?

Yes, Gearboy follows the standardized Model Context Protocol security patterns and only executes tools with explicit user-granted permissions.

Q

Is Gearboy up to date?

Gearboy is currently active in the registry with 1,095 stars on GitHub, indicating its reliability and community support.

Q

Are there any limits for Gearboy?

Usage limits depend on the specific implementation of the MCP server and your system resources. Refer to the official documentation below for technical details.

Official Documentation

View on GitHub

Gearboy

GitHub Workflow Status GitHub Releases) commits) GitHub contributors GitHub Sponsors License Twitter Follow

Gearboy is an accurate cross-platform Game Boy / Game Boy Color / Super Game Boy emulator written in C++ that runs on Windows, macOS, Linux, BSD and RetroArch, with an embedded MCP server for debugging and tooling.

This is an open source project with its ongoing development made possible thanks to the support by these awesome backers. If you find it useful, please consider sponsoring.

Don't hesitate to report bugs or ask for new features by opening an issue.

<img src="http://www.geardome.com/files/gearboy/gearboy_debug_05.png">

Downloads

<table> <thead> <tr> <th>Platform</th> <th>Architecture</th> <th>Download Link</th> </tr> </thead> <tbody> <tr> <td rowspan="2"><strong>Windows</strong></td> <td>Desktop x64</td> <td><a href="https://github.com/drhelius/Gearboy/releases/download/3.8.1/Gearboy-3.8.1-desktop-windows-x64.zip">Gearboy-3.8.1-desktop-windows-x64.zip</a></td> </tr> <tr> <td>Desktop ARM64</td> <td><a href="https://github.com/drhelius/Gearboy/releases/download/3.8.1/Gearboy-3.8.1-desktop-windows-arm64.zip">Gearboy-3.8.1-desktop-windows-arm64.zip</a></td> </tr> <tr> <td rowspan="3"><strong>macOS</strong></td> <td>Homebrew</td> <td><code>brew install --cask drhelius/geardome/gearboy</code></td> </tr> <tr> <td>Desktop Apple Silicon</td> <td><a href="https://github.com/drhelius/Gearboy/releases/download/3.8.1/Gearboy-3.8.1-desktop-macos-arm64.zip">Gearboy-3.8.1-desktop-macos-arm64.zip</a></td> </tr> <tr> <td>Desktop Intel</td> <td><a href="https://github.com/drhelius/Gearboy/releases/download/3.8.1/Gearboy-3.8.1-desktop-macos-intel.zip">Gearboy-3.8.1-desktop-macos-intel.zip</a></td> </tr> <tr> <td rowspan="4"><strong>Linux</strong></td> <td>Ubuntu PPA</td> <td><a href="https://github.com/drhelius/ppa-geardome">drhelius/ppa-geardome</a></td> </tr> <tr> <td>Desktop Ubuntu 24.04 x64</td> <td><a href="https://github.com/drhelius/Gearboy/releases/download/3.8.1/Gearboy-3.8.1-desktop-ubuntu24.04-x64.zip">Gearboy-3.8.1-desktop-ubuntu24.04-x64.zip</a></td> </tr> <tr> <td>Desktop Ubuntu 22.04 x64</td> <td><a href="https://github.com/drhelius/Gearboy/releases/download/3.8.1/Gearboy-3.8.1-desktop-ubuntu22.04-x64.zip">Gearboy-3.8.1-desktop-ubuntu22.04-x64.zip</a></td> </tr> <tr> <td>Desktop Ubuntu 24.04 ARM64</td> <td><a href="https://github.com/drhelius/Gearboy/releases/download/3.8.1/Gearboy-3.8.1-desktop-ubuntu24.04-arm64.zip">Gearboy-3.8.1-desktop-ubuntu24.04-arm64.zip</a></td> </tr> <tr> <td><strong>MCPB</strong></td> <td>All platforms</td> <td><a href="MCP_README.md">MCP Readme</a></td> </tr> <tr> <td><strong>RetroArch</strong></td> <td>All platforms</td> <td><a href="https://docs.libretro.com/library/gearboy/">Libretro core documentation</a></td> </tr> <tr> <td><strong>Dev Builds</strong></td> <td>All platforms</td> <td><a href="https://github.com/drhelius/Gearboy/actions/workflows/gearboy.yml">GitHub Actions</a></td> </tr> </tbody> </table>

Notes:

Features

  • Supported cartridges: ROM, ROM + RAM, MBC1, MBC2, MBC3, MBC5, MBC7, HuC-1, HuC-3, MMM01, Pocket Camera, TAMA5 and MBC1M.
  • Game Boy Color support.
  • Super Game Boy support.
  • LCD screen ghosting effect as seen in the original Game Boy.
  • LCD dot matrix effect.
  • Battery powered RAM save support.
  • Save states.
  • Compressed rom support (ZIP).
  • Bootrom (BIOS) support.
  • Game Genie and GameShark cheat support.
  • VGM recorder.
  • Supported platforms (standalone): Windows, Linux, BSD and macOS.
  • Supported platforms (libretro): Windows, Linux, macOS, Raspberry Pi, Android, iOS, tvOS, PlayStation Vita, PlayStation 3, Nintendo 3DS, Nintendo GameCube, Nintendo Wii, Nintendo WiiU, Nintendo Switch, Emscripten, Classic Mini systems (NES, SNES, C64, ...), OpenDingux, RetroFW and QNX.
  • Full debugger with just-in-time disassembler, CPU breakpoints, memory access breakpoints, code navigation (goto address, JP JR and CALL double clicking), debug symbols, automatic labels, memory editor, trace logger, IO inspector and VRAM viewer including tiles, sprites, backgrounds and palettes.
  • MCP server for AI-assisted debugging with GitHub Copilot, Claude, ChatGPT and similar, exposing tools for execution control, memory inspection, hardware status, and more.
  • Windows and Linux Portable Mode.
  • ROM loading from the command line by adding the ROM path as an argument.
  • ROM loading using drag & drop.
  • Support for modern game controllers through gamecontrollerdb.txt file located in the same directory as the application binary.

Tips

Basic Usage

  • Boot ROM: Gearboy can run with or without a Boot ROM. You can optionally load a Boot ROM and enable it.
  • Mouse Cursor: Automatically hides when hovering over the main output window or when Main Menu is disabled.
  • Portable Mode: Create an empty file named portable.ini in the same directory as the application binary to enable portable mode.

Debugging Features

  • Docking Windows: In debug mode, you can dock windows together by pressing SHIFT and dragging a window onto another.
  • Multi-viewport: In Windows or macOS, you can enable "multi-viewport" in the debug menu. You must restart the emulator for the change to take effect. Once enabled, you can drag debugger windows outside the main window.
  • Single Instance: You can enable "Single Instance" in the Emulator menu. When enabled, opening a ROM while another instance is running will send the ROM to the running instance instead of starting a new one.
  • Debug Symbols: The emulator automatically tries to load a symbol file when loading a ROM (.sym, .noi). For example, for path_to_rom_file.gb it tries to load path_to_rom_file.sym. You can also load a symbol file using the GUI or the CLI. It supports RGBDS, GBDK-2020, WLA-DX, no$gmb, SDCC/NoICE (.noi), EQU and generic file formats.

Command Line Usage

gearboy [options] [rom_file] [symbol_file]

Arguments:
  [rom_file]               ROM file: accepts ROMs (.gb, .dmg, .gbc, .cgb, .sgb) or ZIP (.zip)
  [symbol_file]            Optional symbol file for debugging

Options:
  -f, --fullscreen         Start in fullscreen mode
  -w, --windowed           Start in windowed mode with menu visible
      --mcp-stdio          Auto-start MCP server with stdio transport
      --mcp-http           Auto-start MCP server with HTTP transport
      --mcp-http-port N    HTTP port for MCP server (default: 7777)
      --headless           Run without GUI (requires --mcp-stdio or --mcp-http)
  -v, --version            Display version information
  -h, --help               Display this help message

MCP Server

Gearboy includes a Model Context Protocol (MCP) server that enables AI-assisted debugging through AI agents like GitHub Copilot, Claude, ChatGPT and similar. The server provides tools for execution control, memory inspection, breakpoints, disassembly, hardware status, and more.

For complete setup instructions and tool documentation, see MCP_README.md.

Agent Skills

Gearboy provides Agent Skills that teach AI assistants how to effectively use the emulator for specific tasks:

  • gearboy-debugging — Game debugging, code tracing, breakpoint management, hardware inspection, and reverse engineering.
  • gearboy-romhacking — Cheat creation, memory searching, ROM data modification, text translation, and game patching.

Install with npx skills add drhelius/gearboy. See the skills README for details.

Build Instructions

Windows

  • Install Microsoft Visual Studio Community 2022 or later.
  • Download the latest SDL3 VC development libraries from SDL3 Releases (the file named SDL3-devel-x.y.z-VC.zip).
  • Extract the archive and rename the resulting folder (e.g. SDL3-x.y.z) to SDL3.
  • Place the SDL3 folder inside platforms/windows/dependencies/ so that the include path is platforms/windows/dependencies/SDL3/include/SDL3/.
  • Open the Gearboy Visual Studio solution platforms/windows/Gearboy.sln and build.

macOS

  • Install Xcode and run xcode-select --install in the terminal for the compiler to be available on the command line.
  • Run these commands to generate a Mac app bundle:
brew install sdl3
cd platforms/macos
make dist

Linux

  • Ubuntu / Debian / Raspberry Pi (Raspbian):

If you are using Ubuntu 25.04 or later, you can install SDL3 directly. Use the following commands to build:

sudo apt install build-essential libsdl3-dev
cd platforms/linux
make

For older Ubuntu versions (22.04, 24.04), you need to build SDL3 from source first. Use the following commands to build both SDL3 and Gearlynx:

sudo apt install build-essential cmake \
  libx11-dev libxext-dev libxrandr-dev libxcursor-dev libxfixes-dev \
  libxi-dev libxss-dev libxkbcommon-dev libwayland-dev libdecor-0-dev \
  libdrm-dev libgbm-dev libgl1-mesa-dev libegl1-mesa-dev libdbus-1-dev libudev-dev libxtst-dev
SDL3_TAG=$(curl -s https://api.github.com/repos/libsdl-org/SDL/releases/latest | jq -r '.tag_name')
git clone --depth 1 --branch "$SDL3_TAG" https://github.com/libsdl-org/SDL.git /tmp/SDL3
cmake -S /tmp/SDL3 -B /tmp/SDL3/build -DCMAKE_INSTALL_PREFIX=/usr -DSDL_TESTS=OFF -DSDL_EXAMPLES=OFF
cmake --build /tmp/SDL3/build -j$(nproc)
sudo cmake --install /tmp/SDL3/build
cd platforms/linux
make
  • Fedora:
sudo dnf install @development-tools gcc-c++ SDL3-devel
cd platforms/linux
make
  • Arch Linux:
sudo pacman -S base-devel sdl3
cd platforms/linux
make

BSD

  • FreeBSD:
su root -c "pkg install -y git gmake pkgconf SDL3 lang/gcc"
cd platforms/bsd
gmake
  • NetBSD:
su root -c "pkgin install gmake pkgconf SDL3 lang/gcc"
cd platforms/bsd
gmake

Libretro

  • Ubuntu / Debian / Raspberry Pi (Raspbian):
sudo apt install build-essential
cd platforms/libretro
make
  • Fedora:
sudo dnf install @development-tools gcc-c++
cd platforms/libretro
make

Screenshots

ScreenshotScreenshotScreenshotScreenshotScreenshotScreenshotScreenshotScreenshotScreenshotScreenshotScreenshotScreenshotScreenshotScreenshotScreenshotScreenshotScreenshotScreenshotScreenshotScreenshotScreenshotScreenshotScreenshotScreenshotScreenshotScreenshotScreenshotScreenshot

Contributors

Thank you to all the people who have already contributed to Gearboy!

Contributors

License

Gearboy is licensed under the GNU General Public License v3.0 License, see LICENSE for more information.

Global Ranking

-
Trust ScoreMCPHub Index

Based on codebase health & activity.

Manual Config

{ "mcpServers": { "gearboy": { "command": "npx", "args": ["gearboy"] } } }