You've already forked Diddy-Kong-Racing
mirror of
https://github.com/izzy2lost/Diddy-Kong-Racing.git
synced 2026-03-10 11:36:09 -07:00
* First pass * Fix n64crc and add submodules properly * Fix other versions * Match func_8005B818 for v80 code. * Formatting * Fix build for JPN in last commit. Still broken in post v77 roms though. * Fix builds for other versions. * Match load_menu_text for other versions. * Fix progress script * update m2c * Modify asset tools to remove the LD script code. * Fix asm file macro inclue * Get a working splat version for us_1.0 to build from the assets tool. * update asm differ * Update tools again * Fix the makefile to only compile assets when requested. This will build all versions successfully, and compile assets for us_1.0 when requested. * First round of suggestions * Small cleanup * Fix the gcc_generate.py path. * Make entrypointThreadStack * Small addition to the last commit * "Fix" score script. Still need to fix the score values themselves, but at least it runs and is kind of close. * Much closer matching score script * Fix the splat version due to a breaking change in 0.33.0 for this repo for now. * Fix the main function name * Add gitignore entries * Fix the padding problem to be handled by objcopy instead of a binary pad from splat. * Update the README and change dependencies to setup. * Have a hasm header that can be tweaked. * Still calculate the checksum on no_verify builds or they won't work. * Add support for boot_custom.bin * Fix custom boot ld code. * Fix score script * Fix gcc building. * Update m2c * Fix warning, stop ignoring mod assets, and add some handy make rules. * Uggh, serves me right for not testing. * First stab at modifiable entrypoint. * Fix typo, and small README change * Stop n64crd from defaulting to returning 6105, so we can properly fail if the CIC checksum fails. Also, fix the * Extract custom boot script * Update automated scripts. * Woops, fixed the MAXCONTROLLERS thing now. * Add the method for building binutils back. Sorry! * Only use -m32 when the longbit says we're on a 64 bit platform. * Woops.... * Hopefully fix arm detection for raspi ido downloads.
54 lines
2.0 KiB
Python
54 lines
2.0 KiB
Python
#!/usr/bin/env python3
|
|
|
|
# SPDX-FileCopyrightText: © 2022 AngheloAlf
|
|
# SPDX-License-Identifier: MIT
|
|
|
|
from __future__ import annotations
|
|
|
|
import argparse
|
|
import mapfile_parser
|
|
from pathlib import Path
|
|
import rabbitizer
|
|
|
|
|
|
def decodeInstruction(bytesDiff: bytes, mapFile: mapfile_parser.MapFile) -> str:
|
|
word = (bytesDiff[0] << 24) | (bytesDiff[1] << 16) | (bytesDiff[2] << 8) | (bytesDiff[3] << 0)
|
|
instr = rabbitizer.Instruction(word)
|
|
immOverride = None
|
|
|
|
if instr.isJumpWithAddress():
|
|
# Instruction is a function call (jal)
|
|
|
|
# Get the embedded address of the function call
|
|
symAddress = instr.getInstrIndexAsVram()
|
|
|
|
# Search for the address in the mapfile
|
|
symInfo = mapFile.findSymbolByVramOrVrom(symAddress)
|
|
if symInfo is not None:
|
|
# Use the symbol from the mapfile instead of a raw value
|
|
immOverride = symInfo.symbol.name
|
|
|
|
return instr.disassemble(immOverride=immOverride, extraLJust=-20)
|
|
|
|
def firstDiffMain():
|
|
parser = argparse.ArgumentParser(description="Find the first difference(s) between the built ROM and the base ROM.")
|
|
|
|
parser.add_argument("-c", "--count", type=int, default=5, help="find up to this many instruction difference(s)")
|
|
parser.add_argument("-r", "--region", help="Which region should be processed", default="us")
|
|
parser.add_argument("-v", "--version", help="Which version should be processed", default="v77")
|
|
parser.add_argument("-a", "--add-colons", action='store_true', help="Add colon between bytes" )
|
|
|
|
args = parser.parse_args()
|
|
|
|
buildFolder = Path("build")
|
|
|
|
BUILTROM = buildFolder / f"dkr.{args.region}.{args.version}.z64"
|
|
BUILTMAP = buildFolder / f"dkr.{args.region}.{args.version}.map"
|
|
|
|
EXPECTEDROM = "expected" / BUILTROM
|
|
EXPECTEDMAP = "expected" / BUILTMAP
|
|
|
|
mapfile_parser.frontends.first_diff.doFirstDiff(BUILTMAP, EXPECTEDMAP, BUILTROM, EXPECTEDROM, args.count, mismatchSize=True, addColons=args.add_colons, bytesConverterCallback=decodeInstruction)
|
|
|
|
if __name__ == "__main__":
|
|
firstDiffMain() |