hdl._ir: remove Fragment.drivers
.
This commit is contained in:
parent
262e24b564
commit
81c35a5922
|
@ -675,15 +675,7 @@ class Module(_ModuleBuilderRoot, Elaboratable):
|
|||
for domain, statements in self._statements.items():
|
||||
statements = resolve_statements(statements)
|
||||
fragment.add_statements(domain, statements)
|
||||
visitor = _Visitor()
|
||||
visitor.visit_stmt(statements)
|
||||
for signal in visitor.driven_signals:
|
||||
fragment.add_driver(signal, domain)
|
||||
fragment.add_statements("comb", self._top_comb_statements)
|
||||
visitor = _Visitor()
|
||||
visitor.visit_stmt(self._top_comb_statements)
|
||||
for signal in visitor.driven_signals:
|
||||
fragment.add_driver(signal, "comb")
|
||||
fragment.add_domains(self._domains.values())
|
||||
fragment.generated.update(self._generated)
|
||||
return fragment
|
||||
|
|
|
@ -63,7 +63,6 @@ class Fragment:
|
|||
obj = new_obj
|
||||
|
||||
def __init__(self, *, src_loc=None):
|
||||
self.drivers = OrderedDict()
|
||||
self.statements = {}
|
||||
self.domains = OrderedDict()
|
||||
self.subfragments = []
|
||||
|
@ -73,28 +72,6 @@ class Fragment:
|
|||
self.origins = None
|
||||
self.domains_propagated_up = {}
|
||||
|
||||
def add_driver(self, signal, domain="comb"):
|
||||
assert isinstance(domain, str)
|
||||
if domain not in self.drivers:
|
||||
self.drivers[domain] = _ast.SignalSet()
|
||||
self.drivers[domain].add(signal)
|
||||
|
||||
def iter_drivers(self):
|
||||
for domain, signals in self.drivers.items():
|
||||
for signal in signals:
|
||||
yield domain, signal
|
||||
|
||||
def iter_comb(self):
|
||||
if "comb" in self.drivers:
|
||||
yield from self.drivers["comb"]
|
||||
|
||||
def iter_sync(self):
|
||||
for domain, signals in self.drivers.items():
|
||||
if domain == "comb":
|
||||
continue
|
||||
for signal in signals:
|
||||
yield domain, signal
|
||||
|
||||
def add_domains(self, *domains):
|
||||
for domain in flatten(domains):
|
||||
assert isinstance(domain, _cd.ClockDomain)
|
||||
|
|
|
@ -221,8 +221,6 @@ class MemoryInstance(Fragment):
|
|||
assert isinstance(idx, int)
|
||||
assert idx in range(len(self._write_ports))
|
||||
assert self._write_ports[idx]._domain == port._domain
|
||||
for signal in port._data._rhs_signals():
|
||||
self.add_driver(signal, port._domain)
|
||||
self._read_ports.append(port)
|
||||
|
||||
def write_port(self, *, domain, addr, data, en):
|
||||
|
|
|
@ -252,10 +252,6 @@ class FragmentTransformer:
|
|||
for domain, statements in fragment.statements.items():
|
||||
new_fragment.add_statements(domain, statements)
|
||||
|
||||
def map_drivers(self, fragment, new_fragment):
|
||||
for domain, signal in fragment.iter_drivers():
|
||||
new_fragment.add_driver(signal, domain)
|
||||
|
||||
def map_memory_ports(self, fragment, new_fragment):
|
||||
if hasattr(self, "on_value"):
|
||||
for port in new_fragment._read_ports:
|
||||
|
@ -322,7 +318,6 @@ class FragmentTransformer:
|
|||
self.map_subfragments(fragment, new_fragment)
|
||||
self.map_domains(fragment, new_fragment)
|
||||
self.map_statements(fragment, new_fragment)
|
||||
self.map_drivers(fragment, new_fragment)
|
||||
return new_fragment
|
||||
|
||||
def __call__(self, value, *, src_loc_at=0):
|
||||
|
@ -518,13 +513,6 @@ class DomainRenamer(FragmentTransformer, ValueTransformer, StatementTransformer)
|
|||
map(self.on_statement, statements)
|
||||
)
|
||||
|
||||
def map_drivers(self, fragment, new_fragment):
|
||||
for domain, signals in fragment.drivers.items():
|
||||
if domain in self.domain_map:
|
||||
domain = self.domain_map[domain]
|
||||
for signal in signals:
|
||||
new_fragment.add_driver(self.on_value(signal), domain)
|
||||
|
||||
def map_memory_ports(self, fragment, new_fragment):
|
||||
super().map_memory_ports(fragment, new_fragment)
|
||||
for port in new_fragment._read_ports:
|
||||
|
@ -560,10 +548,6 @@ class DomainLowerer(FragmentTransformer, ValueTransformer, StatementTransformer)
|
|||
self._warn_on_propagation_up(domain, context.src_loc)
|
||||
return self.domains[domain]
|
||||
|
||||
def map_drivers(self, fragment, new_fragment):
|
||||
for domain, signal in fragment.iter_drivers():
|
||||
new_fragment.add_driver(self.on_value(signal), domain)
|
||||
|
||||
def replace_value_src_loc(self, value, new_value):
|
||||
return not isinstance(value, (ClockSignal, ResetSignal))
|
||||
|
||||
|
@ -605,9 +589,12 @@ class _ControlInserter(FragmentTransformer):
|
|||
|
||||
def on_fragment(self, fragment):
|
||||
new_fragment = super().on_fragment(fragment)
|
||||
for domain, signals in fragment.drivers.items():
|
||||
for domain, statements in fragment.statements.items():
|
||||
if domain == "comb" or domain not in self.controls:
|
||||
continue
|
||||
signals = SignalSet()
|
||||
for stmt in statements:
|
||||
signals |= stmt._lhs_signals()
|
||||
self._insert_control(new_fragment, domain, signals)
|
||||
return new_fragment
|
||||
|
||||
|
|
|
@ -631,12 +631,6 @@ class DSLTestCase(FHDLTestCase):
|
|||
)
|
||||
)
|
||||
""")
|
||||
self.assertEqual({repr(sig): k for k, v in frag.drivers.items() for sig in v}, {
|
||||
"(sig a)": "comb",
|
||||
"(sig fsm_state)": "sync",
|
||||
"(sig b)": "sync",
|
||||
"(sig)": "comb",
|
||||
})
|
||||
fsm = frag.find_generated("fsm")
|
||||
self.assertIsInstance(fsm.state, Signal)
|
||||
self.assertEqual(fsm.encoding, OrderedDict({
|
||||
|
@ -960,9 +954,6 @@ class DSLTestCase(FHDLTestCase):
|
|||
(eq (sig c1) (sig s1))
|
||||
)
|
||||
""")
|
||||
self.assertEqual(f1.drivers, {
|
||||
"comb": SignalSet((self.c1,))
|
||||
})
|
||||
self.assertEqual(len(f1.subfragments), 1)
|
||||
(f2, f2_name, _), = f1.subfragments
|
||||
self.assertEqual(f2_name, "foo")
|
||||
|
@ -976,8 +967,4 @@ class DSLTestCase(FHDLTestCase):
|
|||
(eq (sig c3) (sig s3))
|
||||
)
|
||||
""")
|
||||
self.assertEqual(f2.drivers, {
|
||||
"comb": SignalSet((self.c2,)),
|
||||
"sync": SignalSet((self.c3,))
|
||||
})
|
||||
self.assertEqual(len(f2.subfragments), 0)
|
||||
|
|
|
@ -70,13 +70,6 @@ class FragmentGeneratedTestCase(FHDLTestCase):
|
|||
SignalKey(sig))
|
||||
|
||||
|
||||
class FragmentDriversTestCase(FHDLTestCase):
|
||||
def test_empty(self):
|
||||
f = Fragment()
|
||||
self.assertEqual(list(f.iter_comb()), [])
|
||||
self.assertEqual(list(f.iter_sync()), [])
|
||||
|
||||
|
||||
class DuplicateElaboratableTestCase(FHDLTestCase):
|
||||
def test_duplicate(self):
|
||||
sub = Module()
|
||||
|
@ -255,7 +248,6 @@ class FragmentPortsTestCase(FHDLTestCase):
|
|||
cd_sync = ClockDomain()
|
||||
ctr = Signal(4)
|
||||
f.add_domains(cd_sync)
|
||||
f.add_driver(ctr, "sync")
|
||||
f.add_statements("sync", ctr.eq(ctr + 1))
|
||||
nl = build_netlist(f, ports=[
|
||||
ClockSignal("sync"),
|
||||
|
@ -277,7 +269,6 @@ class FragmentPortsTestCase(FHDLTestCase):
|
|||
def test_port_autodomain(self):
|
||||
f = Fragment()
|
||||
ctr = Signal(4)
|
||||
f.add_driver(ctr, "sync")
|
||||
f.add_statements("sync", ctr.eq(ctr + 1))
|
||||
nl = build_netlist(f, ports=[ctr])
|
||||
self.assertRepr(nl, """
|
||||
|
@ -299,7 +290,6 @@ class FragmentPortsTestCase(FHDLTestCase):
|
|||
a = Signal(4)
|
||||
b = Signal(4)
|
||||
c = Signal(3)
|
||||
f1.add_driver(c)
|
||||
f1.add_statements("comb", c.eq((a * b).shift_right(4)))
|
||||
nl = build_netlist(f, ports=[a, b, c])
|
||||
self.assertRepr(nl, """
|
||||
|
@ -546,16 +536,14 @@ class FragmentDomainsTestCase(FHDLTestCase):
|
|||
fa.add_domains(cda)
|
||||
fb = Fragment()
|
||||
fb.add_domains(cdb)
|
||||
fb.add_driver(ResetSignal("sync"), "comb")
|
||||
fb.add_statements("comb", ResetSignal("sync").eq(1))
|
||||
f = Fragment()
|
||||
f.add_subfragment(fa, "a")
|
||||
f.add_subfragment(fb, "b")
|
||||
|
||||
f._propagate_domains_up()
|
||||
fb_new, _, _ = f.subfragments[1]
|
||||
self.assertEqual(fb_new.drivers, OrderedDict({
|
||||
"comb": SignalSet((ResetSignal("b_sync"),))
|
||||
}))
|
||||
self.assertRepr(fb_new.statements["comb"], "((eq (rst b_sync) (const 1'd1)))")
|
||||
|
||||
def test_domain_conflict_rename_drivers_before_creating_missing(self):
|
||||
cda = ClockDomain("sync")
|
||||
|
@ -569,7 +557,7 @@ class FragmentDomainsTestCase(FHDLTestCase):
|
|||
f = Fragment()
|
||||
f.add_subfragment(fa, "a")
|
||||
f.add_subfragment(fb, "b")
|
||||
f.add_driver(s, "b_sync")
|
||||
f.add_statements("b_sync", s.eq(1))
|
||||
|
||||
f._propagate_domains(lambda name: ClockDomain(name))
|
||||
|
||||
|
@ -701,11 +689,11 @@ class FragmentHierarchyConflictTestCase(FHDLTestCase):
|
|||
f1 = Fragment()
|
||||
cd1 = ClockDomain("d", local=True)
|
||||
f1.add_domains(cd1)
|
||||
f1.add_driver(ClockSignal("d"))
|
||||
f1.add_statements("comb", ClockSignal("d").eq(1))
|
||||
f2 = Fragment()
|
||||
cd2 = ClockDomain("d", local=True)
|
||||
f2.add_domains(cd2)
|
||||
f2.add_driver(ClockSignal("d"))
|
||||
f2.add_statements("comb", ClockSignal("d").eq(1))
|
||||
f3 = Fragment()
|
||||
f3.add_subfragment(f1)
|
||||
f3.add_subfragment(f2)
|
||||
|
@ -997,11 +985,8 @@ class NamesTestCase(FHDLTestCase):
|
|||
f.add_domains(cd_sync := ClockDomain())
|
||||
f.add_domains(cd_sync_norst := ClockDomain(reset_less=True))
|
||||
f.add_statements("comb", [o1.eq(0)])
|
||||
f.add_driver(o1, domain="comb")
|
||||
f.add_statements("sync", [o2.eq(i1)])
|
||||
f.add_driver(o2, domain="sync")
|
||||
f.add_statements("sync_norst", [o3.eq(i1)])
|
||||
f.add_driver(o3, domain="sync_norst")
|
||||
|
||||
ports = {
|
||||
"i": (i, PortDirection.Input),
|
||||
|
@ -1242,7 +1227,6 @@ class AssignTestCase(FHDLTestCase):
|
|||
"comb",
|
||||
s1.eq(s2)
|
||||
)
|
||||
f.add_driver(s1, "comb")
|
||||
nl = build_netlist(f, ports=[s1, s2])
|
||||
self.assertRepr(nl, """
|
||||
(
|
||||
|
@ -1265,7 +1249,6 @@ class AssignTestCase(FHDLTestCase):
|
|||
"comb",
|
||||
s1.eq(s2)
|
||||
)
|
||||
f.add_driver(s1, "comb")
|
||||
nl = build_netlist(f, ports=[s1, s2])
|
||||
self.assertRepr(nl, """
|
||||
(
|
||||
|
@ -1288,7 +1271,6 @@ class AssignTestCase(FHDLTestCase):
|
|||
"comb",
|
||||
s1.eq(s2)
|
||||
)
|
||||
f.add_driver(s1, "comb")
|
||||
nl = build_netlist(f, ports=[s1, s2])
|
||||
self.assertRepr(nl, """
|
||||
(
|
||||
|
@ -1311,7 +1293,6 @@ class AssignTestCase(FHDLTestCase):
|
|||
"comb",
|
||||
s1.eq(s2)
|
||||
)
|
||||
f.add_driver(s1, "comb")
|
||||
nl = build_netlist(f, ports=[s1, s2])
|
||||
self.assertRepr(nl, """
|
||||
(
|
||||
|
@ -1334,7 +1315,6 @@ class AssignTestCase(FHDLTestCase):
|
|||
"comb",
|
||||
s1[2:6].eq(s2)
|
||||
)
|
||||
f.add_driver(s1, "comb")
|
||||
nl = build_netlist(f, ports=[s1, s2])
|
||||
self.assertRepr(nl, """
|
||||
(
|
||||
|
@ -1359,7 +1339,6 @@ class AssignTestCase(FHDLTestCase):
|
|||
"comb",
|
||||
s1.bit_select(s3, 4).eq(s2)
|
||||
)
|
||||
f.add_driver(s1, "comb")
|
||||
nl = build_netlist(f, ports=[s1, s2, s3])
|
||||
self.assertRepr(nl, """
|
||||
(
|
||||
|
@ -1404,7 +1383,6 @@ class AssignTestCase(FHDLTestCase):
|
|||
"comb",
|
||||
s1.bit_select(s3, 4).eq(s2)
|
||||
)
|
||||
f.add_driver(s1, "comb")
|
||||
nl = build_netlist(f, ports=[s1, s2, s3])
|
||||
self.assertRepr(nl, """
|
||||
(
|
||||
|
@ -1441,7 +1419,6 @@ class AssignTestCase(FHDLTestCase):
|
|||
"comb",
|
||||
s1.word_select(s3, 4).eq(s2)
|
||||
)
|
||||
f.add_driver(s1, "comb")
|
||||
nl = build_netlist(f, ports=[s1, s2, s3])
|
||||
self.assertRepr(nl, """
|
||||
(
|
||||
|
@ -1478,7 +1455,6 @@ class AssignTestCase(FHDLTestCase):
|
|||
"comb",
|
||||
s1.word_select(s3, 4).eq(s2)
|
||||
)
|
||||
f.add_driver(s1, "comb")
|
||||
nl = build_netlist(f, ports=[s1, s2, s3])
|
||||
self.assertRepr(nl, """
|
||||
(
|
||||
|
@ -1518,9 +1494,6 @@ class AssignTestCase(FHDLTestCase):
|
|||
"comb",
|
||||
Cat(s1, s2, s3).eq(s4)
|
||||
)
|
||||
f.add_driver(s1, "comb")
|
||||
f.add_driver(s2, "comb")
|
||||
f.add_driver(s3, "comb")
|
||||
nl = build_netlist(f, ports=[s1, s2, s3, s4])
|
||||
self.assertRepr(nl, """
|
||||
(
|
||||
|
@ -1549,9 +1522,6 @@ class AssignTestCase(FHDLTestCase):
|
|||
"comb",
|
||||
Cat(s1, s2, s3).eq(s4)
|
||||
)
|
||||
f.add_driver(s1, "comb")
|
||||
f.add_driver(s2, "comb")
|
||||
f.add_driver(s3, "comb")
|
||||
nl = build_netlist(f, ports=[s1, s2, s3, s4])
|
||||
self.assertRepr(nl, """
|
||||
(
|
||||
|
@ -1579,8 +1549,6 @@ class AssignTestCase(FHDLTestCase):
|
|||
s1.as_signed().eq(s3),
|
||||
s2.as_unsigned().eq(s3),
|
||||
])
|
||||
f.add_driver(s1, "comb")
|
||||
f.add_driver(s2, "comb")
|
||||
nl = build_netlist(f, ports=[s1, s2, s3])
|
||||
self.assertRepr(nl, """
|
||||
(
|
||||
|
@ -1607,9 +1575,6 @@ class AssignTestCase(FHDLTestCase):
|
|||
f.add_statements("comb", [
|
||||
Array([s1, s2, s3])[s4].eq(s5),
|
||||
])
|
||||
f.add_driver(s1, "comb")
|
||||
f.add_driver(s2, "comb")
|
||||
f.add_driver(s3, "comb")
|
||||
nl = build_netlist(f, ports=[s1, s2, s3, s4, s5])
|
||||
self.assertRepr(nl, """
|
||||
(
|
||||
|
@ -1660,10 +1625,6 @@ class AssignTestCase(FHDLTestCase):
|
|||
(None, s4),
|
||||
]).eq(s7),
|
||||
])
|
||||
f.add_driver(s1, "comb")
|
||||
f.add_driver(s2, "comb")
|
||||
f.add_driver(s3, "comb")
|
||||
f.add_driver(s4, "comb")
|
||||
nl = build_netlist(f, ports=[s1, s2, s3, s4, s5, s6, s7])
|
||||
self.assertRepr(nl, """
|
||||
(
|
||||
|
@ -1708,7 +1669,6 @@ class AssignTestCase(FHDLTestCase):
|
|||
"comb",
|
||||
s1[1:11][2:6].eq(s2)
|
||||
)
|
||||
f.add_driver(s1, "comb")
|
||||
nl = build_netlist(f, ports=[s1, s2])
|
||||
self.assertRepr(nl, """
|
||||
(
|
||||
|
@ -1736,11 +1696,6 @@ class AssignTestCase(FHDLTestCase):
|
|||
"comb",
|
||||
Cat(s1, s2, s3, s4, s5)[5:14].eq(s6)
|
||||
)
|
||||
f.add_driver(s1, "comb")
|
||||
f.add_driver(s2, "comb")
|
||||
f.add_driver(s3, "comb")
|
||||
f.add_driver(s4, "comb")
|
||||
f.add_driver(s5, "comb")
|
||||
nl = build_netlist(f, ports=[s1, s2, s3, s4, s5, s6])
|
||||
self.assertRepr(nl, """
|
||||
(
|
||||
|
@ -1774,7 +1729,6 @@ class AssignTestCase(FHDLTestCase):
|
|||
"comb",
|
||||
s1.bit_select(s3, 6)[2:4].eq(s2)
|
||||
)
|
||||
f.add_driver(s1, "comb")
|
||||
nl = build_netlist(f, ports=[s1, s2, s3])
|
||||
self.assertRepr(nl, """
|
||||
(
|
||||
|
@ -1817,7 +1771,6 @@ class AssignTestCase(FHDLTestCase):
|
|||
"comb",
|
||||
s1.word_select(s3, 4)[1:3].eq(s2)
|
||||
)
|
||||
f.add_driver(s1, "comb")
|
||||
nl = build_netlist(f, ports=[s1, s2, s3])
|
||||
self.assertRepr(nl, """
|
||||
(
|
||||
|
@ -1851,9 +1804,6 @@ class AssignTestCase(FHDLTestCase):
|
|||
f.add_statements("comb", [
|
||||
Array([s1, s2, s3])[s4][2:7].eq(s5),
|
||||
])
|
||||
f.add_driver(s1, "comb")
|
||||
f.add_driver(s2, "comb")
|
||||
f.add_driver(s3, "comb")
|
||||
nl = build_netlist(f, ports=[s1, s2, s3, s4, s5])
|
||||
self.assertRepr(nl, """
|
||||
(
|
||||
|
@ -1890,7 +1840,6 @@ class AssignTestCase(FHDLTestCase):
|
|||
"comb",
|
||||
s1[1:7].bit_select(s3, 4).eq(s2)
|
||||
)
|
||||
f.add_driver(s1, "comb")
|
||||
nl = build_netlist(f, ports=[s1, s2, s3])
|
||||
self.assertRepr(nl, """
|
||||
(
|
||||
|
@ -1931,7 +1880,6 @@ class AssignTestCase(FHDLTestCase):
|
|||
"comb",
|
||||
s1[3:9].bit_select(s3, 4)[1:3].eq(s2)
|
||||
)
|
||||
f.add_driver(s1, "comb")
|
||||
nl = build_netlist(f, ports=[s1, s2, s3])
|
||||
self.assertRepr(nl, """
|
||||
(
|
||||
|
@ -1971,8 +1919,6 @@ class AssignTestCase(FHDLTestCase):
|
|||
s1.as_signed()[2:7].eq(s3),
|
||||
s2.as_unsigned()[2:7].eq(s3),
|
||||
])
|
||||
f.add_driver(s1, "comb")
|
||||
f.add_driver(s2, "comb")
|
||||
nl = build_netlist(f, ports=[s1, s2, s3])
|
||||
self.assertRepr(nl, """
|
||||
(
|
||||
|
|
|
@ -34,9 +34,6 @@ class DomainRenamerTestCase(FHDLTestCase):
|
|||
"sync",
|
||||
self.s3.eq(0),
|
||||
)
|
||||
f.add_driver(self.s1, "comb")
|
||||
f.add_driver(self.s2, "comb")
|
||||
f.add_driver(self.s3, "sync")
|
||||
|
||||
f = DomainRenamer("pix")(f)
|
||||
self.assertRepr(f.statements["comb"], """
|
||||
|
@ -53,10 +50,6 @@ class DomainRenamerTestCase(FHDLTestCase):
|
|||
)
|
||||
""")
|
||||
self.assertFalse("sync" in f.statements)
|
||||
self.assertEqual(f.drivers, {
|
||||
"comb": SignalSet((self.s1, self.s2)),
|
||||
"pix": SignalSet((self.s3,)),
|
||||
})
|
||||
|
||||
def test_rename_multi(self):
|
||||
f = Fragment()
|
||||
|
@ -204,20 +197,6 @@ class DomainLowererTestCase(FHDLTestCase):
|
|||
)
|
||||
""")
|
||||
|
||||
def test_lower_drivers(self):
|
||||
sync = ClockDomain()
|
||||
pix = ClockDomain()
|
||||
f = Fragment()
|
||||
f.add_domains(sync, pix)
|
||||
f.add_driver(ClockSignal("pix"), "comb")
|
||||
f.add_driver(ResetSignal("pix"), "sync")
|
||||
|
||||
f = DomainLowerer()(f)
|
||||
self.assertEqual(f.drivers, {
|
||||
"comb": SignalSet((pix.clk,)),
|
||||
"sync": SignalSet((pix.rst,))
|
||||
})
|
||||
|
||||
def test_lower_wrong_domain(self):
|
||||
f = Fragment()
|
||||
f.add_statements(
|
||||
|
@ -256,7 +235,6 @@ class ResetInserterTestCase(FHDLTestCase):
|
|||
"sync",
|
||||
self.s1.eq(1)
|
||||
)
|
||||
f.add_driver(self.s1, "sync")
|
||||
|
||||
f = ResetInserter(self.c1)(f)
|
||||
self.assertRepr(f.statements["sync"], """
|
||||
|
@ -273,8 +251,6 @@ class ResetInserterTestCase(FHDLTestCase):
|
|||
f.add_statements("sync", self.s1.eq(1))
|
||||
f.add_statements("pix", self.s2.eq(0))
|
||||
f.add_domains(ClockDomain("sync"))
|
||||
f.add_driver(self.s1, "sync")
|
||||
f.add_driver(self.s2, "pix")
|
||||
|
||||
f = ResetInserter({"pix": self.c1})(f)
|
||||
self.assertRepr(f.statements["sync"], """
|
||||
|
@ -294,7 +270,6 @@ class ResetInserterTestCase(FHDLTestCase):
|
|||
def test_reset_value(self):
|
||||
f = Fragment()
|
||||
f.add_statements("sync", self.s2.eq(0))
|
||||
f.add_driver(self.s2, "sync")
|
||||
|
||||
f = ResetInserter(self.c1)(f)
|
||||
self.assertRepr(f.statements["sync"], """
|
||||
|
@ -309,7 +284,6 @@ class ResetInserterTestCase(FHDLTestCase):
|
|||
def test_reset_less(self):
|
||||
f = Fragment()
|
||||
f.add_statements("sync", self.s3.eq(0))
|
||||
f.add_driver(self.s3, "sync")
|
||||
|
||||
f = ResetInserter(self.c1)(f)
|
||||
self.assertRepr(f.statements["sync"], """
|
||||
|
@ -332,7 +306,6 @@ class EnableInserterTestCase(FHDLTestCase):
|
|||
def test_enable_default(self):
|
||||
f = Fragment()
|
||||
f.add_statements("sync", self.s1.eq(1))
|
||||
f.add_driver(self.s1, "sync")
|
||||
|
||||
f = EnableInserter(self.c1)(f)
|
||||
self.assertRepr(f.statements["sync"], """
|
||||
|
@ -347,8 +320,6 @@ class EnableInserterTestCase(FHDLTestCase):
|
|||
f = Fragment()
|
||||
f.add_statements("sync", self.s1.eq(1))
|
||||
f.add_statements("pix", self.s2.eq(0))
|
||||
f.add_driver(self.s1, "sync")
|
||||
f.add_driver(self.s2, "pix")
|
||||
|
||||
f = EnableInserter({"pix": self.c1})(f)
|
||||
self.assertRepr(f.statements["sync"], """
|
||||
|
@ -367,11 +338,9 @@ class EnableInserterTestCase(FHDLTestCase):
|
|||
def test_enable_subfragment(self):
|
||||
f1 = Fragment()
|
||||
f1.add_statements("sync", self.s1.eq(1))
|
||||
f1.add_driver(self.s1, "sync")
|
||||
|
||||
f2 = Fragment()
|
||||
f2.add_statements("sync", self.s2.eq(1))
|
||||
f2.add_driver(self.s2, "sync")
|
||||
f1.add_subfragment(f2)
|
||||
|
||||
f1 = EnableInserter(self.c1)(f1)
|
||||
|
@ -421,7 +390,6 @@ class _MockElaboratable(Elaboratable):
|
|||
def elaborate(self, platform):
|
||||
f = Fragment()
|
||||
f.add_statements("sync", self.s1.eq(1))
|
||||
f.add_driver(self.s1, "sync")
|
||||
return f
|
||||
|
||||
|
||||
|
|
|
@ -31,8 +31,6 @@ class SimulatorUnitTestCase(FHDLTestCase):
|
|||
stmt = stmt(osig, *isigs)
|
||||
frag = Fragment()
|
||||
frag.add_statements("comb", stmt)
|
||||
for signal in flatten(s._lhs_signals() for s in Statement.cast(stmt)):
|
||||
frag.add_driver(signal)
|
||||
|
||||
sim = Simulator(frag)
|
||||
def process():
|
||||
|
|
Loading…
Reference in a new issue