litex/migen/pytholite/reg.py

43 lines
1.3 KiB
Python
Raw Normal View History

from operator import itemgetter
from migen.fhdl.structure import *
2013-04-10 17:42:46 -04:00
from migen.fhdl.module import Module
from migen.fhdl import visit as fhdl
class AbstractLoad:
def __init__(self, target, source):
self.target = target
self.source = source
def lower(self):
if not self.target.finalized:
raise FinalizeError
return self.target.sel.eq(self.target.source_encoding[id(self.source)])
class LowerAbstractLoad(fhdl.NodeTransformer):
def visit_unknown(self, node):
if isinstance(node, AbstractLoad):
return node.lower()
else:
return node
2013-04-10 17:42:46 -04:00
class ImplRegister(Module):
2012-11-30 11:07:12 -05:00
def __init__(self, name, bits_sign):
self.name = name
2012-11-30 11:07:12 -05:00
self.storage = Signal(bits_sign, name=self.name)
self.source_encoding = {}
self.id_to_source = {}
def load(self, source):
if id(source) not in self.source_encoding:
self.source_encoding[id(source)] = len(self.source_encoding) + 1
self.id_to_source[id(source)] = source
return AbstractLoad(self, source)
2013-04-10 17:42:46 -04:00
def do_finalize(self):
self.sel = Signal(max=len(self.source_encoding)+1, name="pl_regsel_"+self.name)
# do nothing when sel == 0
items = sorted(self.source_encoding.items(), key=itemgetter(1))
2012-11-28 19:11:15 -05:00
cases = dict((v, self.storage.eq(self.id_to_source[k])) for k, v in items)
2013-04-10 17:42:46 -04:00
self.sync += Case(self.sel, cases)