mirror of
https://github.com/enjoy-digital/litex.git
synced 2025-01-04 09:52:26 -05:00
Reset insertion
This commit is contained in:
parent
cd8544c758
commit
e099f4d52f
2 changed files with 81 additions and 53 deletions
76
migen/fhdl/convtools.py
Normal file
76
migen/fhdl/convtools.py
Normal 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)
|
|
@ -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"
|
||||||
|
|
Loading…
Reference in a new issue