CAP/MiniC/TP04/AllInMemAllocator.py
2024-10-21 13:44:40 +02:00

46 lines
1.6 KiB
Python

from Lib import RiscV
from Lib.Operands import Temporary, Operand, S
from Lib.Statement import Instruction
from Lib.Allocator import Allocator
from typing import List
class AllInMemAllocator(Allocator):
def replace(self, old_instr: Instruction) -> List[Instruction]:
"""Replace Temporary operands with the corresponding allocated
memory location."""
numreg = 1
before: List[Instruction] = []
after: List[Instruction] = []
new_args: List[Operand] = []
s_index = 0
for arg in old_instr.args():
if isinstance(arg, Temporary):
s_index += 1
if arg in old_instr.used(): # needs to be read first
before.append(RiscV.ld(
S[s_index], arg.get_alloced_loc()
))
if arg in old_instr.defined(): # needs to be stored after
after.append(RiscV.sd(
S[s_index], arg.get_alloced_loc()
))
new_args.append(S[s_index])
else:
new_args.append(arg)
new_instr = old_instr.with_args(new_args)
return before + [new_instr] + after
def prepare(self) -> None:
"""Allocate all temporaries to memory.
Invariants:
- Expanded instructions can use s2 and s3
(to store the values of temporaries before the actual instruction).
"""
self._fdata._pool.set_temp_allocation(
{temp: self._fdata.fresh_offset()
for temp in self._fdata._pool.get_all_temps()})