Go to file
Maximilian Mader e3c8f1c1d4
Add an optional OpenAL audio driver for the SDL frontend
To compile the OpenAL driver specify `ENABLE_OPENAL=1` when
invoking `make`.
2022-07-09 21:47:26 +02:00
.github Give APU tests more time 2021-10-07 18:30:09 +03:00
BootROMs There you go, kouhai. Closes #455 2022-05-23 22:13:59 +03:00
Cocoa Handle GateKeeper and write permissions in the auto updater 2022-07-03 22:23:35 +03:00
Core Improved MMM01 emulation, fixes #447 2022-07-02 21:03:26 +03:00
FreeDesktop Fix the 16x16 cartridge icon 2022-05-11 03:35:17 +03:00
HexFiend Make it hex editing more reasonable while the core is running 2022-02-20 19:05:49 +02:00
JoyKit Be consistent with hex casing 2022-02-13 16:58:44 +02:00
libretro The vblank callback now reports the vblank type 2022-06-25 01:59:51 +03:00
Misc Add rX as symbol aliases to IO_X 2022-07-01 17:40:47 +03:00
OpenDialog Query the system sample rate on Windows and use it, rather than hardcode 96KHz 2022-07-08 19:51:10 +03:00
QuickLook The vblank callback now reports the vblank type 2022-06-25 01:59:51 +03:00
SDL Add an optional OpenAL audio driver for the SDL frontend 2022-07-09 21:47:26 +02:00
Shaders Be consistent with hex casing 2022-02-13 16:58:44 +02:00
Tester The vblank callback now reports the vblank type 2022-06-25 01:59:51 +03:00
Windows Add audio recording to SDL 2022-05-21 18:18:34 +03:00
.gitattributes Add .gitattributes line ending settings 2020-12-19 00:58:19 -05:00
.gitignore Initial public commit 2016-04-01 21:27:01 +03:00
BESS.md Added MBC7 BESS support, documented BESS TPP1 2022-06-05 14:09:33 +03:00
build-faq.md Update RGBDS links in README and build-faq 2020-10-13 18:19:29 -04:00
CHANGES.md Updated documents to refer to the new website 2017-02-05 21:50:46 +02:00
CONTRIBUTING.md Create CONTRIBUTING.md 2020-09-29 20:43:47 +03:00
LICENSE Visual refresh, update copyright year, crush PNGs 2022-02-24 00:38:27 +02:00
Makefile Add an optional OpenAL audio driver for the SDL frontend 2022-07-09 21:47:26 +02:00
README.md Update readme 2021-02-27 15:37:40 +02:00
version.mk Update version to 0.15.1 2022-07-08 20:10:11 +03:00

SameBoy

SameBoy is an open source Game Boy (DMG) and Game Boy Color (CGB) emulator, written in portable C. It has a native Cocoa frontend for macOS, an SDL frontend for other operating systems, and a libretro core. It also includes a text-based debugger with an expression evaluator. Visit the website.

Features

Features common to both Cocoa and SDL versions:

  • Supports Game Boy (DMG) and Game Boy Color (CGB) emulation
  • Lets you choose the model you want to emulate regardless of ROM
  • High quality 96KHz audio
  • Battery save support
  • Save states
  • Includes open source DMG and CGB boot ROMs:
    • Complete support for (and documentation of) all game-specific palettes in the CGB boot ROM, for accurate emulation of Game Boy games on a Game Boy Color
    • Supports manual palette selection with key combinations, with 4 additional new palettes (A + B + direction)
    • Supports palette selection in a CGB game, forcing it to run in 'paletted' DMG mode, if ROM allows doing so.
    • Support for games with a non-Nintendo logo in the header
    • No long animation in the DMG boot
  • Advanced text-based debugger with an expression evaluator, disassembler, conditional breakpoints, conditional watchpoints, backtracing and other features
  • Extremely high accuracy
  • Emulates PCM_12 and PCM_34 registers
  • T-cycle accurate emulation of LCD timing effects, supporting the Demotronic trick, Prehistorik Man, GBVideoPlayer and other tech demos
  • Real time clock emulation
  • Retina/High DPI display support, allowing a wider range of scaling factors without artifacts
  • Optional frame blending (Requires OpenGL 3.2 or later)
  • Several scaling algorithms (Including exclusive algorithms like OmniScale and Anti-aliased Scale2x; Requires OpenGL 3.2 or later or Metal)

Features currently supported only with the Cocoa version:

  • Native Cocoa interface, with support for all system-wide features, such as drag-and-drop and smart titlebars
  • Game Boy Camera support

Read more.

Compatibility

SameBoy passes all of blargg's test ROMs, all of mooneye-gb's tests (Some tests require the original boot ROMs), and all of Wilbert Pol's tests. SameBoy should work with most games and demos, please report any broken ROM. The latest results for SameBoy's automatic tester are available here.

Contributing

SameBoy is an open-source project licensed under the MIT license, and you're welcome to contribute by creating issues, implementing new features, improving emulation accuracy and fixing existing open issues. You can read the contribution guidelines to make sure your contributions are as effective as possible.

Compilation

SameBoy requires the following tools and libraries to build:

  • clang (Recommended; required for macOS) or GCC
  • make
  • macOS Cocoa port: macOS SDK and Xcode (For command line tools and ibtool)
  • SDL port: libsdl2
  • rgbds, for boot ROM compilation

On Windows, SameBoy also requires:

  • Visual Studio (For headers, etc.)
  • GnuWin
  • Running vcvars32 before running make. Make sure all required tools and libraries are in %PATH% and %lib%, respectively. (see Build FAQ for more details on Windows compilation)

To compile, simply run make. The targets are cocoa (Default for macOS), sdl (Default for everything else), libretro, bootroms and tester. You may also specify CONF=debug (default), CONF=release, CONF=native_release or CONF=fat_release to control optimization, symbols and multi-architectures. native_release is faster than release, but is optimized to the host's CPU and therefore is not portable. fat_release is exclusive to macOS and builds x86-64 and ARM64 fat binaries; this requires using a recent enough clang and macOS SDK using xcode-select, or setting them explicitly with CC= and SYSROOT=, respectively. All other configurations will build to your host architecture. You may set BOOTROMS_DIR=... to a directory containing precompiled boot ROM files, otherwise the build system will compile and use SameBoy's own boot ROMs.

The SDL port will look for resource files with a path relative to executable and inside the directory specified by the DATA_DIR variable. If you are packaging SameBoy, you may wish to override this by setting the DATA_DIR variable during compilation to the target path of the directory containing all files (apart from the executable, that's not necessary) from the build/bin/SDL directory in the source tree. Make sure the variable ends with a / character. On FreeDesktop environments, DATA_DIR will default to /usr/local/share/sameboy/. PREFIX and DESTDIR follow their standard usage and default to an empty string an /usr/local, respectively

Linux, BSD, and other FreeDesktop users can run sudo make install to install SameBoy as both a GUI app and a command line tool.

SameBoy is compiled and tested on macOS, Ubuntu and 64-bit Windows 10.