GBDK is a cross-platform development kit for sm83 and z80 based gaming consoles. It includes libraries, toolchain utilities and the SDCC C compiler suite.
Supported Consoles: (see docs)
- Nintendo Gameboy / Game Boy Color
- Analogue Pocket
- Sega Master System & Game Gear
- Mega Duck / Cougar Boy
Expirimental consoles (not yet fully functional)
- MSXDOS
- NES
Upgrading to a new version? Check the Migration notes. You can find older versions here.
For a full list of changes see the ChangeLog file or online Docs.
GBDK includes extensive documentation. A good place to begin is the Getting Started Section.
Check the Links and Third-Party Tools Section for a list of recommended emulators, graphics tools, music drivers and more.
For SDCC you can check its website and the manual
Most users will only need to download and unzip the latest release
Then go to the examples folder and build them (with compile.bat
on Windows or running make
). They are a good starting point.
The sources in this repo are only needed if you want to re-compile GBDK-2020 yourself instead of using the release binaries linked above.
-
gbdk/zgb Discord - For help with using GBDK (and ZGB), discussion and development of gbdk-2020
-
gbdev Discord - There is a #gbdk channel and also people with a lot of Game Boy development knowledge
-
SMS Power! Discord - Additional SMS & Game Gear discussion and resources.
- The Game Boy Development Forum - A good place to search for Game Boy related answers.
- SMS Power! Forum - Additional SMS & Game Gear discussion and resources.
- Updated CRT and library that suits better for game development
- SDCC Versions
- Current GBDK-2020 versions require SDCC patches for z80 SMS/Game Gear support (only
sdldz80
in GBDK-2020 4.1.0). So SDCC nightlies/snapshot builds cannot be used if you want to target SMS/Game Gear. Instead use the Patched SDCC Builds. - The default calling convention changed in
SDCC 4.2
. This is supported starting withGBDK-2020 4.1.0
. Older versions of GBDK should use SDCC builds #12539 or older (see per-version GBDK notes).
- Current GBDK-2020 versions require SDCC patches for z80 SMS/Game Gear support (only
- The compiler driver lcc supports the latest sdcc toolchain.
Over the years people have been complaining about all the GBDK issues caused by a very old version of SDCC (the compiler). This is a proper attempt of updating it while also keeping all the old functionallity working, like support for banked code and data and so on.
The last version in the OLD repo is 2.96 although releases are available until 2.95-3. Version 2.96 is the starting point of this repo.
Unless you are interested on recompiling the sources for some reason (like fixing some bugs) you don't need to build GBDK
- Windows only: Download and install mingw
- Clone, download this repo or just get the source form the releases
- Download and install the PATCHED sdcc builds from the separate repo for that (https://github.com/gbdk-2020/gbdk-2020-sdcc/releases).
- On Linux don't use package managers The latest release available won't work, you need to compile or download one of the nightlies
- Create SDCCDIR environment variable, that points into the folder, where you installed sdcc
- Open command prompt or a terminal, go to the root directory of the repo and run make