aboutsummaryrefslogtreecommitdiff
path: root/ARMeilleure/Translation/Translator.cs
diff options
context:
space:
mode:
authorLDj3SNuD <35856442+LDj3SNuD@users.noreply.github.com>2021-01-12 19:04:02 +0100
committerGitHub <noreply@github.com>2021-01-12 19:04:02 +0100
commit68f6b79fd3f06ea572d5f0edd5fc8cbaee1ae449 (patch)
treea4cf471c7979f85c3bf894f65129f2cb85931dc3 /ARMeilleure/Translation/Translator.cs
parente57b14042910eac2f876549b4a1e6fd5ba027368 (diff)
Add a simple Pools Limiter. (#1830)
* Added support for offline invalidation, via PPTC, of low cq translations replaced by high cq translations; both on a single run and between runs. Added invalidation of .cache files in the event of reuse on a different user operating system. Added .info and .cache files invalidation in case of a failed stream decompression. Nits. * InternalVersion = 1712; * Nits. * Address comment. * Get rid of BinaryFormatter. Nits. * Move Ptc.LoadTranslations(). Nits. * Nits. * Fixed corner cases (in case backup copies have to be used). Added save logs. * Not core fixes. * Complement to the previous commit. Added load logs. Removed BinaryFormatter leftovers. * Add LoadTranslations log. * Nits. * Removed the search and management of LowCq overlapping functions. * Final increment of .info and .cache flags. * Nit. * Free up memory allocated by Pools during any PPTC translations at boot time. * Nit due to rebase. * Add a simple Pools Limiter. * Nits. * Fix missing JumpTable.RegisterFunction() due to rebase. Clear MemoryStreams as soon as possible, when they are no longer needed. * Code cleaning. * Nit for retrigger Checks. * Update Ptc.cs * Contextual refactoring of Translator. Ignore resetting of pools for DirectCallStubs. * Nit for retrigger Checks.
Diffstat (limited to 'ARMeilleure/Translation/Translator.cs')
-rw-r--r--ARMeilleure/Translation/Translator.cs31
1 files changed, 20 insertions, 11 deletions
diff --git a/ARMeilleure/Translation/Translator.cs b/ARMeilleure/Translation/Translator.cs
index 612f6647..2c32e9f0 100644
--- a/ARMeilleure/Translation/Translator.cs
+++ b/ARMeilleure/Translation/Translator.cs
@@ -201,15 +201,14 @@ namespace ARMeilleure.Translation
{
ArmEmitterContext context = new ArmEmitterContext(memory, jumpTable, address, highCq, Aarch32Mode.User);
- PrepareOperandPool(highCq);
- PrepareOperationPool(highCq);
-
Logger.StartPass(PassName.Decoding);
Block[] blocks = Decoder.Decode(memory, address, mode, highCq, singleBlock: false);
Logger.EndPass(PassName.Decoding);
+ PreparePool(highCq);
+
Logger.StartPass(PassName.Translation);
EmitSynchronization(context);
@@ -240,21 +239,31 @@ namespace ARMeilleure.Translation
if (Ptc.State == PtcState.Disabled)
{
func = Compiler.Compile<GuestFunction>(cfg, argTypes, OperandType.I64, options);
+
+ ReturnPool(highCq);
}
- else
+ else using (PtcInfo ptcInfo = new PtcInfo())
{
- using (PtcInfo ptcInfo = new PtcInfo())
- {
- func = Compiler.Compile<GuestFunction>(cfg, argTypes, OperandType.I64, options, ptcInfo);
+ func = Compiler.Compile<GuestFunction>(cfg, argTypes, OperandType.I64, options, ptcInfo);
- Ptc.WriteInfoCodeReloc(address, funcSize, highCq, ptcInfo);
- }
+ ReturnPool(highCq);
+
+ Ptc.WriteInfoCodeRelocUnwindInfo(address, funcSize, highCq, ptcInfo);
}
+ return new TranslatedFunction(func, funcSize, highCq);
+ }
+
+ internal static void PreparePool(bool highCq)
+ {
+ PrepareOperandPool(highCq);
+ PrepareOperationPool(highCq);
+ }
+
+ internal static void ReturnPool(bool highCq)
+ {
ReturnOperandPool(highCq);
ReturnOperationPool(highCq);
-
- return new TranslatedFunction(func, funcSize, highCq);
}
internal static void ResetPools()