Skip to content

HylianFreddy/oot3d

 
 

Repository files navigation

The Legend of Zelda: Ocarina of Time 3D

This is a WIP decompilation of The Legend of Zelda: Ocarina of Time 3D. 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. The only build currently supported is the USA version.

It builds the following ROM:

  • oot3d_usa.3ds
  • code.bin md5: 20c7ec6288ba0af4feb6db646c6cc6d5
  • romfs.bin md5: d2a0fa58cfb52ca9e584170195821364

For simplicity, this repository only enforces binary matching on the portions of the ROM which contain compiled source code and assets.

Note: This repository does not include any of the assets necessary to build the ROM. A prior copy of the game is required to extract the needed assets.

Website: https://zelda64.dev/

Discord: https://discord.zelda64.dev

Installation

To set up the repository, place a USA version of The Legend of Zelda: Ocarina of Time 3D (USA) in the root directory of the repository and name it baserom.3ds. Any revision (v0 or v1) and either trimmed or untrimmed roms should be able to produce a correct repository.

Place armcc and armasm from RVCT4.0 [Build 821] in the root directory of the repository. These legacy tools are available for public download from ARM. Early research shows that these tools are sufficiently similar to those used to compile the original game.

To begin, run make init. This will compile the some of the necessary tools, extract what is needed from the rom, create a disassembly, and build the rom. If all goes well, a new rom called "oot3d_usa.3ds" should be built and the following text should be printed:

build/code.bin: OK
build/romfs.bin: OK

Note: to speed up the build, you can pass -jN, where N is the number of threads to use in the build.

Another Note: If your build hangs, try closing your terminal and running make again. This is a known issue that often happens when passing -jN.

Building

Run make.

Contributing

If you decompile a function or data, remove the GLOBAL_ASM for that function or data. If you rename a function, you will also need to change its name in oot.ld (oot.ld is the linker script that handles global ordering). For data, replace ASM_[FileName] with [FileName].data in oot.ld. This process is likely to change. If you have worked previously on other matching decomp projects (especially oot or mm), check out the wiki on this repo for a quick guide targetted towards you.

Most discussions happen on our Discord Server, where you are welcome to ask if you need help getting started, or if you have any questions regarding this project and other decompilation projects.

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C++ 82.9%
  • Python 11.0%
  • C 4.4%
  • Kaitai Struct 0.9%
  • Makefile 0.7%
  • Shell 0.1%