hdl._ir: remove Fragment.drivers.
This commit is contained in:
parent
262e24b564
commit
81c35a5922
8 changed files with 9 additions and 156 deletions
|
|
@ -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…
Add table
Add a link
Reference in a new issue