Reset insertion

This commit is contained in:
Sebastien Bourdeauducq 2011-12-04 22:41:50 +01:00
parent cd8544c758
commit e099f4d52f
2 changed files with 81 additions and 53 deletions

76
migen/fhdl/convtools.py Normal file
View file

@ -0,0 +1,76 @@
from .structure import *
class Namespace:
def __init__(self):
self.counts = {}
self.sigs = {}
def GetName(self, sig):
try:
n = self.sigs[sig]
if n:
return sig.name + "_" + str(n)
else:
return sig.name
except KeyError:
try:
n = self.counts[sig.name]
except KeyError:
n = 0
self.sigs[sig] = n
self.counts[sig.name] = n + 1
if n:
return sig.name + "_" + str(n)
else:
return sig.name
def ListSignals(node):
if isinstance(node, Constant):
return set()
elif isinstance(node, Signal):
return {node}
elif isinstance(node, Operator):
l = list(map(ListSignals, node.operands))
return set().union(*l)
elif isinstance(node, Slice):
return ListSignals(node.value)
elif isinstance(node, Cat):
l = list(map(ListSignals, node.l))
return set().union(*l)
elif isinstance(node, Assign):
return ListSignals(node.l) | ListSignals(node.r)
elif isinstance(node, StatementList):
l = list(map(ListSignals, node.l))
return set().union(*l)
elif isinstance(node, If):
return ListSignals(node.cond) | ListSignals(node.t) | ListSignals(node.f)
elif isinstance(node, Fragment):
return ListSignals(node.comb) | ListSignals(node.sync)
else:
raise TypeError
def ListTargets(node):
if isinstance(node, Signal):
return {node}
elif isinstance(node, Slice):
return ListTargets(node.value)
elif isinstance(node, Cat):
l = list(map(ListTargets, node.l))
return set().union(*l)
elif isinstance(node, Assign):
return ListTargets(node.l)
elif isinstance(node, StatementList):
l = list(map(ListTargets, node.l))
return set().union(*l)
elif isinstance(node, If):
return ListTargets(node.t) | ListTargets(node.f)
else:
raise TypeError
def InsertReset(rst, sl):
targets = ListTargets(sl)
resetcode = []
for t in targets:
if not t.variable:
resetcode.append(Assign(t, t.reset))
return If(rst == 1, resetcode, sl)

View file

@ -1,60 +1,12 @@
from .structure import * from .structure import *
from .convtools import *
from functools import partial from functools import partial
class Namespace: def Convert(f, ins, outs, name="top", clkname="sys_clk", rstname="sys_rst"):
def __init__(self):
self.counts = {}
self.sigs = {}
def GetName(self, sig):
try:
n = self.sigs[sig]
if n:
return sig.name + "_" + str(n)
else:
return sig.name
except KeyError:
try:
n = self.counts[sig.name]
except KeyError:
n = 0
self.sigs[sig] = n
self.counts[sig.name] = n + 1
if n:
return sig.name + "_" + str(n)
else:
return sig.name
def ListSignals(node):
if isinstance(node, Constant):
return set()
elif isinstance(node, Signal):
return {node}
elif isinstance(node, Operator):
l = list(map(ListSignals, node.operands))
return set().union(*l)
elif isinstance(node, Slice):
return ListSignals(node.value)
elif isinstance(node, Cat):
l = list(map(ListSignals, node.l))
return set().union(*l)
elif isinstance(node, Assign):
return ListSignals(node.l) | ListSignals(node.r)
elif isinstance(node, StatementList):
l = list(map(ListSignals, node.l))
return set().union(*l)
elif isinstance(node, If):
return ListSignals(node.cond) | ListSignals(node.t) | ListSignals(node.f)
elif isinstance(node, Fragment):
return ListSignals(node.comb) | ListSignals(node.sync)
else:
raise TypeError
def Convert(f, ins, outs, name="top"):
ns = Namespace() ns = Namespace()
clks = Signal(name="sys_clk") clks = Signal(name=clkname)
rsts = Signal(name="sys_rst") rsts = Signal(name=rstname)
clk = ns.GetName(clks) clk = ns.GetName(clks)
rst = ns.GetName(rsts) rst = ns.GetName(rsts)
@ -129,7 +81,7 @@ def Convert(f, ins, outs, name="top"):
if f.sync.l: if f.sync.l:
r += "always @(posedge " + clk + ") begin\n" r += "always @(posedge " + clk + ") begin\n"
r += printnode(1, f.sync) r += printnode(1, InsertReset(rsts, f.sync))
r += "end\n\n" r += "end\n\n"
r += "endmodule\n" r += "endmodule\n"