soc/core/hyperbus: Avoid combinatorial loop on write bursts (Reported when building with Vivado).
This commit is contained in:
parent
ad2c3fcea7
commit
6e9dffdbf5
litex/soc/cores
|
@ -427,10 +427,13 @@ class HyperRAMCore(LiteXModule):
|
||||||
NextState("REG-READ")
|
NextState("REG-READ")
|
||||||
).Else(
|
).Else(
|
||||||
bus_latch.eq(1),
|
bus_latch.eq(1),
|
||||||
NextValue(burst_r_first, 1),
|
# Bus Write.
|
||||||
If(bus.we,
|
If(bus.we,
|
||||||
|
bus.ack.eq(1),
|
||||||
NextState("DAT-WRITE")
|
NextState("DAT-WRITE")
|
||||||
|
# Bus Read.
|
||||||
).Else(
|
).Else(
|
||||||
|
NextValue(burst_r_first, 1),
|
||||||
NextState("DAT-READ")
|
NextState("DAT-READ")
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
@ -472,7 +475,6 @@ class HyperRAMCore(LiteXModule):
|
||||||
bus_dat_w.eq(bus.dat_w),
|
bus_dat_w.eq(bus.dat_w),
|
||||||
)
|
)
|
||||||
]
|
]
|
||||||
self.comb += If(bus_latch, bus.ack.eq(bus.we))
|
|
||||||
self.comb += burst_w.eq(
|
self.comb += burst_w.eq(
|
||||||
# Notified Incrementing Burst.
|
# Notified Incrementing Burst.
|
||||||
(bus_cti == 0b010) |
|
(bus_cti == 0b010) |
|
||||||
|
@ -488,8 +490,10 @@ class HyperRAMCore(LiteXModule):
|
||||||
source.rwds_oe.eq(1),
|
source.rwds_oe.eq(1),
|
||||||
source.dat_w.eq(1),
|
source.dat_w.eq(1),
|
||||||
If(dat_tx_conv.sink.ready,
|
If(dat_tx_conv.sink.ready,
|
||||||
# Stay in DAT-WRITE while Incrementing Burst ongoing...
|
# Ack while Incrementing Burst ongoing...
|
||||||
If(with_bursting & bus.cyc & bus.stb & burst_w,
|
bus.ack.eq(with_bursting & bus.cyc & bus.stb & burst_w),
|
||||||
|
# If Ack, stay in DAT-WRITE.
|
||||||
|
If(bus.ack,
|
||||||
bus_latch.eq(1),
|
bus_latch.eq(1),
|
||||||
NextState("DAT-WRITE")
|
NextState("DAT-WRITE")
|
||||||
# ..else exit.
|
# ..else exit.
|
||||||
|
|
Loading…
Reference in New Issue