Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/zeldaret/oot-vc
Decompilation of the Wii Virtual Console Emulator for Ocarina of Time (JP)
https://github.com/zeldaret/oot-vc
Last synced: 2 days ago
JSON representation
Decompilation of the Wii Virtual Console Emulator for Ocarina of Time (JP)
- Host: GitHub
- URL: https://github.com/zeldaret/oot-vc
- Owner: zeldaret
- Created: 2020-10-27T14:31:27.000Z (about 4 years ago)
- Default Branch: main
- Last Pushed: 2024-10-16T13:08:08.000Z (3 months ago)
- Last Synced: 2025-01-01T22:08:00.351Z (9 days ago)
- Language: Assembly
- Size: 8.05 MB
- Stars: 65
- Watchers: 7
- Forks: 13
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
oot-vc
[![Build Status]][actions] ![oot-j] ![oot-u] ![oot-e] [![Discord Badge]][discord]
=============[Build Status]: https://github.com/zeldaret/oot-vc/actions/workflows/build.yml/badge.svg
[actions]: https://github.com/zeldaret/oot-vc/actions/workflows/build.yml[oot-j]: https://img.shields.io/endpoint?label=oot-j&url=https%3A%2F%2Fprogress.decomp.club%2Fdata%2Foot-vc%2Foot-j%2Fdol%2F%3Fmode%3Dshield%26measure%3Dcode
[oot-u]: https://img.shields.io/endpoint?label=oot-u&url=https%3A%2F%2Fprogress.decomp.club%2Fdata%2Foot-vc%2Foot-u%2Fdol%2F%3Fmode%3Dshield%26measure%3Dcode
[oot-e]: https://img.shields.io/endpoint?label=oot-e&url=https%3A%2F%2Fprogress.decomp.club%2Fdata%2Foot-vc%2Foot-e%2Fdol%2F%3Fmode%3Dshield%26measure%3Dcode
[Discord Badge]: https://img.shields.io/discord/688807550715560050?color=%237289DA&logo=discord&logoColor=%23FFFFFF
[discord]: https://discord.zelda.deco.mp/A work-in-progress decompilation of the N64 emulator used in the Wii Virtual Console releases of N64 games like The Legend of Zelda: Ocarina of Time.
Supported versions:
- `oot-j`: The Legend of Zelda: Ocarina of Time (Wii Virtual Console) - Japan
- `oot-u`: The Legend of Zelda: Ocarina of Time (Wii Virtual Console) - North America
- `oot-e`: The Legend of Zelda: Ocarina of Time (Wii Virtual Console) - Europe/AustraliaCurrently the decompilation mainly targets the `oot-j` version.
## Building
### Requirements
You will need the following dependencies:
* git
* ninja
* python3
* wine (for macOS or non-x86 Linux)
* clang-format (optional)#### Ubuntu/Debian/Windows (WSL)
You can install the dependencies with the following commands:
```
sudo apt-get update
sudo apt-get install git ninja-build python3
```#### macOS
You can install dependencies via Homebrew with the following command:
```
brew install git ninja python3
brew install --cask --no-quarantine gcenx/wine/wine-crossover
```#### Windows (Native)
You will need the following dependencies:
- [ninja.exe](https://github.com/ninja-build/ninja/releases/latest)
- Python (make sure to add it to your PATH during the installation)
- [Git for Windows](https://www.git-scm.com/downloads)You need to add ``C:\Program Files\Git\bin`` to your system's PATH (not the user one) in order to execute bash scripts properly.
To get objdiff to work properly you also need to add the path to the folder containing ``ninja.exe`` to the system's PATH.
### Instructions
1. Clone the repo using `git clone https://github.com/zeldaret/oot-vc`.
2. Extract the following binary containing the N64 emulator from the wad of the version you want to build:
* `content1.app`
Then, copy the app file and place it in the repo as `orig//content1.app`.
You can use [gzinject](https://github.com/krimtonz/gzinject) to perform both of this extraction step.
3. Run `python3 configure.py` to generate the build. (Note: on Windows you might need to run ``python configure.py``.)
4. Run `ninja` to build the `oot-j` version, or run `ninja ` to build another version.
## Development Tools
### Scripts
* `./dol-diff ` will run `dtk dol diff` to show the first differing symbol if the build does not match.
* `./dol-apply ` will run `dtk dol apply` to sync symbols (e.g. if a function was renamed in the repo).
* `./format` will format all source files with `clang-format`.### objdiff
For local decompilation testing, start the objdiff GUI and open this directory as the project directory.
Currently `objdiff` may not work properly on files using asm-processor (i.e. files with `asm_processor=True` in `configure.py`).### asm-differ (diff.py)
First, copy a matching build to the `expected/` directory to diff against:
```
mkdir expected
cp -r build expected/
```Then run e.g. `./diff.py -mwo3 xlMain` to diff a function for `oot-j`, or e.g. `./diff.py -mwo3 xlMain -v VERSION` to diff a function for another version.
### decomp.me
Run `tools/decompme.py ` (e.g. `tools/decompme.py src/emulator/cpu.c asm/non_matchings/cpu/cpuExecute.s`) to create a
[decomp.me](https://decomp.me/) scratch for a function. The C file and all of its included headers will be used as the context.### Permuter
To import a function for [decomp-permuter](https://github.com/simonlindholm/decomp-permuter), ensure `powerpc-eabi-objdump` binary
is on your `PATH` (for instance by adding `tools/binutils` from this project) and run something like```sh
path/to/permuter/import.py src/emulator/cpu.c asm/non_matchings/cpu/cpuExecute.s
path/to/permuter/permuter.py nonmatchings/cpuExecute -j 8
```Sometimes you may need to tweak the source in order for things to import
correctly, for example by explicitly marking auto-inlined functions as `inline`.