- This repo contains a full decompilation of Super Mario 64 (J), (U), (E), and (SH).
- Naming and documentation of the source code and data structures are in progress.
- Beyond Nintendo 64, it can also target Linux, Windows and the Wii U natively.
This repo does not include all assets necessary for compiling the game. A prior copy of the game is required to extract the assets.
- Follow the instructions in the ProgrammingOnTheU tutorial to get the prerequisites for your building system: https://github.com/yawut/ProgrammingOnTheU.
- For Windows, you will mainly be using MSYS2.
- Install git, make, python3 and SDL2 using pacman:
(dkp-)pacman -S git make python3 wiiu-sdl2
. - Clone the repo:
git clone https://github.com/aboood40091/sm64-port.git
, which will create a directorysm64-port
and then enter itcd sm64-port
.
- Make sure
TARGET_WII_U
is set to 1 in the Makefile. (TARGET_WII_U ?= 1
)
- Place a Super Mario 64 ROM called
baserom.<VERSION>.z64
into the repository's root directory for asset extraction, whereVERSION
can beus
,jp
, oreu
. - Run
make
to build. Qualify the version throughmake VERSION=<VERSION>
. Add-j4
to improve build speed (hardware dependent based on the amount of CPU cores available). - The executable binary will be located at
build/<VERSION>_wiiu/sm64.<VERSION>.f3dex2e.rpx
. - You can then proceed to install the RPX to the home menu or as a homebrew app in the Homebrew Launcher.
- Install prerequisites (Ubuntu):
sudo apt install -y git build-essential pkg-config libusb-1.0-0-dev libsdl2-dev
. - Clone the repo:
git clone https://github.com/aboood40091/sm64-port.git
, which will create a directorysm64-port
and then enter itcd sm64-port
.
- Make sure
TARGET_WII_U
is set to 0 in the Makefile. (TARGET_WII_U ?= 0
)
- Place a Super Mario 64 ROM called
baserom.<VERSION>.z64
into the repository's root directory for asset extraction, whereVERSION
can beus
,jp
, oreu
. - Run
make
to build. Qualify the version throughmake VERSION=<VERSION>
. Add-j4
to improve build speed (hardware dependent based on the amount of CPU cores available). - The executable binary will be located at
build/<VERSION>_pc/sm64.<VERSION>.f3dex2e
.
- Install and update MSYS2, following all the directions listed on https://www.msys2.org/.
- From the start menu, launch MSYS2 MinGW and install required packages depending on your machine (do NOT launch "MSYS2 MSYS"):
- 64-bit: Launch "MSYS2 MinGW 64-bit" and install:
pacman -S git make python3 mingw-w64-x86_64-gcc
- 32-bit (will also work on 64-bit machines): Launch "MSYS2 MinGW 32-bit" and install:
pacman -S git make python3 mingw-w64-i686-gcc
- Do NOT by mistake install the package called simply
gcc
.
- The MSYS2 terminal has a current working directory that initially is
C:\msys64\home\<username>
(home directory). At the prompt, you will see the current working directory in yellow.~
is an alias for the home directory. You can change the current working directory toMy Documents
by enteringcd /c/Users/<username>/Documents
. - Clone the repo:
git clone https://github.com/aboood40091/sm64-port.git
, which will create a directorysm64-port
and then enter itcd sm64-port
.
- Make sure
TARGET_WII_U
is set to 0 in the Makefile. (TARGET_WII_U ?= 0
)
- Place a Super Mario 64 ROM called
baserom.<VERSION>.z64
into the repository's root directory for asset extraction, whereVERSION
can beus
,jp
, oreu
. - Run
make
to build. Qualify the version throughmake VERSION=<VERSION>
. Add-j4
to improve build speed (hardware dependent based on the amount of CPU cores available). - The executable binary will be located at
build/<VERSION>_pc/sm64.<VERSION>.f3dex2e.exe
inside the repository.
- If you get
make: gcc: command not found
ormake: gcc: No such file or directory
although the packages did successfully install, you probably launched the wrong MSYS2. Read the instructions again. The terminal prompt should contain "MINGW32" or "MINGW64" in purple text, and NOT "MSYS". - If you get
Failed to open baserom.us.z64!
you failed to place the baserom in the repository. You can writels
to list the files in the current working directory. If you are in thesm64-port
directory, make sure you see it here. - If you get
make: *** No targets specified and no makefile found. Stop.
, you are not in the correct directory. Make sure the yellow text in the terminal ends withsm64-port
. Usecd <dir>
to enter the correct directory. If you writels
you should see all the project files, includingMakefile
if everything is correct. - If you get any error, be sure MSYS2 packages are up to date by executing
pacman -Syu
andpacman -Su
. If the MSYS2 window closes immediately after opening it, restart your computer. - When you execute
gcc -v
, be sure you seeTarget: i686-w64-mingw32
orTarget: x86_64-w64-mingw32
. If you seeTarget: x86_64-pc-msys
, you either opened the wrong MSYS start menu entry or installed the incorrect gcc package. - When switching between building for other platforms, run
make -C tools clean
first to allow for the tools to recompile on the new platform. This also helps when switching between shells like WSL and MSYS2.
For help with building the Wii U version, do not hesitate to join the ForTheUsers Discord Server linked below.
The code can be debugged using gdb
. On Linux install the gdb
package and execute gdb <executable>
. On MSYS2 install by executing pacman -S winpty gdb
and execute winpty gdb <executable>
. The winpty
program makes sure the keyboard works correctly in the terminal. Also consider changing the -mwindows
compile flag to -mconsole
to be able to see stdout/stderr as well as be able to press Ctrl+C to interrupt the program. In the Makefile, make sure you compile the sources using -g
rather than -O2
to include debugging symbols. See any online tutorial for how to use gdb.
For the Wii U port, you can log using WHB, which will log to both the console's native OSReport and Udp.
It is possible to build N64 ROMs as well with this repository. See https://github.com/n64decomp/sm64 for instructions.
sm64
├── actors: object behaviors, geo layout, and display lists
├── asm: handwritten assembly code, rom header
│ └── non_matchings: asm for non-matching sections
├── assets: animation and demo data
│ ├── anims: animation data
│ └── demos: demo data
├── bin: C files for ordering display lists and textures
├── build: output directory
├── data: behavior scripts, misc. data
├── doxygen: documentation infrastructure
├── enhancements: example source modifications
├── include: header files
├── levels: level scripts, geo layout, and display lists
├── lib: SDK library code
├── rsp: audio and Fast3D RSP assembly code
├── sound: sequences, sound samples, and sound banks
├── src: C source code for game
│ ├── audio: audio code
│ ├── buffers: stacks, heaps, and task buffers
│ ├── engine: script processing engines and utils
│ ├── game: behaviors and rest of game source
│ ├── goddard: Mario intro screen
│ ├── menu: title screen and file, act, and debug level selection menus
│ └── pc: port code, audio and video renderer
├── text: dialog, level names, act names
├── textures: skybox and generic texture data
└── tools: build tools
Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change.
Run clang-format
on your code to ensure it meets the project's coding standards.
Official Discord: https://discord.gg/7bcNTPK
ForTheUsers Discord: https://discord.gg/F2PKpEj