amaranth/nmigen/compat/sim/__init__.py

40 lines
1.2 KiB
Python
Raw Normal View History

import functools
import collections
import inspect
2018-12-14 09:22:18 -07:00
from ...back.pysim import *
__all__ = ["run_simulation", "passive"]
2018-12-14 09:22:18 -07:00
def run_simulation(fragment_or_module, generators, clocks={"sync": 10}, vcd_name=None,
special_overrides={}):
assert not special_overrides
if hasattr(fragment_or_module, "get_fragment"):
fragment = fragment_or_module.get_fragment()
2018-12-14 09:22:18 -07:00
else:
fragment = fragment_or_module
if not isinstance(generators, dict):
generators = {"sync": generators}
with Simulator(fragment, vcd_file=open(vcd_name, "w") if vcd_name else None) as sim:
for domain, period in clocks.items():
sim.add_clock(period / 1e9, domain=domain)
for domain, processes in generators.items():
if isinstance(processes, collections.Iterable) and not inspect.isgenerator(processes):
for process in processes:
sim.add_sync_process(process, domain=domain)
else:
sim.add_sync_process(processes, domain=domain)
2018-12-14 09:22:18 -07:00
sim.run()
def passive(generator):
@functools.wraps(generator)
def wrapper(*args, **kwargs):
yield Passive()
yield from generator(*args, **kwargs)
return wrapper