Author Topic: AXI arvalid signal  (Read 960 times)

0 Members and 1 Guest are viewing this topic.

Offline promachTopic starter

  • Frequent Contributor
  • **
  • Posts: 877
  • Country: us
AXI arvalid signal
« on: February 05, 2020, 03:21:57 am »
I have question about AXI arvalid signal used for interfacing with DDR axi controller in Zynq.

if I do not remove i_axi_arready , I will have deadlock issue.
If I remove i_axi_arready , I will have issue arising from DDR periodic mechanism such as auto-refresh.

What could I do ?

Someone told me the following which I do not understand:

VALID signal needs to be set (initially) independent of READY signal, and then only ever adjusted if !(VALID && !READY)

Code: [Select]
always @(posedge clk)
begin   
    if(reset) o_axi_arvalid <= 0;

    // AXI specification: A3.3.1 Dependencies between channel handshake signal
    // the VALID signal of the AXI interface sending information must not be dependent on
    // the READY signal of the AXI interface receiving that information
    // this is to prevent deadlock
    // since AXI slave could waits for i_axi_arvalid to be true before setting o_axi_arready true.
    // Note: VALID cannot be dependent upon READY, but READY can be dependent upon VALID
    //       VALID signal needs to be set (initially) independent of READY signal,
    //       and then only ever adjusted if !(VALID && !READY)
    else o_axi_arvalid <= /*i_axi_arready &&*/ (!cache_is_full);
end
« Last Edit: February 05, 2020, 07:21:22 am by promach »
 

Offline promachTopic starter

  • Frequent Contributor
  • **
  • Posts: 877
  • Country: us
Re: AXI arvalid signal
« Reply #1 on: February 24, 2020, 03:08:40 am »
Which waveform follows AXI spec ?



 

Online langwadt

  • Super Contributor
  • ***
  • Posts: 4650
  • Country: dk
Re: AXI arvalid signal
« Reply #2 on: February 25, 2020, 12:05:46 am »
what deadlock issues?
 

Offline promachTopic starter

  • Frequent Contributor
  • **
  • Posts: 877
  • Country: us
Re: AXI arvalid signal
« Reply #3 on: February 25, 2020, 03:02:53 am »
Code: [Select]
else o_axi_arvalid <= /*i_axi_arready &&*/ (ddr_address_range_is_valid) && o_axi_rready;
The deadlock issue had been solved. Please correct me if wrong.


But why my AXI coding still fail AXI Protocol Checker IP for error bits 59 and 78

And just for information, AXI Protocol Checker IP raised the errors for both AXI interfaces even when RREADY and ARREADY signals are asserted high (free-flow AXI bus without any barriers)
In other words, the AXI code is not AXI-compliant in the simplest test scenario.

« Last Edit: February 28, 2020, 09:45:10 am by promach »
 


Share me

Digg  Facebook  SlashDot  Delicious  Technorati  Twitter  Google  Yahoo
Smf