Skip to content

Commit

Permalink
Browse files Browse the repository at this point in the history
verilog: user-definable reset and clock
  • Loading branch information
Sebastien Bourdeauducq committed Dec 16, 2011
1 parent c7b9dfc commit ee6ca72
Showing 1 changed file with 20 additions and 14 deletions.
34 changes: 20 additions & 14 deletions migen/fhdl/verilog.py
Expand Up @@ -117,11 +117,15 @@ def _printinstances(ns, i, clk, rst):
r += ");\n\n"
return r

def Convert(f, ios=set(), name="top", clkname="sys_clk", rstname="sys_rst", ns=None):
if ns is None: ns = Namespace()

clks = Signal(name=clkname)
rsts = Signal(name=rstname)
def Convert(f, ios=set(), name="top", clk_signal=None, rst_signal=None, ns=None):
if clk_signal is None:
clk_signal = Signal(name="sys_clk")
ios.add(clk_signal)
if rst_signal is None:
rst_signal = Signal(name="sys_rst")
ios.add(rst_signal)
if ns is None:
ns = Namespace()

ios |= f.pads

Expand All @@ -131,15 +135,17 @@ def Convert(f, ios=set(), name="top", clkname="sys_clk", rstname="sys_rst", ns=N

r = "/* Machine-generated using Migen */\n"
r += "module " + name + "(\n"
r += "\tinput " + ns.get_name(clks) + ",\n"
r += "\tinput " + ns.get_name(rsts)
firstp = True
for sig in ios:
if not firstp:
r += ",\n"
firstp = False
if sig in targets:
r += ",\n\toutput reg " + _printsig(ns, sig)
r += "\toutput reg " + _printsig(ns, sig)
elif sig in instouts:
r += ",\n\toutput " + _printsig(ns, sig)
r += "\toutput " + _printsig(ns, sig)
else:
r += ",\n\tinput " + _printsig(ns, sig)
r += "\tinput " + _printsig(ns, sig)
r += "\n);\n\n"
for sig in sigs - ios:
if sig in instouts:
Expand All @@ -153,11 +159,11 @@ def Convert(f, ios=set(), name="top", clkname="sys_clk", rstname="sys_rst", ns=N
r += _printnode(ns, 1, f.comb)
r += "end\n\n"
if f.sync.l:
r += "always @(posedge " + ns.get_name(clks) + ") begin\n"
r += _printnode(ns, 1, insert_reset(rsts, f.sync))
r += "always @(posedge " + ns.get_name(clk_signal) + ") begin\n"
r += _printnode(ns, 1, insert_reset(rst_signal, f.sync))
r += "end\n\n"
r += _printinstances(ns, f.instances, clks, rsts)
r += _printinstances(ns, f.instances, clk_signal, rst_signal)

r += "endmodule\n"

return r
return r

0 comments on commit ee6ca72

Please sign in to comment.