soc/cores/hyperbus: Avoid dq_oe condition to generate dq_o (was only useful for sim but now avoided).
This commit is contained in:
parent
298a004f08
commit
60f83b71fa
|
@ -89,8 +89,8 @@ class HyperRAM(LiteXModule):
|
||||||
|
|
||||||
# Tristates.
|
# Tristates.
|
||||||
# ----------
|
# ----------
|
||||||
dq = self.add_tristate(pads.dq, register=False) if not hasattr(pads.dq, "oe") else pads.dq
|
dq = self.add_tristate(pads.dq, register=False) if not hasattr(pads.dq, "oe") else pads.dq
|
||||||
rwds = self.add_tristate(pads.rwds, register=False) if not hasattr(pads.rwds, "oe") else pads.rwds
|
rwds = self.add_tristate(pads.rwds, register=False) if not hasattr(pads.rwds, "oe") else pads.rwds
|
||||||
self.comb += [
|
self.comb += [
|
||||||
# DQ O/OE.
|
# DQ O/OE.
|
||||||
dq.o.eq( dq_o),
|
dq.o.eq( dq_o),
|
||||||
|
@ -160,7 +160,6 @@ class HyperRAM(LiteXModule):
|
||||||
).Else(
|
).Else(
|
||||||
sr_next[:dw].eq(dq_i),
|
sr_next[:dw].eq(dq_i),
|
||||||
sr_next[dw:].eq(sr),
|
sr_next[dw:].eq(sr),
|
||||||
|
|
||||||
)
|
)
|
||||||
]
|
]
|
||||||
self.sync += If(clk_phase[0] == 0, sr.eq(sr_next)) # Shift on 0°/180° (and sampled on 90°/270°).
|
self.sync += If(clk_phase[0] == 0, sr.eq(sr_next)) # Shift on 0°/180° (and sampled on 90°/270°).
|
||||||
|
@ -168,14 +167,12 @@ class HyperRAM(LiteXModule):
|
||||||
# Data Shift-Out Register ------------------------------------------------------------------
|
# Data Shift-Out Register ------------------------------------------------------------------
|
||||||
self.comb += [
|
self.comb += [
|
||||||
bus.dat_r.eq(sr_next),
|
bus.dat_r.eq(sr_next),
|
||||||
If(dq_oe,
|
# Command/Address: 8-bit.
|
||||||
# Command/Address: 8-bit.
|
If(ca_oe,
|
||||||
If(ca_oe,
|
dq_o.eq(sr[-8:]),
|
||||||
dq_o.eq(sr[-8:]),
|
# Data: dw-bit.
|
||||||
# Data: dw-bit.
|
).Else(
|
||||||
).Else(
|
dq_o.eq(sr[-dw:]),
|
||||||
dq_o.eq(sr[-dw:]),
|
|
||||||
)
|
|
||||||
)
|
)
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|
|
@ -49,7 +49,8 @@ class TestHyperBus(unittest.TestCase):
|
||||||
self.assertEqual(c2bool(clk[i]), (yield dut.pads.clk))
|
self.assertEqual(c2bool(clk[i]), (yield dut.pads.clk))
|
||||||
self.assertEqual(c2bool(cs_n[i]), (yield dut.pads.cs_n))
|
self.assertEqual(c2bool(cs_n[i]), (yield dut.pads.cs_n))
|
||||||
self.assertEqual(c2bool(dq_oe[i]), (yield dut.pads.dq.oe))
|
self.assertEqual(c2bool(dq_oe[i]), (yield dut.pads.dq.oe))
|
||||||
self.assertEqual(int(dq_o[2*(i//2):2*(i//2)+2], 16), (yield dut.pads.dq.o))
|
if (yield dut.pads.dq.oe):
|
||||||
|
self.assertEqual(int(dq_o[2*(i//2):2*(i//2)+2], 16), (yield dut.pads.dq.o))
|
||||||
self.assertEqual(c2bool(rwds_oe[i]), (yield dut.pads.rwds.oe))
|
self.assertEqual(c2bool(rwds_oe[i]), (yield dut.pads.rwds.oe))
|
||||||
self.assertEqual(c2bool(rwds_o[i]), (yield dut.pads.rwds.o))
|
self.assertEqual(c2bool(rwds_o[i]), (yield dut.pads.rwds.o))
|
||||||
yield
|
yield
|
||||||
|
@ -73,7 +74,8 @@ class TestHyperBus(unittest.TestCase):
|
||||||
self.assertEqual(c2bool(clk[i]), (yield dut.pads.clk))
|
self.assertEqual(c2bool(clk[i]), (yield dut.pads.clk))
|
||||||
self.assertEqual(c2bool(cs_n[i]), (yield dut.pads.cs_n))
|
self.assertEqual(c2bool(cs_n[i]), (yield dut.pads.cs_n))
|
||||||
self.assertEqual(c2bool(dq_oe[i]), (yield dut.pads.dq.oe))
|
self.assertEqual(c2bool(dq_oe[i]), (yield dut.pads.dq.oe))
|
||||||
self.assertEqual(int(dq_o[2*(i//2):2*(i//2)+2], 16), (yield dut.pads.dq.o))
|
if (yield dut.pads.dq.oe):
|
||||||
|
self.assertEqual(int(dq_o[2*(i//2):2*(i//2)+2], 16), (yield dut.pads.dq.o))
|
||||||
self.assertEqual(c2bool(rwds_oe[i]), (yield dut.pads.rwds.oe))
|
self.assertEqual(c2bool(rwds_oe[i]), (yield dut.pads.rwds.oe))
|
||||||
self.assertEqual(c2bool(rwds_o[i]), (yield dut.pads.rwds.o))
|
self.assertEqual(c2bool(rwds_o[i]), (yield dut.pads.rwds.o))
|
||||||
yield
|
yield
|
||||||
|
@ -97,7 +99,8 @@ class TestHyperBus(unittest.TestCase):
|
||||||
self.assertEqual(c2bool(clk[i]), (yield dut.pads.clk))
|
self.assertEqual(c2bool(clk[i]), (yield dut.pads.clk))
|
||||||
self.assertEqual(c2bool(cs_n[i]), (yield dut.pads.cs_n))
|
self.assertEqual(c2bool(cs_n[i]), (yield dut.pads.cs_n))
|
||||||
self.assertEqual(c2bool(dq_oe[i]), (yield dut.pads.dq.oe))
|
self.assertEqual(c2bool(dq_oe[i]), (yield dut.pads.dq.oe))
|
||||||
self.assertEqual(int(dq_o[2*(i//2):2*(i//2)+2], 16), (yield dut.pads.dq.o))
|
if (yield dut.pads.dq.oe):
|
||||||
|
self.assertEqual(int(dq_o[2*(i//2):2*(i//2)+2], 16), (yield dut.pads.dq.o))
|
||||||
self.assertEqual(c2bool(rwds_oe[i]), (yield dut.pads.rwds.oe))
|
self.assertEqual(c2bool(rwds_oe[i]), (yield dut.pads.rwds.oe))
|
||||||
self.assertEqual(c2bool(rwds_o[i]), (yield dut.pads.rwds.o))
|
self.assertEqual(c2bool(rwds_o[i]), (yield dut.pads.rwds.o))
|
||||||
yield
|
yield
|
||||||
|
@ -121,7 +124,8 @@ class TestHyperBus(unittest.TestCase):
|
||||||
self.assertEqual(c2bool(clk[i]), (yield dut.pads.clk))
|
self.assertEqual(c2bool(clk[i]), (yield dut.pads.clk))
|
||||||
self.assertEqual(c2bool(cs_n[i]), (yield dut.pads.cs_n))
|
self.assertEqual(c2bool(cs_n[i]), (yield dut.pads.cs_n))
|
||||||
self.assertEqual(c2bool(dq_oe[i]), (yield dut.pads.dq.oe))
|
self.assertEqual(c2bool(dq_oe[i]), (yield dut.pads.dq.oe))
|
||||||
self.assertEqual(int(dq_o[2*(i//2):2*(i//2)+2], 16), (yield dut.pads.dq.o))
|
if (yield dut.pads.dq.oe):
|
||||||
|
self.assertEqual(int(dq_o[2*(i//2):2*(i//2)+2], 16), (yield dut.pads.dq.o))
|
||||||
self.assertEqual(c2bool(rwds_oe[i]), (yield dut.pads.rwds.oe))
|
self.assertEqual(c2bool(rwds_oe[i]), (yield dut.pads.rwds.oe))
|
||||||
self.assertEqual(c2bool(rwds_o[i]), (yield dut.pads.rwds.o))
|
self.assertEqual(c2bool(rwds_o[i]), (yield dut.pads.rwds.o))
|
||||||
yield
|
yield
|
||||||
|
@ -148,7 +152,8 @@ class TestHyperBus(unittest.TestCase):
|
||||||
self.assertEqual(c2bool(clk[i]), (yield dut.pads.clk))
|
self.assertEqual(c2bool(clk[i]), (yield dut.pads.clk))
|
||||||
self.assertEqual(c2bool(cs_n[i]), (yield dut.pads.cs_n))
|
self.assertEqual(c2bool(cs_n[i]), (yield dut.pads.cs_n))
|
||||||
self.assertEqual(c2bool(dq_oe[i]), (yield dut.pads.dq.oe))
|
self.assertEqual(c2bool(dq_oe[i]), (yield dut.pads.dq.oe))
|
||||||
self.assertEqual(int(dq_o[2*(i//2):2*(i//2)+2], 16), (yield dut.pads.dq.o))
|
if (yield dut.pads.dq.oe):
|
||||||
|
self.assertEqual(int(dq_o[2*(i//2):2*(i//2)+2], 16), (yield dut.pads.dq.o))
|
||||||
self.assertEqual(c2bool(rwds_oe[i]), (yield dut.pads.rwds.oe))
|
self.assertEqual(c2bool(rwds_oe[i]), (yield dut.pads.rwds.oe))
|
||||||
yield
|
yield
|
||||||
|
|
||||||
|
@ -174,7 +179,8 @@ class TestHyperBus(unittest.TestCase):
|
||||||
self.assertEqual(c2bool(clk[i]), (yield dut.pads.clk))
|
self.assertEqual(c2bool(clk[i]), (yield dut.pads.clk))
|
||||||
self.assertEqual(c2bool(cs_n[i]), (yield dut.pads.cs_n))
|
self.assertEqual(c2bool(cs_n[i]), (yield dut.pads.cs_n))
|
||||||
self.assertEqual(c2bool(dq_oe[i]), (yield dut.pads.dq.oe))
|
self.assertEqual(c2bool(dq_oe[i]), (yield dut.pads.dq.oe))
|
||||||
self.assertEqual(int(dq_o[2*(i//2):2*(i//2)+2], 16), (yield dut.pads.dq.o))
|
if (yield dut.pads.dq.oe):
|
||||||
|
self.assertEqual(int(dq_o[2*(i//2):2*(i//2)+2], 16), (yield dut.pads.dq.o))
|
||||||
self.assertEqual(c2bool(rwds_oe[i]), (yield dut.pads.rwds.oe))
|
self.assertEqual(c2bool(rwds_oe[i]), (yield dut.pads.rwds.oe))
|
||||||
yield
|
yield
|
||||||
|
|
||||||
|
@ -200,7 +206,8 @@ class TestHyperBus(unittest.TestCase):
|
||||||
self.assertEqual(c2bool(clk[i]), (yield dut.pads.clk))
|
self.assertEqual(c2bool(clk[i]), (yield dut.pads.clk))
|
||||||
self.assertEqual(c2bool(cs_n[i]), (yield dut.pads.cs_n))
|
self.assertEqual(c2bool(cs_n[i]), (yield dut.pads.cs_n))
|
||||||
self.assertEqual(c2bool(dq_oe[i]), (yield dut.pads.dq.oe))
|
self.assertEqual(c2bool(dq_oe[i]), (yield dut.pads.dq.oe))
|
||||||
self.assertEqual(int(dq_o[2*(i//2):2*(i//2)+2], 16), (yield dut.pads.dq.o))
|
if (yield dut.pads.dq.oe):
|
||||||
|
self.assertEqual(int(dq_o[2*(i//2):2*(i//2)+2], 16), (yield dut.pads.dq.o))
|
||||||
self.assertEqual(c2bool(rwds_oe[i]), (yield dut.pads.rwds.oe))
|
self.assertEqual(c2bool(rwds_oe[i]), (yield dut.pads.rwds.oe))
|
||||||
yield
|
yield
|
||||||
|
|
||||||
|
@ -226,7 +233,8 @@ class TestHyperBus(unittest.TestCase):
|
||||||
self.assertEqual(c2bool(clk[i]), (yield dut.pads.clk))
|
self.assertEqual(c2bool(clk[i]), (yield dut.pads.clk))
|
||||||
self.assertEqual(c2bool(cs_n[i]), (yield dut.pads.cs_n))
|
self.assertEqual(c2bool(cs_n[i]), (yield dut.pads.cs_n))
|
||||||
self.assertEqual(c2bool(dq_oe[i]), (yield dut.pads.dq.oe))
|
self.assertEqual(c2bool(dq_oe[i]), (yield dut.pads.dq.oe))
|
||||||
self.assertEqual(int(dq_o[2*(i//2):2*(i//2)+2], 16), (yield dut.pads.dq.o))
|
if (yield dut.pads.dq.oe):
|
||||||
|
self.assertEqual(int(dq_o[2*(i//2):2*(i//2)+2], 16), (yield dut.pads.dq.o))
|
||||||
self.assertEqual(c2bool(rwds_oe[i]), (yield dut.pads.rwds.oe))
|
self.assertEqual(c2bool(rwds_oe[i]), (yield dut.pads.rwds.oe))
|
||||||
yield
|
yield
|
||||||
|
|
||||||
|
@ -255,7 +263,8 @@ class TestHyperBus(unittest.TestCase):
|
||||||
self.assertEqual(c2bool(clk[i]), (yield dut.pads.clk))
|
self.assertEqual(c2bool(clk[i]), (yield dut.pads.clk))
|
||||||
self.assertEqual(c2bool(cs_n[i]), (yield dut.pads.cs_n))
|
self.assertEqual(c2bool(cs_n[i]), (yield dut.pads.cs_n))
|
||||||
self.assertEqual(c2bool(dq_oe[i]), (yield dut.pads.dq.oe))
|
self.assertEqual(c2bool(dq_oe[i]), (yield dut.pads.dq.oe))
|
||||||
self.assertEqual(int(dq_o[2*(i//2):2*(i//2)+2], 16), (yield dut.pads.dq.o))
|
if (yield dut.pads.dq.oe):
|
||||||
|
self.assertEqual(int(dq_o[2*(i//2):2*(i//2)+2], 16), (yield dut.pads.dq.o))
|
||||||
self.assertEqual(c2bool(rwds_oe[i]), (yield dut.pads.rwds.oe))
|
self.assertEqual(c2bool(rwds_oe[i]), (yield dut.pads.rwds.oe))
|
||||||
self.assertEqual(c2bool(rwds_o[i]), (yield dut.pads.rwds.o))
|
self.assertEqual(c2bool(rwds_o[i]), (yield dut.pads.rwds.o))
|
||||||
yield
|
yield
|
||||||
|
|
Loading…
Reference in New Issue