From 6ad14ef6447a5b1f0b2a18e15c638157d5e34659 Mon Sep 17 00:00:00 2001 From: Hans Baier Date: Mon, 22 May 2023 10:03:53 +0700 Subject: [PATCH] AvalonMM/AvalonMM2Wishbone: fix read bursts (readdatavalid one cycle too short) --- litex/soc/interconnect/avalon/avalon_mm.py | 2 ++ litex/soc/interconnect/avalon/avalon_mm_to_wishbone.py | 3 ++- 2 files changed, 4 insertions(+), 1 deletion(-) diff --git a/litex/soc/interconnect/avalon/avalon_mm.py b/litex/soc/interconnect/avalon/avalon_mm.py index 1fef0a9fe..c166da078 100644 --- a/litex/soc/interconnect/avalon/avalon_mm.py +++ b/litex/soc/interconnect/avalon/avalon_mm.py @@ -102,6 +102,8 @@ class AvalonMMInterface(Record): def continue_read_burst(self): yield + while not (yield self.readdatavalid): + yield return (yield self.readdata) def bus_write(self, address, writedata, byteenable=None, chipselect=None): diff --git a/litex/soc/interconnect/avalon/avalon_mm_to_wishbone.py b/litex/soc/interconnect/avalon/avalon_mm_to_wishbone.py index 4bdeaa3fc..0e85f801a 100644 --- a/litex/soc/interconnect/avalon/avalon_mm_to_wishbone.py +++ b/litex/soc/interconnect/avalon/avalon_mm_to_wishbone.py @@ -15,7 +15,7 @@ from litex.soc.interconnect.avalon import AvalonMMInterface # Avalon MM <--> Wishbone Bridge ------------------------------------------------------------------- class AvalonMM2Wishbone(Module): - def __init__(self, data_width=32, avalon_address_width=32, wishbone_address_width=32, wishbone_base_address=0x0, burst_increment=1, avoid_combinatorial_loop=True): + def __init__(self, data_width=32, avalon_address_width=32, wishbone_address_width=32, wishbone_base_address=0x0, burst_increment=1, avoid_combinatorial_loop=False): self.a2w_avl = avl = AvalonMMInterface (data_width=data_width, adr_width=avalon_address_width) self.a2w_wb = wb = wishbone.Interface(data_width=data_width, adr_width=wishbone_address_width, bursting=True) @@ -125,6 +125,7 @@ class AvalonMM2Wishbone(Module): NextValue(burst_count, burst_count - 1) ), If(burst_count == 0, + avl.readdatavalid.eq(int(avoid_combinatorial_loop)), wb.cyc.eq(0), wb.stb.eq(0), NextState("SINGLE"))