1 AXI4 总线协议
AXI4,全称第四代高级可扩展接口(Advanced eXtensible Interface 4),是一种高性能、高带宽、低延迟的片上总线协议,可用于处理器与内存之间传递数据。
动态随机存储器(Dynamic Random Access Memory,DRAM)是内存的主要组成部分。由于其访问速度较慢,它并不能随时随地接收访问请求,送出数据的时机也不可预知。因此,为了保障数据传输的可靠性,需要做到以下五点:
确保读地址被存储器正确接收; 确保读数据能被处理器正确接收; 确保写地址被存储器正确接收; 确保写数据被存储器正确接收; 确保处理器能够得知写操作完成。AXI4 总线协议正是对以上五点进行了规定。在一次读写请求中,AXI4 总线通过处理器和存储器之间的多次握手,保障了上述信号的正确传输,从而保障了数据传输的可靠性。
在本文档中,我们只会针对实验中涉及的信号进行解读,其他信号的解读请参考 AXI4 总线协议规范。
2 AXI4 总线特性
AXI4 总线具有以下特点:
高性能:AXI4 总线支持乱序传输,可以同时进行多个读写操作,从而提高了总线的利用率; 高带宽:AXI4 总线支持突发传输,可以在一次请求中传输多个数据,从而提高了总线的带宽; 高并行:AXI4 总线提供多个通道,可以实现读写的并行传输,从而提高了总线的并行度; 非对齐:AXI4 总线可以支持地址非对齐的传输。3 AXI4 总线时序
3.1 握手
在 AXI4 总线协议中,读写请求的握手使用了基本的 valid-ready 握手信号。
在一次握手事务中,存在一个主方和一个从方。主方会主动地发送 valid 信号,并期待从方发送一个 ready 信号。而从方的 ready 信号可能不依赖与主方的 valid 信号,也可能依赖。对于“握手成功”的概念,在主方和从方的视角下,有不同的定义:
主方:自己发送了 valid 且收到了从方发出的 ready,即为“握手成功”; 从方:自己发送了 ready 且收到了主方发出的 valid,即为“握手成功”。总线的“握手成功”,是主方和从方同时握手成功,只有一方视角的“握手成功”现象是不合法的。
握手并不是仅仅为了“看到某个信号”,握手通常是为了可靠地传递其他信息的。例如,当主方发送 valid 的时候,可能会同时将一些数据通过另一个信号发送给从方;而从方收到 valid 信号时,可能会先保存住主方发送的这个数据,然后再发送 ready 信号。这样,主方就可以通过 ready 信号来判断从方是否已经接收了数据。
3.2 读事务时序
AXI4 总线的读事务时序如下图所示:

AXI4 协议规定的一次读事务,需要一次地址握手和若干次数据握手,具体解读如下:
读地址握手:这是一次读事务的开端。处理器会向存储器发送本次读请求的地址,同时发送一个 arvalid 信号。同时,处理器还会发送本次读请求的一些配置信号,一些重要配置如下:
arsize:本次读请求单个返回数据的宽度的对数,宽度以字节为单位。如果 arsize 为 n当存储器看到了处理器发送的 arvalid 信号后,会发送一个 arready 信号,表示已经接收到了处理器发送的地址和配置信号。至此,读地址握手完成,从下个周期开始,存储器将不定期地用 arburst 指定的模式发送由 arsize 和 arlen 规定的数据。
读数据握手:这是一次读事务的主体。存储器将会不定期地发送读取的数据,并同时发送一个 rvalid 信号,告知处理器本次发送的读数据是有效的。处理器得到数据和 rvalid 信号后,应当锁存住这个数据,并发送一个 rready 信号作为回应。一旦存储器看到了 rready 信号,就可以继续发送下一个数据了。
当存储器发送最后一个数据时,将会同时发送一个 rlast 信号,表示这是本次读事务的最后一个数据。处理器完成最后这个数据的读握手后,就可以认为本次读事务已经完成了。
3.3 写事务时序
AXI4 总线的写事务时序如下图所示:

