aboutsummaryrefslogtreecommitdiff
path: root/ChocolArm64/Translation/TranslationTier.cs
diff options
context:
space:
mode:
authorgdkchan <gab.dark.100@gmail.com>2019-02-04 18:26:05 -0300
committerGitHub <noreply@github.com>2019-02-04 18:26:05 -0300
commita694420d11ef74e4f0bf473be2b6f64635bc89c7 (patch)
tree6c44e7a0633dca7b54d99ac3f01f0648fa602559 /ChocolArm64/Translation/TranslationTier.cs
parentf5b4f6ccc4815cfac1fa3c103d8941a26d152d8a (diff)
Implement speculative translation on the CPU (#515)
* Implement speculative translation on the cpu, and change the way how branches to unknown or untranslated addresses works * Port t0opt changes and other cleanups * Change namespace from translation related classes to ChocolArm64.Translation, other minor tweaks * Fix typo * Translate higher quality code for indirect jumps aswell, and on some cases that were missed when lower quality (tier 0) code was available * Remove debug print * Remove direct argument passing optimization, and enable tail calls for BR instructions * Call delegates directly with Callvirt rather than calling Execute, do not emit calls for tier 0 code * Remove unused property * Rename argument on ArmSubroutine delegate
Diffstat (limited to 'ChocolArm64/Translation/TranslationTier.cs')
-rw-r--r--ChocolArm64/Translation/TranslationTier.cs11
1 files changed, 11 insertions, 0 deletions
diff --git a/ChocolArm64/Translation/TranslationTier.cs b/ChocolArm64/Translation/TranslationTier.cs
new file mode 100644
index 00000000..13afd9c5
--- /dev/null
+++ b/ChocolArm64/Translation/TranslationTier.cs
@@ -0,0 +1,11 @@
+namespace ChocolArm64.Translation
+{
+ enum TranslationTier
+ {
+ Tier0,
+ Tier1,
+ Tier2,
+
+ Count
+ }
+} \ No newline at end of file