aboutsummaryrefslogtreecommitdiff
path: root/ARMeilleure/Translation/RegisterToLocal.cs
diff options
context:
space:
mode:
Diffstat (limited to 'ARMeilleure/Translation/RegisterToLocal.cs')
-rw-r--r--ARMeilleure/Translation/RegisterToLocal.cs52
1 files changed, 52 insertions, 0 deletions
diff --git a/ARMeilleure/Translation/RegisterToLocal.cs b/ARMeilleure/Translation/RegisterToLocal.cs
new file mode 100644
index 00000000..aa918018
--- /dev/null
+++ b/ARMeilleure/Translation/RegisterToLocal.cs
@@ -0,0 +1,52 @@
+using ARMeilleure.IntermediateRepresentation;
+using System.Collections.Generic;
+
+using static ARMeilleure.IntermediateRepresentation.OperandHelper;
+
+namespace ARMeilleure.Translation
+{
+ static class RegisterToLocal
+ {
+ public static void Rename(ControlFlowGraph cfg)
+ {
+ Dictionary<Register, Operand> registerToLocalMap = new Dictionary<Register, Operand>();
+
+ Operand GetLocal(Operand op)
+ {
+ Register register = op.GetRegister();
+
+ if (!registerToLocalMap.TryGetValue(register, out Operand local))
+ {
+ local = Local(op.Type);
+
+ registerToLocalMap.Add(register, local);
+ }
+
+ return local;
+ }
+
+ foreach (BasicBlock block in cfg.Blocks)
+ {
+ foreach (Node node in block.Operations)
+ {
+ Operand dest = node.Destination;
+
+ if (dest != null && dest.Kind == OperandKind.Register)
+ {
+ node.Destination = GetLocal(dest);
+ }
+
+ for (int index = 0; index < node.SourcesCount; index++)
+ {
+ Operand source = node.GetSource(index);
+
+ if (source.Kind == OperandKind.Register)
+ {
+ node.SetSource(index, GetLocal(source));
+ }
+ }
+ }
+ }
+ }
+ }
+} \ No newline at end of file