2024-01-22 01:39:28 +03:00
[![Discord Invitation ](https://discordapp.com/api/guilds/1190102597521133700/widget.png?style=banner2 'Starfox 64' )](https://discord.gg/tuwdmuTTqc)
2024-01-09 02:57:46 +03:00
2023-10-07 18:39:22 +03:00
# Starfox 64 (US) REV 1.1
2023-12-23 02:56:06 +03:00
This is a WIP **matching decompilation** of ** *Starfox 64***. The purpose of the project is to recreate a source code base for the game from scratch, using information found inside the game along with static and/or dynamic analysis.
2023-10-07 18:39:22 +03:00
It currently builds the following ROM:
2024-05-12 03:11:29 +03:00
* starfox64.us.rev1.z64 `MD5: 741a94eee093c4c8684e66b89f8685e8`
2023-10-07 18:39:22 +03:00
**This repo does not include any assets or assembly code necessary for compiling the ROM. A prior copy of the game is required to extract the required assets.**
## Installation
2024-01-01 23:29:08 +03:00
#### 1. Install build dependencies
2023-10-07 18:39:22 +03:00
### Windows
For Windows 10, install WSL and a distribution by following this
[Windows Subsystem for Linux Installation Guide ](https://docs.microsoft.com/en-us/windows/wsl/install-win10 ).
2023-10-08 17:25:33 +03:00
We recommend using Debian or Ubuntu 22.04 Linux distributions.
2023-10-07 18:39:22 +03:00
### Linux (Native or under WSL / VM)
The build process has the following package requirements:
* make
* git
* build-essential
* binutils-mips-linux-gnu
* python3
* pip3
* libpng-dev
Under Debian / Ubuntu (which we recommend using), you can install them with the following commands:
```bash
sudo apt update
2024-02-28 21:55:00 +03:00
sudo apt install make cmake git build-essential binutils-mips-linux-gnu python3 python3-pip clang-format-14 clang-tidy
2023-12-26 23:55:57 +03:00
```
### MacOS
Install [Homebrew ](https://brew.sh ) and the following dependencies:
```
brew update
brew install coreutils make pkg-config tehzz/n64-dev/mips64-elf-binutils
2023-10-07 18:39:22 +03:00
```
#### 2. Clone the repository
Create your own fork of the repository at `https://github.com/sonicdcer/sf64` . Then clone your fork where you wish to have the project, with the command:
```bash
git clone https://github.com/< YOUR_USERNAME > /sf64.git
```
This will copy the GitHub repository contents into a new folder in the current directory called `sf64` . Change into this directory before doing anything else:
```bash
cd sf64
```
#### 3. Install python dependencies
2023-10-12 20:01:43 +03:00
The build process has a few python packages required that are located in `/tools/requirements-python.txt` .
2023-10-07 18:39:22 +03:00
To install them simply run in a terminal:
```bash
2024-05-06 05:10:44 +03:00
python3 -m pip install -r ./tools/requirements-python.txt
2023-10-07 18:39:22 +03:00
```
2024-05-06 05:10:44 +03:00
* Depending on your python version, you might need to add --break-system-packages, or use venv.
2023-10-07 18:39:22 +03:00
2023-12-06 15:20:22 +03:00
#### 4. Update submodules & build toolchain
2023-10-14 15:33:21 +03:00
```bash
git submodule update --init --recursive
2023-12-10 22:27:26 +03:00
make toolchain
2023-10-14 15:33:21 +03:00
```
#### 5. Prepare a base ROM
2023-10-07 18:39:22 +03:00
2024-05-12 03:11:29 +03:00
Copy your ROM to the root of this new project directory, and rename the file of the baserom to reflect the version of ROM you are using. ex: `baserom.us.rev1.z64`
2024-05-06 05:12:56 +03:00
* Make sure the ROM is the US version, revision 1.1 (REV A).
2023-10-07 18:39:22 +03:00
2023-10-14 15:33:21 +03:00
#### 6. Make and Build the ROM
2023-10-07 18:39:22 +03:00
To start the extraction/build process, run the following command:
```bash
make init
```
2024-01-05 08:07:59 +03:00
This will create the build folders, a new folder with the assembly as well as containing the disassembly of nearly all the files containing code.
2023-10-07 18:39:22 +03:00
2024-05-12 03:11:29 +03:00
this make target will also build the ROM. If all goes well, a new ROM called "starfox64.us.rev1.z64" should be built and the following text should be printed:
2023-10-07 18:39:22 +03:00
```bash
2024-05-12 03:11:29 +03:00
741a94eee093c4c8684e66b89f8685e8 build/starfox64.us.rev1.z64
./build/starfox64.us.rev1.z64: OK
2023-10-07 18:39:22 +03:00
```
If you instead see the following:
```bash
2024-05-12 03:11:29 +03:00
./build/starfox64.us.rev1.z64: FAILED
2023-10-07 18:39:22 +03:00
md5sum: WARNING: 1 computed checksum did NOT match
```
This means that something is wrong with the ROM's contents. Either the base files are incorrect due to a bad ROM, or some of the code is not matching.
2023-10-16 01:18:54 +03:00
2023-10-16 01:19:33 +03:00
From now on you should be able to build the rom by running `make` .