Mercurial > lcfOS
view python/instructionselector.py @ 277:046017431c6a
Started register allocator
author | Windel Bouwman |
---|---|
date | Thu, 26 Sep 2013 21:14:25 +0200 |
parents | 6f2423df0675 |
children | 2ccd57b1d78c |
line wrap: on
line source
import ir import irmach from irmach import makeIns def genTemps(): n = 900 while True: yield ir.Temp('t{}'.format(n)) n = n + 1 class InstructionSelector: """ Base instruction selector. This class must be overridden by backends. """ def __init__(self): self.temps = genTemps() def newTmp(self): return self.temps.__next__() def munchFunction(self, f, frame): # Entry point for instruction selection assert isinstance(f, ir.Function) self.targets = {} # Enter a frame per function: self.frame = frame # First define labels: for bb in f.Blocks: itgt = makeIns('{}:'.format(bb.name)) self.targets[bb] = itgt # Generate code for all blocks: for bb in f.Blocks: self.emit2(self.targets[bb]) for i in bb.Instructions: self.munchStm(i) self.munchStm(ir.Move(self.frame.rv, f.return_value)) self.emit('mov %s0, %s0', src=[self.frame.rv]) def move(self, dst, src): self.emit('mov %d0, %s0', src=[src], dst=[dst]) def emit(self, *args, **kwargs): """ Abstract instruction emitter """ i = makeIns(*args, **kwargs) return self.emit2(i) def emit2(self, i): self.frame.instructions.append(i) return i def munchStm(self, s): """ Implement this in the target specific back-end """ raise NotImplementedError() def munchExpr(self, e): """ Implement this in the target specific back-end """ raise NotImplementedError()