Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

axi_to_mem: Comb path from b_ready to w_ready #287

Open
niwis opened this issue Mar 13, 2023 · 2 comments
Open

axi_to_mem: Comb path from b_ready to w_ready #287

niwis opened this issue Mar 13, 2023 · 2 comments
Labels
bug Something isn't working

Comments

@niwis
Copy link
Contributor

niwis commented Mar 13, 2023

There is a combinational path in axi_to_mem from axi_req_i.b_ready to axi_resp_o.w_ready. In particular, this is can be dangerous when connecting this module downstream of axi_dw_downsize, which has a comb path from w_ready to b_ready, resulting in a combinational loop.

@niwis niwis added the bug Something isn't working label Mar 13, 2023
@christian-lanius
Copy link

christian-lanius commented May 31, 2023

Is there a workaround to this issue?
I have something along the lines:
AXI_UPSIZE -> AXI_MUX -> AXI_TO_MEM -> SRAM
and observe the combinational loop. I have tried to insert a AXI_CUT block after the AXI_MUX block, but this does not help.
I have parameterized the block with
NumBanks=1
BufDepth=1 (SRAM has latency of 1 cycle)
HideStrb=1
OutFifoDepth=1

Does any of the other axi_to_mem blocks (interleaved, split etc) not exhibit this problem?

@xXIty
Copy link

xXIty commented Jul 11, 2024

Same here... I think the trick is to register both sides of the module. For instance, place an axi_cut in one side and ensure the mem side is not answered combinationally.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
None yet
Development

No branches or pull requests

3 participants