AXI4 协议规定的一次写事务,需要一次地址握手、若干次数据握手和一次写回确认握手,具体解读如下:
写地址握手:这是一次写事务的开端。处理器会向存储器发送本次写请求的地址,同时发送一个 awvalid 信号。同时,处理器还会发送本次写请求的一些配置信号,一些重要配置如下:
awsize:本次写请求单个写入数据的宽度的对数,单位为字节。如果 awsize 为 n当存储器看到了处理器发送的 awvalid 信号后,会发送一个 awready信号,表示已经接收到了处理器发送的地址和配置信号。此时,写地址握手完成,从下个周期开始,存储器将不定期地用 awburst 模式接收由 awsize 和 awlen 规定的数据。
写数据握手:这是一次写事务的主体。处理器将发送 wvalid 信号,以告知存储器当前周期发送的数据是有效的,需要被写入。当存储器接收到这个数据后,将会应答一个 wready 信号,表示已经接收到了这个数据。处理器看到了 wready 信号后,就可以继续发送下一个数据了。
在每次发送写数据的时候,处理器还需要发送一个 wstrb 信号作为写数据的掩码。信号掩码的定义我们将在下文进行讲述。
当处理器发送最后一个数据时,还需要额外发送一个 wlast 信号,表示这是本次写事务的最后一个数据。存储器接收到了 wlast 信号,且本次写入数据握手完成后,就认为本次写事务已经完成了,将进入写回确认阶段。
写回确认握手:这是一次写事务的结尾。存储器将会发送 bvalid 信号,表示本次写事务已经完成。处理器接收到 bvalid 信号后,应当发送 bready 信号,表示已经接收到了存储器的写回确认。当存储器收到 bready 信号后,就可以认为本次写事务已经完成了。
4 AXI4 总线信号解读
信号约定 AXI4 总线能够支持的单次最大传输位宽可以为 32、64、128 位,而最常用的一般是 32 位。在我们的实验中,我们将地址和数据位宽约定为 32 位; 表格中的“信号方向”是针对存储器而言的,即存储器的输入信号和输出信号。因此,CPU 的输出信号对应的是输入信号,而输入信号对应的是输出信号。4.1 读地址信号(以 ar 开头)
信号名 信号方向 信号位宽 信号描述 araddr 输入 32 读地址,表示本次读事务的起始地址 arvalid 输入 1 读地址有效,表示本次读事务的读地址和配置信号已经发送完毕,存储器可以开始读取数据 arready 输出 1 读地址就绪,表示存储器已经接收到了本次读事务的读地址和配置信号 arsize 输入 3 读数据宽度,表示本次读事务单个返回数据的宽度的对数,单位为字节 arlen 输入 8 读数据个数,表示本次读事务需要连续读取的数据个数 - 1 arburst 输入 2 读数据模式,表示本次读事务的突发模式以上的信号都是在读地址握手阶段使用的信号,用于传递读地址和配置信息。
其中,arburst 信号的三种突发模式的含义如下:
固定地址(0b00):存储器将会连续返回若干个请求地址的数据,每个数据的地址都是相同的。 递增地址(0b01):存储器将会连续返回若干个递增的地址的数据,每个数据的地址都是上一个数据地址加上数据宽度。例如:若 arsize 为 2、arlen 为 3,那么存储器将会连续返回 4 个地址的数据,地址分别为 araddr, araddr+4, araddr+8, araddr+12。 回绕地址(0b10):存储器将会连续返回若干个递增的地址的数据,每个数据的地址都是上一个数据地址加上数据宽度。当地址达到一定边界后,将会从初始地址的 (arlen+1)×2arsize在本课程实验框架中,我们都采用递增地址的模式进行读写操作。
事实上,回绕地址的访问方式是为了配合 Cache “关键字优先”的技术,但如此一来会增加 Cache 的设计复杂度,不利于大家理解代码。
4.2 读数据信号(以 r 开头)
信号名 信号方向 信号位宽 信号描述 rdata 输出 32 读数据,表示存储器返回的数据 rvalid 输出 1 读数据有效,表示存储器返回的数据和配置信号已经发送完毕,处理器可以开始读取数据 rready 输入 1 读数据就绪,表示处理器已经接收到了存储器发送的读数据和配置信号 rlast 输出 1 读数据结束,表示存储器返回的数据是本次读事务的最后一个数据 rresp 输出 2 读响应,表示存储器返回的数据的状态,包括正常(0b00)、错误(0b01)、保留(0b10)、未知(0b11)4.3 写地址信号(以 aw 开头)
信号名 信号方向 信号位宽 信号描述 awaddr 输入 32 写地址,表示本次写事务的起始地址 awvalid 输入 1 写地址有效,表示本次写事务的写地址和配置信号已经发送完毕,存储器可以开始写入数据 awready 输出 1 写地址就绪,表示存储器已经接收到了本次写事务的写地址和配置信号 awsize 输入 3 写数据宽度,表示本次写事务单个写入数据的宽度的对数,单位为字节 awlen 输入 8 写数据个数,表示本次写事务需要连续写入的数据个数 - 1 awburst 输入 2 写数据模式,表示本次写事务的突发模式其中,awburst 的三种突发模式的含义与 arburst 相同,不再赘述。
4.4 写数据信号(以 w 开头)
信号名 信号方向 信号位宽 信号描述 wdata 输入 32 写数据,表示本次写事务需要写入的数据 wvalid 输入 1 写数据有效,表示本次写事务的写数据已经发送完毕,存储器可以写入该数据 wready 输出 1 写数据就绪,表示存储器已经接收到了本次写事务的写数据 wstrb 输入 4 写数据掩码,表示本次写事务需要写入的数据的哪些字节是有效的 wlast 输入 1 写数据结束,标识了当前写数据是本次写事务的最后一个数据其中,wstrb 信号的每一位表示了对应字节是否有效,例如,如果 wstrb 为 0b0011,则表示本次发送的写数据的低两个字节是有效的,高两个字节是无效的且不会被写入。
一般来说,wstrb 只有 0b1111(写全字)、0b0011(写低半字)、0b1100(写高半字)、0b0001(写低字节)、0b0010(写次低字节)、0b0100(写次高字节)、0b1000(写高字节)、0b0000(不写)这几种情况,其余情况视为非法。

