Gearboy is a cross-platform Game Boy / Game Boy Color emulator written in C++ that runs on Windows, macOS, Linux, BSD and RetroArch.

Features​

  • Accurate CPU emulation, passes cpu_instrs.gb from blargg's tests.
  • Accurate instruction and memory timing, passes instr_timing.gb and mem_timing.gb from blargg's tests.
  • Supported cartridges: ROM, ROM + RAM, MBC1, MBC2, MBC3 + RTC, MBC5, HuC-1 and MBC1M (multicart).
  • Accurate LCD controller emulation with correct timings and priorities including mid-scanline effects.
  • Game Boy Color 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.
  • 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, memory editor, IO inspector and VRAM viewer including tiles, sprites, backgrounds and palettes.
  • Windows and Linux Portable Mode.
  • Rom loading from the command line by adding the rom path as an argument.
  • Support for modern game controllers through gamecontrollerdb.txt file located in the same directory as the application binary.


Tips​

  • 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 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.
  • Docking windows: In debug mode you can dock windows together by pressing SHIFT and drag'n drop a window into another.
  • Debug multi-viewport: In Windows or macOS you can enable "multi-viewport" in debug menu. You must restart the emulator for the change to take effect. Once enabled you can drag debugger windows outside the main window.
  • Debug Symbols: The emulator always tries to load a symbol file at the same time a rom is being loaded. For example, for path_to_rom_file.gb it tries to load path_to_rom_file.sym. It is also possible to load a symbol file using the GUI or using the CLI.
  • Command Line Usage: gearboy [rom_file] [symbol_file]


What's Changed​

  • Windows ARM64 support.
  • Updated GLEW, SDL, Imgui, mINI, miniz and NFD libraries to latest version.
  • Properly codesign and notarize macOS binaries.
  • Improved audio client.
  • Game mode in macOS.
  • Manual integer video scale settings.
  • [Debugger] Docking windows and multi viewport.
  • [Debugger] Improved memory editor.
  • [WiiU] Aroma CFW Compatibility by @Ploggy in #183
  • [ios/tvos] Properly set min supported version by @warmenhoven in #185
  • Quality of life updates.
  • Minor bugfixes.


New Contributors​



https://github.com/drhelius/Gearboy