From 71be61681763fd54bc01cf1c2abab156b9104428 Mon Sep 17 00:00:00 2001 From: Florent Kermarrec Date: Fri, 9 Nov 2018 10:10:07 +0100 Subject: [PATCH] frontend/axi: be sure wdata is available before sending the command to the controller --- litedram/frontend/axi.py | 12 +++++++----- test/test_axi.py | 5 ++--- 2 files changed, 9 insertions(+), 8 deletions(-) diff --git a/litedram/frontend/axi.py b/litedram/frontend/axi.py index f668402..7605b6d 100644 --- a/litedram/frontend/axi.py +++ b/litedram/frontend/axi.py @@ -165,7 +165,9 @@ class LiteDRAMAXI2NativeW(Module): self.comb += [ id_buffer.sink.valid.eq(aw.valid & aw.ready), id_buffer.sink.id.eq(aw.id), - If(axi.w.valid & axi.w.last & axi.w.ready, + If(w_buffer.source.valid & + w_buffer.source.last & + w_buffer.source.ready, resp_buffer.sink.valid.eq(1), resp_buffer.sink.resp.eq(resp_types["okay"]), resp_buffer.sink.id.eq(id_buffer.source.id), @@ -176,9 +178,9 @@ class LiteDRAMAXI2NativeW(Module): # Command self.comb += [ - self.cmd_request.eq(aw.valid), + self.cmd_request.eq(aw.valid & w_buffer.source.valid), If(self.cmd_grant, - port.cmd.valid.eq(aw.valid), + port.cmd.valid.eq(aw.valid & w_buffer.source.valid), aw.ready.eq(port.cmd.ready), port.cmd.we.eq(1), port.cmd.addr.eq(aw.addr >> ashift) @@ -187,8 +189,8 @@ class LiteDRAMAXI2NativeW(Module): # Write Data self.comb += [ - If(id_buffer.source.valid, axi.w.connect(w_buffer.sink)), - w_buffer.source.connect(port.wdata, omit={"strb"}), + axi.w.connect(w_buffer.sink), + If(id_buffer.source.valid, w_buffer.source.connect(port.wdata, omit={"strb"})), port.wdata.we.eq(w_buffer.source.strb) ] diff --git a/test/test_axi.py b/test/test_axi.py index 3f71fdc..8132bbe 100755 --- a/test/test_axi.py +++ b/test/test_axi.py @@ -31,18 +31,17 @@ class TestAXI(unittest.TestCase): yield axi_port.aw.valid.eq(1) yield axi_port.aw.addr.eq(write.addr<<2) yield axi_port.aw.id.eq(write.id) - yield while (yield axi_port.aw.ready) == 0: yield - yield axi_port.aw.valid.eq(0) yield + yield axi_port.aw.valid.eq(0) # send data yield axi_port.w.valid.eq(1) yield axi_port.w.last.eq(1) yield axi_port.w.data.eq(write.data) - yield while (yield axi_port.w.ready) == 0: yield + yield yield axi_port.w.valid.eq(0) def writes_response_generator(axi_port, writes):