2020-09-17 21:11:59 +00:00
|
|
|
#!/usr/bin/env python3
|
|
|
|
|
|
|
|
import argparse
|
Overhaul the build system (#234)
* wip
* fix
* add disassembler
* Disasm builds OK
* Variable addends
* More wip
* Rodata migration implemented
* Cleanup old tools
* Try fix submodule -> subrepo merge
* git subrepo pull --force --remote=https://github.com/zeldaret/ZAPD.git tools/ZAPD
subrepo:
subdir: "tools/ZAPD"
merged: "602e609"
upstream:
origin: "https://github.com/zeldaret/ZAPD.git"
branch: "master"
commit: "602e609"
git-subrepo:
version: "0.4.3"
origin: "https://github.com/ingydotnet/git-subrepo"
commit: "2f68596"
* Builds again but assets are totally broken
* git subrepo pull --force tools/asm-processor
subrepo:
subdir: "tools/asm-processor"
merged: "1ffdb08a"
upstream:
origin: "https://github.com/simonlindholm/asm-processor.git"
branch: "master"
commit: "1ffdb08a"
git-subrepo:
version: "0.4.3"
origin: "https://github.com/ingydotnet/git-subrepo"
commit: "2f68596"
* More cleanup, move functions.txt and variables.txt to tools/disasm and rm tables
* rm z64compress in preparation for subrepo
* git subrepo clone (merge) https://github.com/z64me/z64compress.git tools/z64compress
subrepo:
subdir: "tools/z64compress"
merged: "eb11085c"
upstream:
origin: "https://github.com/z64me/z64compress.git"
branch: "main"
commit: "eb11085c"
git-subrepo:
version: "0.4.3"
origin: "https://github.com/ingydotnet/git-subrepo"
commit: "2f68596"
* Fix asset extraction
* Fix diff-init make rule
* Split code bss
* Split assumed linker bug padding from assembly files
* add filelists for mm.us.rev1
* Maybe working, but I'm not sure
* add overlays to spec
* Add rodata to actos
* Everything compiles
* Make a lot of C files for code
* Add almost every file in code to spec
* whoops
* 3 code files left
* add scenes to spec
* More progress on progress.py
* Fix skelanime in spec
* audio files!
* Fix merge issues
* Fix some C files in code
* Fix remaining code files
* Use existing O1 C files in spec
* reorder boot order in spec
* update spec
* fault.c
* Convert relocs on completed actors, fixbaserom uses current rom name
* more boot files
* Add VT macros and script
* finish already existing boot files
* most of libultra
* fix 64bits libultra files
* Use C files for libultra, wrap some functions in NON_MATCHING
* Remove duplicate of OS_CLOCK_RATE from fault.c
* C files for fbdemos
* delete dumb files
* bootstrap C files, still need to add them to the spec
* update fixbaserom
* boot OK?
* I forgot to commit the spec
* C for gamestates
* C for kaleido
* Change all includes to ""
* copy actor sizes script from oot
* I forgot to delete those files
* Basic C files for effects
* Add effects initvars names
* Remove mislabelled boot functions from header/txt
* Begin porting bootstrap_fx, some sizes
* Fix <>
* Fix enum
* Fix diff.py
* fix libultra stuff
* update regconvert
* update setup warnings
* add some missing ;
* Fix some makefile stuff and other fixes on some non_matching functions
* add executable flag in extract_baserom and fixbaserom
* fix relative path
* copy assist from oot
* fix map path
* another assist path fix
* Delete C files for handwritten files
* add code_801A51F0 to spec
* add gfxbuffers to spec
* Move rodata to top of each file when possible
* UNK_TYPEs for func_801A51F0
* Remove kaleido rodata from spec
* Update spec and undefined_syms for recent merge
* GCC warnings and fix errors in nonmatchings,
* round percentage numbers
* progress script: format changes
* progress: error on non-existing files
* fix warning in z_scene_table
* Match 2 nonmatchings in z_actor
* Warnings in lightswitch and invadepoh
* Fix warning in z_actor_dlftbls
* I though I fixed this one
* whoops
* Comment out CC_CHECK
* Removed redundant ultra64.h includes
* Update asm_processor, sorted boot_O1 into other folders, completed the fbdemo bootstrap, cleaned up undefined_syms
* Completed gamestates bootstrap
* Split kaleido_scope
* Remove section.h and segment.h, move keep object externs to a common location in variables.h
* Completed effects bootstrap
* Segmented address externs for effects, fbdemos, gamestates and kaleido
* Move actor data externs out of the if 0
* Segmented address externs for actors
* Prepare actionfunc detection
* fix script, how did it even work before
* Fix actionfunc script again, re-introduce some more intermediate prints to the disassembler
* Automated actionFunc detection in actors
* Segmented addresses from player .text
* rm old segment addrs script and fix build
* Move sizes folder to tools
* Make build.py executable
* New Jenkinsfile Prayge
* Remove numpy dependencies
* Add warnings_disasm_current.txt
* my bad
* Update spec and undefined_syms
* Add z_eff_ss_hahen to pametfrog
* git subrepo pull (merge) --force tools/z64compress
subrepo:
subdir: "tools/z64compress"
merged: "163ca2af"
upstream:
origin: "https://github.com/z64me/z64compress.git"
branch: "main"
commit: "163ca2af"
git-subrepo:
version: "0.4.3"
origin: "https://github.com/ingydotnet/git-subrepo"
commit: "2f68596"
* Make z64compress print to stdout
* sneeky commit to update warnings tooling
* test
* Another test
* Mark fixing overlay reloc generating as a TODO
* Update warnings stuff
* Communicate the return code from running z64compress back to the Makefile through the wrapper
* Run formatter, remove extra commented copy of function
* Re-fix some includes
* Convert atan to hex to conform to decided style
* Some tidying up, remove c for fp and the other two handwritten code files
* BSS in z_collision_check & z_scene_proc
* add static back in
* Fix timerintr bss, add file to spec, some cleanup
* Remove externs
* Newline
* Readd enums
* Typo
* Colours
* Comments for hitmark enum values
Co-authored-by: EllipticEllipsis <73679967+EllipticEllipsis@users.noreply.github.com>
* Improvements and suggestions
* Organize and remove unused imports and use env for python3 scripts, delete unused overlay.py
Co-authored-by: angie <angheloalf95@gmail.com>
Co-authored-by: Elliptic Ellipsis <elliptic.ellipsis@gmail.com>
Co-authored-by: engineer124 <engineer124engineer124@gmail.com>
Co-authored-by: EllipticEllipsis <73679967+EllipticEllipsis@users.noreply.github.com>
2021-08-04 03:21:31 +00:00
|
|
|
import os.path
|
2020-09-17 21:11:59 +00:00
|
|
|
|
|
|
|
parser = argparse.ArgumentParser(
|
|
|
|
description="Display various information about a symbol or address."
|
|
|
|
)
|
|
|
|
parser.add_argument(
|
|
|
|
"name",
|
|
|
|
type=str,
|
|
|
|
default="",
|
2021-09-21 22:09:14 +00:00
|
|
|
help="symbol name or VROM/VRAM address to lookup"
|
2020-09-17 21:11:59 +00:00
|
|
|
)
|
|
|
|
parser.add_argument(
|
|
|
|
"-e",
|
|
|
|
"--expected",
|
|
|
|
dest="use_expected",
|
|
|
|
action="store_true",
|
|
|
|
help="use the map file in expected/build/ instead of build/"
|
|
|
|
)
|
|
|
|
args = parser.parse_args()
|
|
|
|
|
|
|
|
mymap = "build/mm.map"
|
|
|
|
if args.use_expected:
|
|
|
|
mymap = f"expected/{mymap}"
|
|
|
|
|
|
|
|
if not os.path.isfile(mymap):
|
|
|
|
print(f"{mymap} must exist.")
|
|
|
|
exit(1)
|
|
|
|
|
|
|
|
|
|
|
|
def search_address(target_addr):
|
|
|
|
is_ram = target_addr & 0x80000000
|
|
|
|
ram_offset = None
|
|
|
|
prev_ram = 0
|
|
|
|
prev_rom = 0
|
|
|
|
prev_sym = "<start of rom>"
|
|
|
|
cur_file = "<no file>"
|
|
|
|
prev_file = cur_file
|
|
|
|
prev_line = ""
|
|
|
|
with open(mymap) as f:
|
|
|
|
for line in f:
|
|
|
|
if "load address" in line:
|
|
|
|
# Ignore .bss sections if we're looking for a ROM address
|
|
|
|
if not is_ram and (".bss" in line or ".bss" in prev_line):
|
|
|
|
ram_offset = None
|
|
|
|
continue
|
|
|
|
ram = int(line[16 : 16 + 18], 0)
|
|
|
|
rom = int(line[59 : 59 + 18], 0)
|
|
|
|
ram_offset = ram - rom
|
|
|
|
continue
|
|
|
|
|
|
|
|
prev_line = line
|
|
|
|
|
|
|
|
if (
|
|
|
|
ram_offset is None
|
|
|
|
or "=" in line
|
|
|
|
or "*fill*" in line
|
|
|
|
or " 0x" not in line
|
|
|
|
):
|
|
|
|
continue
|
|
|
|
|
|
|
|
ram = int(line[16 : 16 + 18], 0)
|
|
|
|
rom = ram - ram_offset
|
|
|
|
sym = line.split()[-1]
|
|
|
|
|
|
|
|
if "0x" in sym and "/" not in sym:
|
|
|
|
ram_offset = None
|
|
|
|
continue
|
|
|
|
if "/" in sym:
|
|
|
|
cur_file = sym
|
|
|
|
continue
|
|
|
|
|
|
|
|
if rom == target_addr or (is_ram and ram == target_addr):
|
2021-09-21 22:09:14 +00:00
|
|
|
return f"{sym} (VRAM 0x{ram:X}, VROM 0x{rom:X}, {cur_file})"
|
2020-09-17 21:11:59 +00:00
|
|
|
if rom > target_addr or (is_ram and ram > target_addr):
|
|
|
|
offset = target_addr - prev_ram if is_ram else target_addr - prev_rom
|
2021-09-21 22:09:14 +00:00
|
|
|
return f"at 0x{offset:X} bytes inside {prev_sym} (VRAM 0x{prev_ram:X}, VROM 0x{prev_rom:X}, {prev_file})"
|
2020-09-17 21:11:59 +00:00
|
|
|
|
|
|
|
prev_ram = ram
|
|
|
|
prev_rom = rom
|
|
|
|
prev_sym = sym
|
|
|
|
prev_file = cur_file
|
|
|
|
|
|
|
|
return "at end of rom?"
|
|
|
|
|
|
|
|
|
|
|
|
def search_symbol(target_sym):
|
|
|
|
ram_offset = None
|
|
|
|
cur_file = "<no file>"
|
|
|
|
prev_line = ""
|
|
|
|
with open(mymap) as f:
|
|
|
|
for line in f:
|
|
|
|
if "load address" in line:
|
|
|
|
ram = int(line[16 : 16 + 18], 0)
|
|
|
|
rom = int(line[59 : 59 + 18], 0)
|
|
|
|
ram_offset = ram - rom
|
|
|
|
continue
|
|
|
|
|
|
|
|
prev_line = line
|
|
|
|
|
|
|
|
if (
|
|
|
|
ram_offset is None
|
|
|
|
or "=" in line
|
|
|
|
or "*fill*" in line
|
|
|
|
or " 0x" not in line
|
|
|
|
):
|
|
|
|
continue
|
|
|
|
|
|
|
|
ram = int(line[16 : 16 + 18], 0)
|
|
|
|
rom = ram - ram_offset
|
|
|
|
sym = line.split()[-1]
|
|
|
|
|
|
|
|
if "0x" in sym and "/" not in sym:
|
|
|
|
ram_offset = None
|
|
|
|
continue
|
|
|
|
elif "/" in sym:
|
|
|
|
cur_file = sym
|
|
|
|
continue
|
|
|
|
|
|
|
|
if sym == target_sym:
|
|
|
|
return (rom, cur_file, ram)
|
|
|
|
|
|
|
|
return None
|
|
|
|
|
|
|
|
|
|
|
|
try:
|
|
|
|
target_addr = int(args.name, 0)
|
|
|
|
print(args.name, "is", search_address(target_addr))
|
|
|
|
except ValueError:
|
|
|
|
sym_info = search_symbol(args.name)
|
|
|
|
if sym_info is not None:
|
|
|
|
sym_rom = sym_info[0]
|
|
|
|
sym_file = sym_info[1]
|
|
|
|
sym_ram = sym_info[2]
|
2021-09-21 22:09:14 +00:00
|
|
|
print(f"Symbol {args.name} (VRAM: 0x{sym_ram:08X}, VROM: 0x{sym_rom:06X}, {sym_file})")
|
2020-09-17 21:11:59 +00:00
|
|
|
else:
|
|
|
|
print(f"Symbol {args.name} not found in map file {mymap}")
|