mirror of
https://github.com/N64Recomp/N64Recomp.git
synced 2025-01-28 00:35:19 +00:00
66062a06e9
This commit implements the "live recompiler", which is another backend for the recompiler that generates platform-specific assembly at runtime. This is still static recompilation as opposed to dynamic recompilation, as it still requires information about the binary to recompile and leverages the same static analysis that the C recompiler uses. However, similarly to dynamic recompilation it's aimed at recompiling binaries at runtime, mainly for modding purposes. The live recompiler leverages a library called sljit to generate platform-specific code. This library provides an API that's implemented on several platforms, including the main targets of this component: x86_64 and ARM64. Performance is expected to be slower than the C recompiler, but should still be plenty fast enough for running large amounts of recompiled code without an issue. Considering these ROMs can often be run through an interpreter and still hit their full speed, performance should not be a concern for running native code even if it's less optimal than the C recompiler's codegen. As mentioned earlier, the main use of the live recompiler will be for loading mods in the N64Recomp runtime. This makes it so that modders don't need to ship platform-specific binaries for their mods, and allows fixing bugs with recompilation down the line without requiring modders to update their binaries. This PR also includes a utility for testing the live recompiler. It accepts binaries in a custom format which contain the instructions, input data, and target data. Documentation for the test format as well as most of the tests that were used to validate the live recompiler can be found here. The few remaining tests were hacked together binaries that I put together very hastily, so they need to be cleaned up and will probably be uploaded at a later date. The only test in that suite that doesn't currently succeed is the div test, due to unknown behavior when the two operands aren't properly sign extended to 64 bits. This has no bearing on practical usage, since the inputs will always be sign extended as expected.
16 lines
447 B
Plaintext
16 lines
447 B
Plaintext
[submodule "lib/rabbitizer"]
|
|
path = lib/rabbitizer
|
|
url = https://github.com/Decompollaborate/rabbitizer
|
|
[submodule "lib/ELFIO"]
|
|
path = lib/ELFIO
|
|
url = https://github.com/serge1/ELFIO
|
|
[submodule "lib/fmt"]
|
|
path = lib/fmt
|
|
url = https://github.com/fmtlib/fmt
|
|
[submodule "lib/tomlplusplus"]
|
|
path = lib/tomlplusplus
|
|
url = https://github.com/marzer/tomlplusplus
|
|
[submodule "lib/sljit"]
|
|
path = lib/sljit
|
|
url = https://github.com/zherczeg/sljit
|