forked from Entroper/FF1Disassembly
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathreadme.txt
95 lines (62 loc) · 3.67 KB
/
readme.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
FF Disassembly readme!
v1.0 Complete!
Disch
--------------------------------------------
This disassembly has been an on-again off-again (mostly off) project of mine for literally
years. I finally got around to finishing it!
This is a fully commented and documented, reassemblable disassembly of the US release of
Final Fantasy for the NES. Everything you need to reassemble is included.
This can be used for whatever means you want, but the goal was for it to allow for a
ridiculous easy way to perform ASM hacks and bugfixes to the game.
Final Fantasy has numerous bugs. As I was going through this disassembly, I uncovered several.
I tried to label them all with "BUGGED". So if you do a "find in files" for that, you will
be able to see most of them. I try to get into detail of how they're bugged and usually
offer a suggested fix.
The *.asm files are pretty self explanatory. However there are a few other files:
- build.bat is a batch file to generate a ROM from the source. So just make your changes to
the asm, run build.bat, and your hack is done! **NOTE** that build.bat will delete any
"bank_*.bin" and "*.o" files in the root directory as part of its cleanup.
- macros.inc includes a handful of macros that are [sparesely] used. Really the main ones are the
CRITPAGECHECK and PAGECHECK which error/warning if a timed loop (branch) crosses a page boundary,
as this would screw with the timing of the routine (crossing a page adds another cycle)
- Constants.inc includes various constants. Should be self explanitory mostly. I tried to keep the
number of addresses listed in there to a minimum. The ones that are in there are primarily
for addresses that point somewhere in the middle of a block of binary data, so it's hard
to create them with labels.
- variables.inc is the closest thing to a RAM map that I have. It's not *really* as organized
as it could be, and some of the names are questionable, but hopefully get the point
across well enough.
- "some formats.txt" is some very sketchy notes I made about some less-than-obvious formats used
by the game. Specifically tile attributes for overworld and standard maps, and the battle formation
data. This is a holdover from when I started this project. As I got further into it, I started
putting these descriptions in large block comments in the actual code -- since that seemed to
make more sense and was more organized.
As mentioned, since work for this has spread over several years, my style may be inconsistent in
parts. Sorry! I like to think I improved as time went on.
For large blocks of data that's intermingled in the code, I've been trying to put those into seperate
binary files and .INCBIN'ing them. The /bin/ directory has them. The naming is a little
inconsistent, but one thing to note is that if they have an address in them ("0D_storytext_A800.bin"
for example) then they include a pointer table at the start.
Anyway that's about it. A lot of this isn't polished yet, as I was going to go over everything and
clean it up/make it prettier once I finished all the commenting.
Have fun!
-Disch-
CHANGES:
v1.0
----------------------
- Completed documentation of ALL code
- Renamed .bin files to be more consistent
v0.4
----------------------
- don't remember =x
v0.3
----------------------
- Fixed so it actually assembles now (was missing files before)
- Intro screen and music driver commented.
v0.2
----------------------
- converted it back to 16K bank sizes (rather than the previous 8K nonsense)
- much more stuff commented
First Release:
----------------------
- first release!