soc/core/hyperbus: Avoid combinatorial loop on write bursts (Reported when building with Vivado).

This commit is contained in:
Florent Kermarrec 2024-09-19 11:10:51 +02:00
parent ad2c3fcea7
commit 6e9dffdbf5
1 changed files with 8 additions and 4 deletions
litex/soc/cores

View File

@ -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.