* git subrepo pull tools/ZAPD --force subrepo: subdir: "tools/ZAPD" merged: "e02e151c" upstream: origin: "https://github.com/zeldaret/ZAPD.git" branch: "master" commit: "e02e151c" git-subrepo: version: "0.4.3" origin: "https://github.com/ingydotnet/git-subrepo.git" commit: "2f68596" * git subrepo pull tools/decomp-permuter --force subrepo: subdir: "tools/decomp-permuter" merged: "86b1975e" upstream: origin: "https://github.com/simonlindholm/decomp-permuter.git" branch: "main" commit: "86b1975e" git-subrepo: version: "0.4.3" origin: "https://github.com/ingydotnet/git-subrepo.git" commit: "2f68596" * git subrepo pull tools/graphovl --force subrepo: subdir: "tools/graphovl" merged: "eb25be94" upstream: origin: "https://github.com/AngheloAlf/graphovl.git" branch: "master" commit: "eb25be94" git-subrepo: version: "0.4.3" origin: "https://github.com/ingydotnet/git-subrepo.git" commit: "2f68596" * git subrepo pull (merge) tools/z64compress --force subrepo: subdir: "tools/z64compress" merged: "98ef0ac2" upstream: origin: "https://github.com/z64me/z64compress.git" branch: "main" commit: "98ef0ac2" git-subrepo: version: "0.4.3" origin: "https://github.com/ingydotnet/git-subrepo.git" commit: "2f68596" * git subrepo pull tools/ZAPD --force subrepo: subdir: "tools/ZAPD" merged: "45cb0d6b" upstream: origin: "https://github.com/zeldaret/ZAPD.git" branch: "master" commit: "45cb0d6b" git-subrepo: version: "0.4.3" origin: "https://github.com/ingydotnet/git-subrepo.git" commit: "2f68596" * git subrepo pull tools/asm-differ --force subrepo: subdir: "tools/asm-differ" merged: "48e675ff" upstream: origin: "https://github.com/simonlindholm/asm-differ.git" branch: "main" commit: "48e675ff" git-subrepo: version: "0.4.3" origin: "https://github.com/ingydotnet/git-subrepo.git" commit: "2f68596" * git subrepo pull tools/ZAPD --force subrepo: subdir: "tools/ZAPD" merged: "3c00dcb3" upstream: origin: "https://github.com/zeldaret/ZAPD.git" branch: "master" commit: "3c00dcb3" git-subrepo: version: "0.4.3" origin: "https://github.com/ingydotnet/git-subrepo.git" commit: "2f68596" * git subrepo pull tools/asm-differ --force subrepo: subdir: "tools/asm-differ" merged: "47c94c99" upstream: origin: "https://github.com/simonlindholm/asm-differ.git" branch: "main" commit: "47c94c99" git-subrepo: version: "0.4.3" origin: "https://github.com/ingydotnet/git-subrepo.git" commit: "2f68596" * Declare required textures * Name texture, add decomp.me permuter settings * git subrepo pull tools/ZAPD --force subrepo: subdir: "tools/ZAPD" merged: "913810fc" upstream: origin: "https://github.com/zeldaret/ZAPD.git" branch: "master" commit: "913810fc" git-subrepo: version: "0.4.3" origin: "https://github.com/ingydotnet/git-subrepo.git" commit: "2f68596" * git subrepo pull tools/asm-differ --force subrepo: subdir: "tools/asm-differ" merged: "97197f2a" upstream: origin: "https://github.com/simonlindholm/asm-differ.git" branch: "main" commit: "97197f2a" git-subrepo: version: "0.4.3" origin: "https://github.com/ingydotnet/git-subrepo.git" commit: "2f68596" * git subrepo pull tools/ZAPD --force subrepo: subdir: "tools/ZAPD" merged: "623d779f" upstream: origin: "https://github.com/zeldaret/ZAPD.git" branch: "master" commit: "623d779f" git-subrepo: version: "0.4.3" origin: "https://github.com/ingydotnet/git-subrepo.git" commit: "2f68596" * git subrepo pull tools/asm-differ --force subrepo: subdir: "tools/asm-differ" merged: "55bba23a" upstream: origin: "https://github.com/simonlindholm/asm-differ.git" branch: "main" commit: "55bba23a" git-subrepo: version: "0.4.3" origin: "https://github.com/ingydotnet/git-subrepo.git" commit: "2f68596" * git subrepo pull tools/decomp-permuter --force subrepo: subdir: "tools/decomp-permuter" merged: "a20bac94" upstream: origin: "https://github.com/simonlindholm/decomp-permuter.git" branch: "main" commit: "a20bac94" git-subrepo: version: "0.4.3" origin: "https://github.com/ingydotnet/git-subrepo.git" commit: "2f68596"
3.7 KiB
z64compress
z64compress
is a program for compressing Zelda 64 roms: be they retail, hacked traditionally, or custom-built from the Ocarina of Time
or Majora's Mask
reverse engineering projects. It is written in highly efficient C and leverages the power of multithreading to make compression as fast as possible. To reduce overhead on subsequent compressions, an optional cache directory can be specified.
In addition to the default yaz
, it supports some faster and more compact algorithms such as lzo
, ucl
, and aplib
. In order to use these, grab patches or code from my z64enc
repository.
If you add an algorithm, please make sure valgrind
reports no memory leaks or other errors before making a pull request. Thank you!
(By the way, valgrind
works better without the -march=native -mtune=native
optimizations, so turn those off when testing valgrind
.)
Usage
This is a command line application. Learn from these common examples and adapt the arguments to your needs:
compressing oot debug
--in "path/to/in.z64"
--out "path/to/out.z64"
--mb 32
--codec yaz
--cache "path/to/cache"
--dma "0x12F70,1548"
--compress "9-14,28-END"
--threads 4
compressing oot ntsc 1.0
--in "path/to/in.z64"
--out "path/to/out.z64"
--mb 32
--codec yaz
--cache "path/to/cache"
--dma "0x7430,1526"
--compress "10-14,27-END"
--threads 4
compressing mm usa
--in "path/to/in.z64"
--out "path/to/out.z64"
--mb 32
--codec yaz
--cache "path/to/cache"
--dma "0x1A500,1568"
--compress "10-14,23,24,31-END"
--skip "1127"
--repack "15-20,22"
--threads 4
Arguments
--in uncompressed input rom
--out compressed output rom
--matching attempt matching compression at the cost of
some optimizations and reduced performance
--mb how many mb the compressed rom should be
--codec currently supported codecs
yaz
ucl
lzo
aplib
* to use non-yaz codecs, find patches
and code on my z64enc repo
--cache is optional and won't be created if
no path is specified (having a cache
makes subsequent compressions faster)
* pro-tip: linux users who don't want a
cache to persist across power cycles
can use the path "/tmp/z64compress"
--dma specify dmadata address and count
--compress enable compression on specified files
--skip disable compression on specified files
--repack handles Majora's Mask archives
--threads optional multithreading;
exclude this argument to disable it
--only-stdout reserve stderr for errors and print
everything else to stdout
arguments are executed as they
are parsed, so order matters!
Building
I have included shell scripts for building Linux and Windows binaries. Windows binaries are built using a cross compiler (I recommend MXE
).
Alternatively, a Makefile-based build system is provided. Choose the target platform with make TARGET=linux64|linux32|win32
, default is linux64. If building for windows with a cross compiler, specify the compiler executable with make TARGET=win32 CC=/path/to/executable
.