4.6 KiB
- First time setup
- Firmware backup/update
- Internal flashcart state
- Uploading game/save
- Downloading save
- Running 64DD games
- Direct boot option
- Debug terminal
- LED blink patters
First time setup
- Make sure
python3
andpip3
are installed in your system - Grab latest
SC64.zip
package from GitHub releases - Extract package contents to a folder
- Install requirements:
pip3 install -r requirements.txt
- Run
python3 sc64.py --help
to check if requirements are installed - Run
python3 sc64.py --print-state
to check if SC64 is detected
Firmware backup/update
Keeping SC64 firmware up to date is highly recommended. sc64.py
script is tightly coupled with specific firmware versions and will error out when it detects unsupported firmware version.
To download and backup current version of SC64 firmware run python3 sc64.py --backup-firmware sc64_firmware_backup.bin
To update SC64 firmware run python3 sc64.py --update-firmware sc64_firmware.bin
Internal flashcart state
SC64 holds some configuration after script has exit. To reset it simply run: python3 sc64.py --reset-state
. Internal flashcart state can be checked by running: python3 sc64.py --print-state
Uploading game/save
python3 sc64.py --boot rom --rom path_to_rom.n64 --save-type eeprom-4k --save path_to_save.sav
Replace path_to_rom.n64
/ eeprom-4k
/ path_to_save.sav
with appropriate values for desired game. Check included help in script to check available save types.
Arguments --save-type
and/or --save
can be omitted if game doesn't require any save.
Downloading save
python3 sc64.py --backup-save path_to_save.sav
Replace path_to_save.sav
with appropriate value. Specifying save type isn't required when set correctly previously.
Running 64DD games
64DD games require DDIPL ROM and disk images. To run disk game type python3 sc64.py --boot ddipl --ddipl path_to_ddipl.n64 --disk path_to_disk_1.ndd --disk path_to_disk_2.ndd
.
Replace path_to_ddipl.n64
/ path_to_disk_x.ndd
with appropriate values. Argument --disk
can be specified multiple times. Only .ndd
disk format is supported currently. To change inserted disk press button on the back of SC64 flashcart.
Direct boot option
If booting game through included bootloader isn't a desired option then flashcart can be put in special mode that omits this step.
Run python3 sc64.py --boot direct-rom --rom path_to_rom.n64
to disable bootloader during boot and console reset. By default sc64.py
script will try to guess CIC seed and calculate checksum. To change seed or disable CIC use --cic-params 0x3F,0
argument with appropriate values. Refer to included help in script for values meaning. This option is useful only for very specific cases (e.g. testing custom IPL3 or running SC64 on top of GameShark).
Debug terminal
sc64.py
supports UNFLoader protocol and has same functionality implemented as aforementioned program. Use argument --debug
to activate it.
LED blink patters
LED on SC64 board can blink in certain situations. Most of them during normal use are related to SD card access. Here's list of blink patters meaning:
Pattern | Meaning |
---|---|
Nx [Short ON - Short OFF] | SD card is being accessed (initialization or data read/write) or save writeback is in progress |
Nx [Medium ON - Long OFF] | CIC region didn't match, please power off console and power on again |
2x [Very short ON - Short OFF] | Pattern used during firmware update process, it means that specific part of firmware has started programming |
10x [Very short ON - Very short OFF] | Firmware has been successfully updated |
30x [Long ON - Long OFF] | There was serious problem during firmware update, device is most likely bricked |
Nx means that blink count is varied.
LED blinking on SD card access can be disabled through sc64.py
script. Please refer to included help for option to change the LED behavior.