读和写地址通道是独立的,地址通道用于传输地址和控制信号,AXI协议支持以下机制
读数据通道传输读来的数据以及来自从机的回应信号
写通道数据只是传输写入到从机的信号
写操作回应信号产生在每个burst完成之后,其中一个数据传输完成之后并不会产生此信号。
每个通道,包括地址和控制通道,数据通道,以及写操作反馈通道,均会有VALID,READY信号进行握手,确保传输准确!!!
AXI协议为接口提供单独的接口定义,分别是主机和互联线之间,从机和互连线之间,主从机之间。大多数的系统使用以下三种之一的互连线方式,
每个AXI通道只在一个方向传输信息,各个通道之间不需要固定的关系。 这很重要,因为它可以在任何通道中插入寄存器片,但代价是额外的延迟周期。 这使得在延迟周期和最大操作频率之间进行权衡成为可能。
还可以在给定互连内的几乎任何点使用寄存器片。 在处理器和高性能存储器之间使用直接、快速的连接可能是有利的,但使用简单的寄存器片将更长的路径隔离到对性能不太重要的外围设备。
关于寄存器片的内容可参考:Register Slices.
本部分介绍了按照基本AXI协议传输的例子,显示了VALID和READY信号的握手过程。传输发生在VALID和READY信号均为高电平的时候,主要有以下三个例子,分别是Read burst, Overlapping read burst, Write burst。
所谓的Overlapping read burst也就是两个或者多个read burst连在一起进行传输
整个过程主要包含以下几个步骤
AXI支持乱序操作,有助于提高效率
对于主机要求按顺序返回的,即按顺序返回,对于主机没有要求按顺序返回的,可以乱序返回
如果是一个多主机,多从机的系统,可以在ID Tag后加入特殊的信息以区分来自不同的主机。同时一个主机的可以通过扩展主机编号的方式得到多个虚拟主机
ACLK 来自时钟源,全局时钟信号,所有信号进行时钟的上升沿采样
ARESETn 来自复位源,全局复位信号,低电平有效,也就是低电平复位
以下Ax表示AW或者AR
AxID[3:0] 来自主机,写地址的ID
AxADDR[31:0] 来自主机,表示写操作的起始地址,剩余额控制信号决定其他数据的地址
AxLEN[3:0] 来自主机,表示burst的数据数量1-16,和地址相关,对于wrapping bursts来说,此数量必须是偶数,也就是2,4,6。。。16.在burst传输过程,不会被任何部分所打断,即使在写burst中,主机可以通过取消置位所有写选通的方法禁止进一步写入,但是也得将burst的剩余部分传输完成,同样,对于读burst,主机可以不要接下来读过来的数据,但是也得将读burst结束。
(注:此处的transfer类似于AHB中定义的beat。burst大小不能超过4K的地址边界,因为最小的外部设备内存定义为4K。上面的burst长度为AXI3中定义,AXI4中增加了burst的长度,最大可达256个transfer,但是大于16个transfer的burst只支持INCR burst type)
AWSIZE[3:0] 来自主机,表示burst中最大位数的那个transfer的大小,范围是1-128,因为是按照字节大小来的,所以对应于8,16,24…1024 bits
(注:此处的大小和总线宽度有关,需要保证transfer size<=data width)
AWBURST[1:0] 来自主机,表示burst传输的类型,分别是Fixed burst, Incrementing burst, Wrapping burst.结合AWSIZE信号,可以计算出写的每个数据的地址
(注:其中Fixed burst表示每次都是从固定地址读取或者写入,例如外围FIFO
Incrementing burst表示在burst中的每一拍地址都是增加的,增加的地址大小取决于size的大小,比如一个burst中size为4,那么每次地址都是增加4
Wrapping burst类似于Incrementing burst,每次传输的地址都是前一个传输地址的增量。 然而,在Wrapping burst中,当到达Wrapping边界时,地址会Wrapping到较低地址。
Wrapping burst的边界是猝发传输中每个传输的大小乘以猝发传输中的传输总数。
Wrapping burst有两个限制条件
• 起始地址必须与传输的大小对齐
• 突发的长度必须是 2、4、8 或 16。)
AWLOCK[1:0] 来自主机,表示操作中的访问类型,分为Normal access, Exclusive access, Locked access。
(注:以上为AXI3定义, AXI4中因为去掉了Locked access,所以 AWLOCK[1:0] 信号改成了AWLOCK,从2bit变成了1bit,也就是access分成了Normal access和Exclusive access两种)
AxPROT[2:0] 来自主机,保护类型,此信号为防止非法访问提供三个等级的保护
AxCACHE[3:0] cache的类型
AxVALID 主机发出的,表示地址和控制信息是否可获取,并且会在AWREADY信号拉高之前一直保持稳定,1表示可获取,0表示不可获取
AxREADY 从机发出的,表示写操作的地址准备好接收到,也就是表示从机已经准备好接收来自主机的地址和控制信号了,1表示准备好了,0表示还没准备好
WID[3:0] 主机发出的,写操作的ID标签,在写操作的时候,WID必须和AWID的值相匹配
(注:此信号为AXI3中定义,AXI4中已将此信号去掉,意味着AXI不支持写out-of-order以及interleaving)
WDATA[31:0] 主机发出的,需要写入到从机的数据,可以是8,16…1024位宽
WSTRB[3:0] 主机发出的,写选通信号,此信号表明选通哪个字节通道
WLAST 主机发出的,写数据最后一个beat的标志位
WVALID 主机发出的,写操作的有效位,表示要写入的数据已经准备好了,1表示数据和选通都好了,0表示数据和选通没有准备好
WREADY 从机发出的,写操作中从机的READY信号,表示准备好接收数据了。1表示从机准备好了,0表示没准备好
BID[3:0] 从机发出的,表示返回到主机的ID标签,此标签必须和主机地址通道发出的AWID信号相匹配
BRESP[1:0] 从机发出的表示写操作的反馈,分别有OKAY,EXOKAY,SLVERR,DECERR.
BVALID 从机发出的,表示写操作反馈此时是否可获得,1表示可获得,0表示没有不可获得
BREADY 主机发出的,表示此时是否准备好接收来自从机的反馈信号,1表示准备好了,0表示还没准备好。
RID[3:0] 从机发出的,表示读取的地址ID,此ID要和主机发出的ID想匹配
RDATA[31:0] 从机发出的,表示此时读取的数据
RRESP[1:0] 从机发出的,表示对读取操作的反馈,分别由OKAY,EXOKAY,SLVERR,DECERR四种反馈信号
RLAST 从机发出的,标识读取burst中数据的最后一个Transfer
RVALID 从机发出的,表示此时主机要读取的数据是否准备好了,1表示准备好了,0表示还没准备好
RREADY 主机发出的,表示主机是否准备好接收来自从机的数据了,1表示准备好了,0表示还没准备好。
CSYSREQ 来自时钟控制器,系统时钟给出此信号让外设进入低功耗状态
CSYSACK 来自外设,对系统时钟要求外设进入低功耗状态的回应
CACTIVE 来自外设,表示外设是否要求时钟信号,1表示要求,0表示没要求。
上图为外设接受系统要求,进入低功耗状态并退出的时序图。其中T1时刻,系统时钟要求外设进入低功耗状态,T2时刻,外设响应要求,拉低CACTIVE信号,进入低功耗,并在T3拉低CSYSACK完成进入低功耗的步骤。T4时刻系统拉高CSYSREQ信号,要求外设退出低功耗状态,外设接受请求并在T5时刻拉高CACTIVE信号,接着在T6时刻拉高CSYSACK信号,完成握手流程,完全退出低功耗状态。
上图为外设拒绝接受系统要求,没有进入低功耗状态的时序图。其中T1时刻,系统时钟要求外设进入低功耗状态,T2时刻,外设没有响应要求并保持CACTIVE信号为高,但是还是在T2时刻,拉低了CSYSACK信号进行握手。T3时刻系统拉高CSYSREQ信号,外设在T4拉高CSYSACK信号完成握手流程。
所有的五个通道均使用相同的VALID/READY握手来传输数据和控制信息。VALID信号表示何时数据可以被获得,READY信号表示何时准备好接收数据或者控制信号。只有在两个都是HIGH的情况下,才会发生传输,如下图,整个过程中,首先地址和控制信号准备好后,主机会将VALID信号拉高,并一直保持到从机发出的READY信号拉高,并在两个都是高电平的那个时钟上升沿进行数据的传输。
地址、读、写和写响应通道之间的关系是灵活的。 例如,写入数据可以出现在与其相关的写入地址之前的接口处。 当写地址通道包含比写数据通道更多的寄存器级时,就会发生这种情况。 写数据也可能出现在与地址相同的周期中。
当互连必须确定目标地址空间或从属空间时,它必须重新对齐地址并写入数据。 这需要确保写入数据仅向其指定的从机发送有效信号。
必须保持的两个关系是:
比较重要的两个关系来预防死锁情况发生,第一个AXI中一个组件的VALID信号必须不能依赖于此次传输的其他组件的READY信号。第二个是READY信号可以等待VALID信号的置位发生
其基本的依赖关系如下图所示(单箭头表示被指向的那个信号可以先断言,双箭头表示被指向的那个信号必须等到前面那个信号断言之后才能断言)
从机可以在等待ARVALID信号被置位之前就一直将AREADY信号置位
从机可以将AWREADY 或 WREADY在AWVALID或WVALID被主机置位之前置位
在置位 AWREADY 之前,从设备可以等待 AWVALID 或 WVALID,或两者兼而有之
在置位 WREADY 之前,从设备可以等待 AWVALID 或 WVALID,或两者兼而有之
从设备必须等待 WVALID 和 WREADY 都被置位之后再置位BVALID,也就是说BVALID拉高之前,WVALID 和 WREADY都已在传输中拉高过。
(注:以上为AXI3中定义的依赖关系,AXI4中新增加了部分依赖关系,如下图所示,也就是说BVALID必须等待AWVALID和AWREADY都被置位之后再置位,含义是从机在地址和控制信号传输完成之前不能进行响应)
上图为AXI3中定义的AxCACHE各个bit所对应的含义,表明此数据是否可以buffer或者cache,以及是否被allocate,此部分涉及到cache的知识
独占访问机制能够实现信号量类型的操作,而无需在操作期间将总线保持锁定到特定的主机。 独占访问的优点是信号量类型的操作不会影响关键的总线访问延迟或最大可实现的带宽。 ARLOCK[1:0] 或 AWLOCK[1:0] 信号选择独占访问,RRESP[1:0] 或 BRESP[1:0] 信号表示成功 或独占访问失败。 从机必须有额外的逻辑来支持独占访问。 AXI 协议提供了一种故障安全机制,以指示主设备何时尝试对不支持它的从设备进行独占访问。
以下为主要步骤
此访问指的是此transfer被锁定,在完成之前,任何其他主机都不可访问此地址,这会限制系统的性能
(注: AXI4中已去掉了此操作)
写数据总线的每8位有一个写选通,所以WSTRB[n]对应WDATA[(8×n)+7:(8×n)]。 图 9-1 显示了 64 位数据总线上的这种关系。
当主机产生比其数据总线窄的传输时,地址和控制信息决定传输使用哪些字节通道。 在递增或包装突发时,不同的字节通道在突发的每个节拍上传输数据。 在固定突发中,地址保持不变,可以使用的字节通道也保持不变。
字节不变的字节序意味着到给定地址的字节传输将相同数据总线上的八位数据传递到相同的地址位置
下图是一个需要字节不变访问的数据结构示例。 标头信息(例如源和目标标识符)可能采用小端格式,但有效负载是大端字节流。
关于big endian and little endian
对于整型、长整型等数据类型,Big endian 认为第一个字节是最高位字节(按照从低地址到高地址的顺序存放数据的高位字节到低位字节);而 Little endian 则相反,它认为第一个字节是最低位字节(按照从低地址到高地址的顺序存放据的低位字节到高位字节
AXI 总线支持非对齐的传输,当传输位宽超过1byte,起始地址不为数据总线硬件带宽(byte单位)整数倍时,为不对齐传输。不对齐传输的时候需要配合数据选通在第一次传输时将某几个byte置为无效,使第二次突发传输的起始地址(从机自动计算)为突发尺寸的整数倍。
在AXI4中增加了QOS信号
AWQOS 4-bit 在写地址通道上为每个写事务发送的 QoS 标识符
ARQOS 4-bit 在读地址通道上为每个读事务发送的 QoS 标识符.
此信号表示读(写)操作中哪个传输具有更高的优先级,数字越大,表示更高的优先级
每个 AXI 组件使用单个时钟信号 ACLK。 所有输入信号都在 ACLK 的上升沿采样。 所有输出信号的变化都必须发生在 ACLK 的上升沿之后。
主接口和从接口上的输入和输出信号之间不得有组合路径。
异步复位,同步释放
在复位期间,以下接口要求适用: