A utilitarian bootloader for the GameCube
Supported targets:
- PicoBoot
- Qoob Pro and Qoob SX
- ViperGC and ViperGC Extreme
- Savegame exploits
- Swiss in-game reset (IGR)
gekkoboot will attempt to load DOLs from the following locations in order:
- USB Gecko in Card Slot B
- SD Gecko in Card Slot B
- USB Gecko in Card Slot A
- SD Gecko in Card Slot A
- SD2SP2
You can use button shortcuts to keep alternate software on quick access. When loading from an SD card, gekkoboot will look for and load different filenames depending on what buttons are being held:
Button Held | File Loaded |
---|---|
None | /ipl.dol |
A | /a.dol |
B | /b.dol |
X | /x.dol |
Y | /y.dol |
Z | /z.dol |
Start | /start.dol |
CLI files are also supported.
If the selected shortcut file cannot be loaded, gekkoboot will fall back to
/ipl.dol
. If that cannot be loaded either, the next device will be searched.
If all fails, gekkoboot will reboot to the onboard IPL (original GameCube intro
and menu).
Holding D-Pad Left or the reset button will skip gekkoboot functionality and reboot straight into the onboard IPL.
For example, this configuration would boot straight into Swiss by default, or GBI if you held B, or the original GameCube intro if you held D-Pad Left:
/ipl.dol
- Swiss/b.dol
- GBI
This configuration would boot into the original GameCube intro by default, or Swiss if you held Z, or GBI if you held B:
/z.dol
- Swiss/b.dol
- GBI
Pro-tip: You can prevent files from showing in Swiss by marking them as hidden files on the SD card.
If you hold multiple buttons, the highest in the table takes priority. Be careful not to touch any of the analog controls (sticks and triggers) when powering on as this is when they are calibrated.
gekkoboot also acts as a server for @emukidid's usb-load, should you want to use it for development purposes.
Something not working? See the troubleshooting section.
Download and extract the latest release.
Prepare your SD card by copying DOLs onto the SD card and renaming them according the table above.
gekkoboot is bundled with the PicoBoot firmware. Just follow the update guide.
You can also update gekkoboot separately from the PicoBoot firmware,
using the supplied gekkoboot_pico.uf2
, and following the same procedure
(requires PicoBoot 0.4 or later).
Qoob Pro only: use the Qoob USB flash utility to install gekkoboot_qoob_pro.gcb
as a BIOS like you normally would.
A modified copy of the updater is also provided for both versions of the Qoob. It can be run via Swiss, or the original Qoob BIOS, from an ISO9660 DVD or over the nework using a Broadband Adapter1.
The updater files are qoob_pro_gekkoboot_upgrade.elf
and
qoob_sx_gekkoboot_upgrade.elf
respectively.
When burning them to a disc, you may need to pad the image with a large (~1GiB)
file, to ensure the drive can read it properly.
The recommended method however is to burn Swiss to a DVD, and run the updater from an SD card.
On Qoob SX, you will need to hold D-Pad left while turning the system on to boot
into the "backup" BIOS, otherwise write protection will be enabled.
This means that a DVD drive or a BBA is required to flash anyting to a Qoob SX.
If this is inconvenient, consider upgrading to PicoBoot.
This will be improved in a future release.
Tip
Alternatively, if gekkoboot is already installed, or you have access to another boot method, you can disconnect the modchip from its cable and reconnect it while the system is running. This will disable write protection, and you can run the updater from there.
Important
ViperGC is the most limited modchip family.
Because of its design, it's incapable of overriding BS1 or communicating with
software after the initial boot.
This means that support is considered best-effort,
and some upcoming features may never be available for Viper.
Please consider upgrading to PicoBoot.
Flash gekkoboot_viper.vgc
as a BIOS like you normally would.
The hardware flasher is recommended, as it is required to recover from bricks,
and there is no way to update gekkoboot via software after the initial installation.
Software flashing is planned.
Copy gekkoboot_memcard.gci
to a memory card using GCMM or Swiss.
It will be saved as boot.dol
and can be used in conjunction with the various
game save exploits.
- Copy the contents of the
swiss_igr
folder to your SD card, retaining the directory structure. - In Swiss, go to global game settings, and set in-game reset to "Apploader".
Note
When using a Qoob, the recommended IGR mode is "Reboot". Swiss will re-enable the modchip and do a hard reset, triggering the usual boot process.
gekkoboot displays useful diagnostic messages as it attempts to load the selected DOL. But it's so fast you may not have time to read or even see them. If you hold the down direction on the D-Pad, the messages will remain on screen until you let go.
When choosing a shortcut button, beware that some software checks for buttons held at boot to alter certain behaviors. If your software behaves differently when booted through gekkoboot, ensure the assigned shortcut button is not used in this way. For example, it is not recommended to assign Swiss to the B button as holding B causes Swiss to disable the DVD drive.
Also on Qoob SX, the "backup" BIOS will run before gekkoboot, so it may interfere with some shortcuts.
You should only need to compile gekkoboot if you want to modify to the source code. Otherwise, you can just download prebuilt binaries from the releases tab.
Prerequisites:
- devkitPPC,
the compiler toolchain for GameCube and Wii homebrew
(install the gamecube-dev group)
Ensure that theDEVKITPRO
andDEVKITPPC
environment variables are set correctly - Git, for cloning the repo
- Meson, the build system
- Ninja, the build executor
- 7-Zip (p7zip), to compress the executable
- Python 3, required by build scripts
- A C++ compiler for your build machine, for some build tools
- For Qoob Pro: an IPL ROM dump, see below
Note: on Windows, you'll want to install all the dependencies inside of MSYS2.
# Clone this repo
$ git clone https://github.com/redolution/gekkoboot.git
# Ensure devkitPPC is in PATH
$ export PATH="$DEVKITPPC/bin:$PATH"
# Initialize the build system
$ meson setup . build --cross-file=devkitPPC.ini
# Build it!
$ meson compile -C build
# The binaries will be in the build directory
$ ls build
...
gekkoboot_memcard.gci
gekkoboot_pico.uf2
gekkoboot_qoob_pro.gcb
gekkoboot_viper.vgc
qoob_pro_gekkoboot_upgrade.elf
qoob_sx_gekkoboot_upgrade.elf
...
Qoob Pro requires BS1 (early initialization code) from the original bootrom. This can be obtained from an existing Qoob Pro BIOS or any IPL dump.
To use an existing Qoob Pro BIOS (easiest method),
grab gekkoboot_qoob_pro.gcb
from the latest release.
Alternatively, you can dump the IPL ROM from your own GameCube using Swiss:
- Ensure file management is enabled in Swiss settings: press B, select the gear icon at bottom right, press R until you reach "Advanced Settings", scroll down to "File Management", press right to enable, save and exit.
- Switch to the system device: Select the eject icon at bottom left, scroll right to "System", press A.
- Scroll down to
ipl.bin
, press Z then X, and copy to your SD card. - Copy
ipl.bin
from your SD card to your computer.
You should now have a suitable IPL ROM.
- Rename the file to
ipl.rom
and place it in theres
directory. - If you've already run
meson setup
, run it again with--reconfigure
for it to find the file. - The output should now say
Qoob Pro support: YES
. - Continue building normally.
Footnotes
-
See the Qoob documentation for more information. ↩