mirror of
https://github.com/notwa/mm
synced 2025-01-04 18:08:04 -08:00
describe how to use the Lua and asm stuff
This commit is contained in:
parent
43315e1ea3
commit
a171559727
4 changed files with 122 additions and 22 deletions
|
@ -3,7 +3,7 @@
|
||||||
These are written for
|
These are written for
|
||||||
[the latest revision of Bizhawk.][biz]
|
[the latest revision of Bizhawk.][biz]
|
||||||
|
|
||||||
[biz]: https://github.com/TASVideos/bizhawk/
|
[biz]: //github.com/TASVideos/bizhawk/
|
||||||
|
|
||||||
Note that some scripts lack full support for Ocarina of Time.
|
Note that some scripts lack full support for Ocarina of Time.
|
||||||
|
|
||||||
|
@ -63,7 +63,7 @@ TODO
|
||||||
#### monitor epona.lua
|
#### monitor epona.lua
|
||||||
used to investigate [this glitch with unloading Epona.][eponaglitch]
|
used to investigate [this glitch with unloading Epona.][eponaglitch]
|
||||||
|
|
||||||
[eponaglitch]: https://www.youtube.com/watch?v=kX0ZcIS8P84
|
[eponaglitch]: //www.youtube.com/watch?v=kX0ZcIS8P84
|
||||||
|
|
||||||
#### monitor event flags.lua
|
#### monitor event flags.lua
|
||||||
Monitors event flags,
|
Monitors event flags,
|
||||||
|
@ -78,7 +78,7 @@ using human-readable English names.
|
||||||
Provides the function `dump_all_exits(fn)`
|
Provides the function `dump_all_exits(fn)`
|
||||||
which produces [a large csv file.][csv]
|
which produces [a large csv file.][csv]
|
||||||
|
|
||||||
[csv]: https://eaguru.guru/t/_exits.csv
|
[csv]: //eaguru.guru/t/_exits.csv
|
||||||
|
|
||||||
#### monitor misc.lua
|
#### monitor misc.lua
|
||||||
Monitors unknown regions of memory.
|
Monitors unknown regions of memory.
|
||||||
|
|
|
@ -99,7 +99,7 @@ where:
|
||||||
* [two digits]: version number of a release build for the N64
|
* [two digits]: version number of a release build for the N64
|
||||||
* GC: Gamecube
|
* GC: Gamecube
|
||||||
* DE: Demo (includes Debug features)
|
* DE: Demo (includes Debug features)
|
||||||
* DE: Debug
|
* DB: Debug
|
||||||
* MQ: Master Quest
|
* MQ: Master Quest
|
||||||
|
|
||||||
### menus/\*
|
### menus/\*
|
||||||
|
|
136
README.md
136
README.md
|
@ -2,12 +2,112 @@
|
||||||
|
|
||||||
i like to muck around in the memory of these games.
|
i like to muck around in the memory of these games.
|
||||||
|
|
||||||
those who are more interested in the ROM will find [the binary template repo][bt]
|
those who are more interested in the ROM may find [the binary template repo][bt]
|
||||||
more resourceful.
|
more resourceful.
|
||||||
|
|
||||||
[bt]: https://github.com/EntranceJew/zelda-binary-templates
|
[bt]: //github.com/EntranceJew/zelda-binary-templates
|
||||||
|
|
||||||
# Majora's Mask
|
## Lua Scripts
|
||||||
|
|
||||||
|
this repo contains a ton of Lua scripts
|
||||||
|
written for [the latest version of Bizhawk.][bizhawk]
|
||||||
|
all the scripts you'll want to use are in the root Lua directory,
|
||||||
|
and their dependencies are in further subdirectories.
|
||||||
|
that means, if you want to use a script,
|
||||||
|
you **must** preserve the directory structure.
|
||||||
|
you **cannot,** say, extract one file from [this repo's archive][arch]
|
||||||
|
and expect it to work.
|
||||||
|
[bizhawk]: //github.com/tasvideos/bizhawk
|
||||||
|
[arch]: //github.com/notwa/mm/archive/master.zip
|
||||||
|
|
||||||
|
a summary of each script is available in [the Lua README.md file,][luarm]
|
||||||
|
and another for [the library files][librm] that the scripts use.
|
||||||
|
|
||||||
|
[luarm]: /Lua/README.md
|
||||||
|
[librm]: /Lua/lib/README.md
|
||||||
|
|
||||||
|
of these, you probably came for `cheat menu.lua`
|
||||||
|
this script will bind your L button to open an on-screen menu
|
||||||
|
allowing you to control many aspects of the game.
|
||||||
|
|
||||||
|
![cheat menu.lua in action](/img/M_US10.2016-10-02%2019.02.17.png)
|
||||||
|
|
||||||
|
of immediate interest are the classic levitation and run-fast cheats,
|
||||||
|
but also the menu of warps to any area and any entrance in the game.
|
||||||
|
you can also change your Z-Targeting method to Hold in the 2nd
|
||||||
|
page of the Progress menu, in case you forgot to change it in-game.
|
||||||
|
|
||||||
|
## Assembly Hacks
|
||||||
|
|
||||||
|
i have written a handful of ROM and RAM hacks for Majora's Mask and Ocarina of Time.
|
||||||
|
these have all been written in the custom assembler syntax of
|
||||||
|
[_lips,_ a MIPS assembler written in Lua.][lips]
|
||||||
|
_lips_ is included in this repository; you do not need to acquire it separately.
|
||||||
|
[lips]: //github.com/notwa/lips
|
||||||
|
|
||||||
|
you only need to run `Lua/inject.lua` in Bizhawk
|
||||||
|
to run the *RAM hacks* — that is, modifications that act
|
||||||
|
directly on the game's RAM while it runs; not modifying the ROM.
|
||||||
|
|
||||||
|
for the *ROM hacks,* you will need to set up a lot more.
|
||||||
|
you will need:
|
||||||
|
|
||||||
|
* **bash 4.3** to run the shell scripts responsible for
|
||||||
|
automatically running all the following software.
|
||||||
|
|
||||||
|
* **Python 3.4** to run the scripts responsible for
|
||||||
|
splitting the ROM into files, and merging those files into a single ROM again.
|
||||||
|
|
||||||
|
* **LuaJIT 2.0** to run the *lips* assembler responsible for
|
||||||
|
turning the assembly files into executable binary code.
|
||||||
|
you might manage to use the *Lua 5.1* interpreter,
|
||||||
|
but this is not strictly supported.
|
||||||
|
|
||||||
|
* **gcc 4.9** *or* **clang 3.6** to compile the programs responsible for
|
||||||
|
(de)compressing the *Yaz* archive files, and for computing checksums.
|
||||||
|
|
||||||
|
the versions listed above are rough estimates, and newer versions of software
|
||||||
|
are likely to work fine.
|
||||||
|
|
||||||
|
if you're on Windows, and you're not afraid of the (\*nix) console,
|
||||||
|
you can set up [cygwin](//cygwin.com)
|
||||||
|
to install binaries of bash, python, and gcc.
|
||||||
|
then all that's left is to compile LuaJIT yourself.
|
||||||
|
|
||||||
|
last, but not least, you will need the approriate ROM for the ROM hack.
|
||||||
|
you will probably need to change the hard-coded paths to the ROMs.
|
||||||
|
*(note to self: change scripts to take the required ROM as their first argument)*
|
||||||
|
|
||||||
|
finally, you just run the appropriate shell scripts
|
||||||
|
for the ROM hacks you want to produce. for example:
|
||||||
|
```
|
||||||
|
$ cd asm
|
||||||
|
$ ./mm-bq
|
||||||
|
zelda@srd44
|
||||||
|
00-07-31 17:04:16
|
||||||
|
uncompressed 0031 V00B3C000
|
||||||
|
ratio: 59%
|
||||||
|
compressed 0031 V00B3C000
|
||||||
|
ratio: 59%
|
||||||
|
compressed 1552 V02EE7040
|
||||||
|
ratio: 1%
|
||||||
|
bootcode: 6105
|
||||||
|
crcs: 5CF5359C A893E696
|
||||||
|
```
|
||||||
|
|
||||||
|
### blah
|
||||||
|
|
||||||
|
to compile the C programs, you might need to pass `-std=gnu11`. basically:
|
||||||
|
```
|
||||||
|
gcc -std=gnu11 -Wall -Ofast z64yaz0.c -o z64yaz0
|
||||||
|
gcc -std=gnu11 -Wall -Ofast z64crc.c -o z64crc
|
||||||
|
```
|
||||||
|
|
||||||
|
in the future, it'd be nice to only depend on LuaJIT to build ROMs.
|
||||||
|
|
||||||
|
cygwin's newline mangling will be the death of me.
|
||||||
|
|
||||||
|
# Miscellaneous notes on Majora's Mask
|
||||||
|
|
||||||
for brevity, all addresses written here are given for the original US version.
|
for brevity, all addresses written here are given for the original US version.
|
||||||
refer to the spreadsheets or Lua tables for their equivalent in other versions.
|
refer to the spreadsheets or Lua tables for their equivalent in other versions.
|
||||||
|
@ -33,19 +133,19 @@ some sheets have been put together to dump data in. some of them can be used to
|
||||||
*spoilers:* no desirable results besides light arrows, if it were even possible.
|
*spoilers:* no desirable results besides light arrows, if it were even possible.
|
||||||
_potential crashes are not taken account for._
|
_potential crashes are not taken account for._
|
||||||
|
|
||||||
[eventflags]: https://docs.google.com/spreadsheets/d/181V9dR5vBROdCVB4FkljG5oz2O4gGU5OTAkoPQX9X10/edit?usp=sharing
|
[eventflags]: //docs.google.com/spreadsheets/d/181V9dR5vBROdCVB4FkljG5oz2O4gGU5OTAkoPQX9X10/edit?usp=sharing
|
||||||
[gs_addrs]: https://docs.google.com/spreadsheets/d/1HD8yZM1Jza3O8zO28n3k_Rjwdx58RSMA03915l51oDA/edit?usp=sharing
|
[gs_addrs]: //docs.google.com/spreadsheets/d/1HD8yZM1Jza3O8zO28n3k_Rjwdx58RSMA03915l51oDA/edit?usp=sharing
|
||||||
[noice]: /Lua/addrs/M/common.lua
|
[noice]: /Lua/lib/addrs/M/common.lua
|
||||||
[gim]: https://docs.google.com/spreadsheets/d/17LsLbF6aRePVRxisui8azPtDBfPmjugWIf91wPuXTsY
|
[gim]: //docs.google.com/spreadsheets/d/17LsLbF6aRePVRxisui8azPtDBfPmjugWIf91wPuXTsY
|
||||||
[ed]: https://docs.google.com/spreadsheets/d/1e9kDyAW0gxXHFWS-GNEtVIo-rp39wQJJOtf3B0ehhqY
|
[ed]: //docs.google.com/spreadsheets/d/1e9kDyAW0gxXHFWS-GNEtVIo-rp39wQJJOtf3B0ehhqY
|
||||||
[calc]: /Lua/exit%20calculator.lua
|
[calc]: /Lua/exit%20calculator.lua
|
||||||
[csv]: https://eaguru.guru/t/_exits.csv
|
[csv]: //eaguru.guru/t/_exits.csv
|
||||||
|
|
||||||
## save files
|
## save files
|
||||||
|
|
||||||
save contents are mostly documented by [the save file binary templates.][savebt]
|
save contents are mostly documented by [the save file binary templates.][savebt]
|
||||||
|
|
||||||
[savebt]: https://github.com/EntranceJew/zelda-binary-templates/tree/master/filetypes/Save
|
[savebt]: //github.com/EntranceJew/zelda-binary-templates/tree/master/filetypes/Save
|
||||||
|
|
||||||
in the versions of the game with owl saves,
|
in the versions of the game with owl saves,
|
||||||
regular saves are 0x100C in size, and owl saves are 0x3CA0.
|
regular saves are 0x100C in size, and owl saves are 0x3CA0.
|
||||||
|
@ -56,7 +156,7 @@ each slot has one backup copy of itself, though they don't seem to be used?
|
||||||
if a slot is corrupted, it will show up as empty in the menu.
|
if a slot is corrupted, it will show up as empty in the menu.
|
||||||
|
|
||||||
the checksum is a 16-bit sum of all bytes up to that point, allowing overflows.
|
the checksum is a 16-bit sum of all bytes up to that point, allowing overflows.
|
||||||
i've written [a checksum-fixing program][chksum] in python for bizhawk savefiles.
|
i've written [a checksum-fixing program][chksum] in Python for Bizhawk savefiles.
|
||||||
i've also written an [010][010] Editor [script][chksum2]
|
i've also written an [010][010] Editor [script][chksum2]
|
||||||
and its [OoT variant][chksumOoT]
|
and its [OoT variant][chksumOoT]
|
||||||
for properly formed save files, such as those made by nemu64.
|
for properly formed save files, such as those made by nemu64.
|
||||||
|
@ -64,8 +164,8 @@ for properly formed save files, such as those made by nemu64.
|
||||||
owl saves always have 0x24 added to their checksum for some reason.
|
owl saves always have 0x24 added to their checksum for some reason.
|
||||||
|
|
||||||
[chksum]: /chksum.py
|
[chksum]: /chksum.py
|
||||||
[chksum2]: https://github.com/EntranceJew/zelda-binary-templates/blob/master/scripts/FixSaveMM.1sc
|
[chksum2]: //github.com/EntranceJew/zelda-binary-templates/blob/master/scripts/FixSaveMM.1sc
|
||||||
[chksumOoT]: https://github.com/EntranceJew/zelda-binary-templates/blob/master/scripts/FixSaveOoT.1sc
|
[chksumOoT]: //github.com/EntranceJew/zelda-binary-templates/blob/master/scripts/FixSaveOoT.1sc
|
||||||
[010]: http://www.sweetscape.com/010editor/
|
[010]: http://www.sweetscape.com/010editor/
|
||||||
|
|
||||||
bizhawk save files, at the time of writing, have the first file offset to 0x20800.
|
bizhawk save files, at the time of writing, have the first file offset to 0x20800.
|
||||||
|
@ -84,14 +184,14 @@ xxd -r $x > "$s"
|
||||||
revend "$s"
|
revend "$s"
|
||||||
```
|
```
|
||||||
|
|
||||||
## save files (for download)
|
## MM Save Files
|
||||||
|
|
||||||
because no one likes first cycle.
|
because no one likes first cycle.
|
||||||
|
|
||||||
sometime i'll bother checking what the bombers/lottery codes are for these.
|
sometime i'll bother checking what the bombers/lottery codes are for these.
|
||||||
|
|
||||||
* [Bizhawk US 1.0 race file](https://eaguru.guru/t/MM%20US%20Race%20File%20for%20Bizhawk.zip )
|
* [Bizhawk US 1.0 race file](//eaguru.guru/t/MM%20US%20Race%20File%20for%20Bizhawk.zip )
|
||||||
* [mupen64plus US 1.0 race file](https://eaguru.guru/t/Legend%20of%20Zelda%2C%20The%20-%20Majora%27s%20Mask%20%28U%29%20%5B%21%5D.zip)
|
* [mupen64plus US 1.0 race file](//eaguru.guru/t/Legend%20of%20Zelda%2C%20The%20-%20Majora%27s%20Mask%20%28U%29%20%5B%21%5D.zip)
|
||||||
|
|
||||||
## bitfields
|
## bitfields
|
||||||
|
|
||||||
|
@ -114,8 +214,8 @@ they appear in a different order than in save files, however.
|
||||||
803E898C corresponds to offset 0xC.
|
803E898C corresponds to offset 0xC.
|
||||||
803E8994 corresponds to offset 0x10.
|
803E8994 corresponds to offset 0x10.
|
||||||
|
|
||||||
### link's status
|
### Link's status
|
||||||
|
|
||||||
here's [an incomplete document on some of link's bitfields][linkfields] for JP 1.0.
|
here's [an incomplete document on some of Link's bitfields][linkfields] for JP 1.0.
|
||||||
|
|
||||||
[linkfields]: /mm-bitflags.txt
|
[linkfields]: /mm-bitflags.txt
|
||||||
|
|
BIN
img/M_US10.2016-10-02 19.02.17.png
Normal file
BIN
img/M_US10.2016-10-02 19.02.17.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 100 KiB |
Loading…
Reference in a new issue