mirror of
https://github.com/enjoy-digital/litex.git
synced 2025-01-04 09:52:26 -05:00
fhdl/verilog: revert "fhdl/verilog: add simulation parameter to avoid simulation tricks in synthetizable code"
This probably breaks simulation with Icarus Verilog (and others simulators?)
This commit is contained in:
parent
2fc2f8a6c0
commit
ea9c1b8e69
2 changed files with 20 additions and 24 deletions
|
@ -274,11 +274,11 @@ class GenericPlatform:
|
||||||
|
|
||||||
def get_verilog(self, fragment, **kwargs):
|
def get_verilog(self, fragment, **kwargs):
|
||||||
return self._get_source(fragment, lambda f: verilog.convert(f, self.constraint_manager.get_io_signals(),
|
return self._get_source(fragment, lambda f: verilog.convert(f, self.constraint_manager.get_io_signals(),
|
||||||
return_ns=True, create_clock_domains=False, simulation=False, **kwargs))
|
return_ns=True, create_clock_domains=False, **kwargs))
|
||||||
|
|
||||||
def get_edif(self, fragment, cell_library, vendor, device, **kwargs):
|
def get_edif(self, fragment, cell_library, vendor, device, **kwargs):
|
||||||
return self._get_source(fragment, lambda f: edif.convert(f, self.constraint_manager.get_io_signals(),
|
return self._get_source(fragment, lambda f: edif.convert(f, self.constraint_manager.get_io_signals(),
|
||||||
cell_library, vendor, device, return_ns=True, simulation=False, **kwargs))
|
cell_library, vendor, device, return_ns=True, **kwargs))
|
||||||
|
|
||||||
def build(self, fragment):
|
def build(self, fragment):
|
||||||
raise NotImplementedError("GenericPlatform.build must be overloaded")
|
raise NotImplementedError("GenericPlatform.build must be overloaded")
|
||||||
|
|
|
@ -175,19 +175,18 @@ def _printheader(f, ios, name, ns):
|
||||||
r += "\n"
|
r += "\n"
|
||||||
return r
|
return r
|
||||||
|
|
||||||
def _printcomb(f, ns, simulation, display_run):
|
def _printcomb(f, ns, display_run):
|
||||||
r = ""
|
r = ""
|
||||||
if f.comb:
|
if f.comb:
|
||||||
if simulation:
|
# Generate a dummy event to get the simulator
|
||||||
# Generate a dummy event to get the simulator
|
# to run the combinatorial process once at the beginning.
|
||||||
# to run the combinatorial process once at the beginning.
|
syn_off = "// synthesis translate_off\n"
|
||||||
syn_off = "// synthesis translate_off\n"
|
syn_on = "// synthesis translate_on\n"
|
||||||
syn_on = "// synthesis translate_on\n"
|
dummy_s = Signal(name_override="dummy_s")
|
||||||
dummy_s = Signal(name_override="dummy_s")
|
r += syn_off
|
||||||
r += syn_off
|
r += "reg " + _printsig(ns, dummy_s) + ";\n"
|
||||||
r += "reg " + _printsig(ns, dummy_s) + ";\n"
|
r += "initial " + ns.get_name(dummy_s) + " <= 1'd0;\n"
|
||||||
r += "initial " + ns.get_name(dummy_s) + " <= 1'd0;\n"
|
r += syn_on
|
||||||
r += syn_on
|
|
||||||
|
|
||||||
groups = group_by_targets(f.comb)
|
groups = group_by_targets(f.comb)
|
||||||
|
|
||||||
|
@ -195,11 +194,10 @@ def _printcomb(f, ns, simulation, display_run):
|
||||||
if len(g[1]) == 1 and isinstance(g[1][0], _Assign):
|
if len(g[1]) == 1 and isinstance(g[1][0], _Assign):
|
||||||
r += "assign " + _printnode(ns, _AT_BLOCKING, 0, g[1][0])
|
r += "assign " + _printnode(ns, _AT_BLOCKING, 0, g[1][0])
|
||||||
else:
|
else:
|
||||||
if simulation:
|
dummy_d = Signal(name_override="dummy_d")
|
||||||
dummy_d = Signal(name_override="dummy_d")
|
r += "\n" + syn_off
|
||||||
r += "\n" + syn_off
|
r += "reg " + _printsig(ns, dummy_d) + ";\n"
|
||||||
r += "reg " + _printsig(ns, dummy_d) + ";\n"
|
r += syn_on
|
||||||
r += syn_on
|
|
||||||
|
|
||||||
r += "always @(*) begin\n"
|
r += "always @(*) begin\n"
|
||||||
if display_run:
|
if display_run:
|
||||||
|
@ -207,10 +205,9 @@ def _printcomb(f, ns, simulation, display_run):
|
||||||
for t in g[0]:
|
for t in g[0]:
|
||||||
r += "\t" + ns.get_name(t) + " <= " + _printexpr(ns, t.reset)[0] + ";\n"
|
r += "\t" + ns.get_name(t) + " <= " + _printexpr(ns, t.reset)[0] + ";\n"
|
||||||
r += _printnode(ns, _AT_NONBLOCKING, 1, g[1])
|
r += _printnode(ns, _AT_NONBLOCKING, 1, g[1])
|
||||||
if simulation:
|
r += syn_off
|
||||||
r += syn_off
|
r += "\t" + ns.get_name(dummy_d) + " <= " + ns.get_name(dummy_s) + ";\n"
|
||||||
r += "\t" + ns.get_name(dummy_d) + " <= " + ns.get_name(dummy_s) + ";\n"
|
r += syn_on
|
||||||
r += syn_on
|
|
||||||
r += "end\n"
|
r += "end\n"
|
||||||
r += "\n"
|
r += "\n"
|
||||||
return r
|
return r
|
||||||
|
@ -290,7 +287,6 @@ def convert(f, ios=None, name="top",
|
||||||
return_ns=False,
|
return_ns=False,
|
||||||
special_overrides=dict(),
|
special_overrides=dict(),
|
||||||
create_clock_domains=True,
|
create_clock_domains=True,
|
||||||
simulation=True,
|
|
||||||
display_run=False):
|
display_run=False):
|
||||||
if not isinstance(f, _Fragment):
|
if not isinstance(f, _Fragment):
|
||||||
f = f.get_fragment()
|
f = f.get_fragment()
|
||||||
|
@ -320,7 +316,7 @@ def convert(f, ios=None, name="top",
|
||||||
|
|
||||||
r = "/* Machine-generated using Migen */\n"
|
r = "/* Machine-generated using Migen */\n"
|
||||||
r += _printheader(f, ios, name, ns)
|
r += _printheader(f, ios, name, ns)
|
||||||
r += _printcomb(f, ns, simulation, display_run)
|
r += _printcomb(f, ns, display_run)
|
||||||
r += _printsync(f, ns)
|
r += _printsync(f, ns)
|
||||||
r += _printspecials(special_overrides, f.specials - lowered_specials, ns)
|
r += _printspecials(special_overrides, f.specials - lowered_specials, ns)
|
||||||
r += _printinit(f, ios, ns)
|
r += _printinit(f, ios, ns)
|
||||||
|
|
Loading…
Reference in a new issue