gen/fhdl: add simulation Display, Finish support.

In some simulation cases, it's easier to add debug traces directly in the code
than in the verilog/Migen testbench. This adds support for verilog $display in
Migen code.

Being able to terminate a simulation from the code is also useful, this also
add support for verilog $finish.
This commit is contained in:
Florent Kermarrec 2018-12-09 09:45:17 +01:00
parent 92a6169d2a
commit fa260f5b42
1 changed files with 11 additions and 0 deletions

View File

@ -155,6 +155,17 @@ def _printnode(ns, at, level, node, target_filter=None):
return r
else:
return ""
elif isinstance(node, Display):
s = "\"" + node.s + "\""
for arg in node.args:
s += ", "
if isinstance(arg, Signal):
s += ns.get_name(arg)
else:
s += str(arg)
return "\t"*level + "$display(" + s + ");\n"
elif isinstance(node, Finish):
return "\t"*level + "$finish;\n"
else:
raise TypeError("Node of unrecognized type: "+str(type(node)))