AMBA4—无聊的Narrow transfers介绍

接口/总线/驱动

1143人已加入

描述

 编 者 按   

    AMBA总线无论FPGA还是ASIC,应该都是比较常用的一组总线协议。对于其中的协议,有一种传输格式叫Narrow Transfers,颇有些“无聊”~

》AxSize     

在AXI4总线里,Aw通道以及Ar通道均存在一个size字段:

AMBA总线

    这里面就有点儿意思了。比如说在FPGA里面常用的512总线位宽场景下,FPGA设计里一般也会直接固定死arsize、awsize为0x6,即每拍传输64Bytes,然而协议里面的设置也允许了axsize可以设置为0x0~0x6中的任一值,即每拍可以传输1、2、4、8、16、32、64中的任一情况。而这种不满位宽输出的场景,即为“Narrow Transfers”。

》传输规则

在AXI4总线中,协议中规定了其传输规则:

Start_Addr:Master发起传输的起始地址。

Data_Bytes:总线数据位宽。

Aligned_Addr:地址对齐的起始地址

Address_N:第N拍的传输地址(1为第一拍)

Wrap_Boundary:Warp传输的相应低位地址

Lower_Byte_Lane:每拍传输的低位地址

Upper_Byte_Lane:每拍传输的高位地址

INT(x):X向下取整

    对于传输,定义:

Start_Addr=AxADDR

Aligned_Addr = INT(Start_Addr / Size)* Size

AMBA总线

AMBA总线

    对于AwSize为2,即4字节时,传输时序为:

AMBA总线

    对于awSize为1时,即2字节,传输时序为:

AMBA总线

 仔细分析上面的这三张图,除了awsize为3的正常传输外,剩下的两个均是narrow transfer。   

 如果你从下往上看,像俄罗斯方块那种从下往上堆叠,在地址不跨越总线位宽地址(8 Byte)的情况下,像俄罗斯方块那种模式,则会有:

AMBA总线

    所以,所谓的narrow transfer,不过是正常的传输给拆分成按照(1<

AMBA总线

      确实有点儿蛮“无聊”的是吧~

》实现考虑     

从逻辑实现的角度来考虑,对于Master实现,当满带宽的数据(总线位宽用满)进来后,我们所需要考虑的是数据需要停留几拍。

而停留几拍数据,所需要考虑的是地址累加什么时候到达Data_Bytes的整数倍(或者数据全部送完)。然后再取下一拍送出即可,同时输出相应的STRB信号进行字节选取。

而对于Slave端实现的角度,我们同样需要根据相应的规则选择停留合并合适的N拍后进行输出,比如写通道,则可以:   

AMBA总线






审核编辑:刘清

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分