AXI协议相较于UART,SPI,I2C来说,无论是内容还是难度都上了一个层级,放在一篇文章中进行解读未免篇幅过长,因此,有关AXI一些共性的、通用的问题,作者单独以前缀为【AXI】的标题进行小范围的串联,最终再汇总为深入浅出解读AXI协议,与从零开始的Verilog AXI协议设计,此为作者所思所考的推进顺序,单看【AXI】的每一篇,可能很多读者未免感到有些管中窥豹的疑惑,但若等作者更完此专栏再行观看,从头到尾进行阅读,应该就会有有茅塞顿开的收获与领悟。
AXI协议中的乱序操作的本质,实际上是构建在Transaction ID这组信号的理解之上完成的,同时Transaction ID这组信号在AXI3与AXI4中的区别也很大,后文会提及。总而言之,通过加大设计上的实现难度,来支持AXI协议的乱序操作,增大面积的同时提高了操作效率,就是乱序操作的本质。
Transaction通道 | Transaction ID |
---|---|
写地址通路 | AWID |
写数据通路 | WID |
写回复通路 | BID |
读地址通路 | ARID |
读数据通路 | RID |
主设备提供的ID号:AWID,WID,ARID.
从设备提供的ID号:BID,RID.
Transaction通道 | Transaction ID |
---|---|
写地址通路 | AWID |
写回复通路 | BID |
读地址通路 | ARID |
读数据通路 | RID |
主设备提供的ID号:AWID,ARID.
从设备提供的ID号:BID,RID.
在AXI4中,比较AXI3和AXI4中我们可以发现ARM公司取消了写数据通路的ID信号WID,换言之,在AXI4中,设计者不需要考虑write interleaving的情况,什么叫write interleaving呢?
按照AXI3所言,每个transaction的写数据会有一个WID,不同WID的写数据transfer可以间插发送。但同一WID的写数据之间需要保序。
举例如下:假如transaction ID1有a和b两个transfer,写transaction ID2有c和d两个transfer,transaction1和2依次发送。
假如在支持write interleaving的情况下,实际的transfer顺序可以是a c d b / a b c d(在AXI3中不同WID的写数据transfer可以间插发送。但同一WID的写数据之间需要保序)
但是在AXI4中,transfer的顺序不能出现a c d b的这种情况(即取消了WID进而导致的取消了write interleaving的支持所产生的影响)
因为AXI3协议很老了,因此后文中我们默认还是更多侧重AXI4协议讲解AXI的乱序机制和原则
AXI的读顺序涉及到的信号为ARID和RID,ARID来自主设备,RID来自从设备,遵循的原则如下
AXI的读顺序涉及到的信号为AWID和BID,AWID来自主设备,BID来自从设备,遵循的原则如下
对于AXI协议而言,读写通路分离,因此从协议规定的层面上,没有读写传输之间的约束关系,无论ID编号是否相同,读写操作不需要遵循顺序关系,乱序即可。
对于不支持outstanding操作的主设备而言,要么发送读请求,要么发送写请求,必须确保前一个请求完成后才能发送后一个请求,遵循的原则如下
同时对于支持outstanding操作的主设备而言,每一次的读写transaction操作都需要比较地址是否有覆盖,只有当不同的transaction间地址不相同时,才可以在不等待前一个信号完成时发送新的信号。
原因:避免内存冲突的出现,outstanding下,transaction发送后默认是乱序执行的,假如outstanding中同时存在对相同地址的读写行为,先读后写和先写后读,读行为返回的值可能是不相同的,为了避免这种情况,在电路设计时,主设备transaction的发送需要比较是否有可能会造成冲突的地址信号。
当一个主设备连接到互联网络时,互联网络可以额外标记“ARID,AWID,WID(AXI4中WID取消)”。通过这种形式,主设备就不需要知道有哪些ID值被其他主设备使用(即主设备之间不需要沟通ID号的使用问题),互联网络可以独一无二的标记从不同主设备送出的Transaction ID号,从设备同理,RID和BID也可以在互联网络中也可以拥有一些额外的位,以此来确定读数据和写回复信号传输具体传输到哪一个主设备上,因此Transaction ID这个信号在主设备界面的位宽、实际网络中传输的位宽、从设备界面的位宽是有可能不一样的。
协议中并没有规定Transaction ID的位宽是多少,但是推荐情况如下
以上为推荐值,无规定值
通过Transaction ID这组信号,AXI4协议可以完成自身的乱序机制,从AXI3到AXI4的进化中,write interleaving被取消了,大的方向下,AXI遵循着相同ID顺序执行,不同ID乱序执行的原则,同时从主设备-互联网络-从设备的连接中,Transaction ID可能会出现额外的位扩展。在原版的协议中,除了从读写行为的乱序模型分析外,还通过主从设备的角度讲述乱序模型的规定和原则,感兴趣的读者可自行阅读。