A decompilation of Perfect Dark. (MIRROR of https://gitlab.com/ryandwyer/perfect-dark)
Go to file
2022-09-08 23:02:20 +10:00
docs Decompile bgunTickGunLoad 2022-07-10 21:36:13 +10:00
include Decompile bootPhase1 2022-08-22 20:24:50 +10:00
ld Decompile mempakPrepare 2022-09-08 23:02:20 +10:00
src Decompile mempakPrepare 2022-09-08 23:02:20 +10:00
tools Fix some comments and white space issues 2022-07-15 17:57:31 +10:00
.gitignore Introduce mkrom 2021-10-23 11:27:59 +10:00
.gitmodules Remove support for qemu-irix and require the use of recomp 2022-02-15 23:24:53 +10:00
checksums.jpn-final.md5 Merge lang json files 2022-03-10 23:43:52 +10:00
checksums.ntsc-1.0.md5 Merge lang json files 2022-03-10 23:43:52 +10:00
checksums.ntsc-beta.md5 Merge lang json files 2022-03-10 23:43:52 +10:00
checksums.ntsc-final.md5 Merge lang json files 2022-03-10 23:43:52 +10:00
checksums.pal-beta.md5 Merge lang json files 2022-03-10 23:43:52 +10:00
checksums.pal-final.md5 Merge lang json files 2022-03-10 23:43:52 +10:00
Makefile Rename src/files/setup to src/setups 2022-08-17 17:55:15 +10:00
README.md Remove support for qemu-irix and require the use of recomp 2022-02-15 23:24:53 +10:00
stagetable.txt Initial commit 2019-09-06 08:09:40 +10:00

Perfect Dark Decompilation (WIP)

This repository contains a work-in-progress decompilation of Perfect Dark for the Nintendo 64.

Status

See the Perfect Dark Decompilation Status Page.

Installation Requirements

For Arch Linux:

  • Install these packages: binutils fakeroot gcc make python vim
  • Install from AUR: armips mips64-elf-binutils

For Debian and Ubuntu:

  • Install these packages: binutils-mips-linux-gnu build-essential libc6-dev-i386 libcapstone3 libcapstone-dev make
  • Compile and install armips

ROM Versions

Perfect Dark has six known versions:

ROM ID Description MD5 Checksum
ntsc-beta NTSC 6.4 beta aa93f4df16fceada399a749f5ad2f273
ntsc-1.0 NTSC 8.7 final (the initial, buggy release) 7f4171b0c8d17815be37913f535e4e93
ntsc-final NTSC 8.7 final e03b088b6ac9e0080440efed07c1e40f
pal-beta PAL 28.7 beta ad2de210a3455ba5ec541f0c78d91444
pal-final PAL 8.7 final d9b5cd305d228424891ce38e71bc9213
jpn-final JPN 8.9 final 538d2b75945eae069b29c46193e74790

The project uses the $ROMID environment variable to know which version to work with. If not set, it defaults to ntsc-final. You can change it by running something like export ROMID=ntsc-1.0.

Extracting the base ROM

Before you do anything you need an existing ROM to extract assets from.

  1. Save your existing ROM file into the root of the repository with the name pd.ntsc-final.z64. It should not be byteswapped (the first four bytes should be 0x80371240).
  2. Run make extract.

This will extract assets to src/assets. If any asset already exists then it will not be overwritten. This means you can modify assets as desired, and your changes will not be overwritten if you run the extract command again.

The extract command will also create an extracted/ntsc-final directory. This directory contains some compiled code segments from the ROM and is only used for comparison purposes.

Compiling

  • Run git submodule update --init --recursive. You only have to do this once.
  • Run make -j to build the ROM. The ROM will be written to build/ntsc-final/pd.z64.

How do I know the built files are matching?

Run make followed by make test. If make test produces no output then the compiled project is matching.

You can also md5sum your base ROM with the built ROM and check they have the same hash: md5sum pd.ntsc-final.z64 build/ntsc-final/pd.z64.