首页 > 其他分享 >AXI总线协议小记

AXI总线协议小记

时间:2023-07-17 17:33:42浏览次数:48  
标签:通道 总线 有效 地址 VALID 信号 READY AXI 小记

目录

参考

https://developer.arm.com/documentation/ihi0022/hc

https://www.zhihu.com/column/c_1251094110297509888

对应于文档中高电平的低电平,小记中分别使用1和0指代

介绍

根据文档所说,AXI协议可以做到:

  1. 地址可以在数据之前传输,也就是先传地址,再传数据,emm...
  2. 支持多个未完成的传输(看了这个协议的文档才知道,outstanding还有未完成的意思)
  3. 支持乱序完成传输

接下来看看AXI抽象出来的五个传输通道

通道 信号命名前缀
读地址通道 AR
读数据通道 R
写地址通道 AW
写数据通道 W
写响应通道 B

一图胜千言,文档中用几张图简单描述了上面几个通道所携带的数据以及时序关系:

image-20230715232659913

image-20230715234118897

ok,简单来说就是将一堆信号抽象成五个通道,在主从之间控制传输的行为,每个通道包含各自的信号。

Channel(通道)

五个通道的共同点

都由valid、ready和其他信号组成。其中valid和ready就如同字面意思,分别表示发送方数据是否有效,以及接收方是否准备好接收数据,这两个信号是握手的基础。另外还约定last信号来指示本次数据是否最后一个数据。

各自通道还有他们的不同点

ARC/AWC(读地址通道/写地址通道)

包含地址和控制信号

RC(读数据通道)

包含数据总线、用于指示本次读事务是否完成的读响应信号

WC(写数据通道)

包含数据总线、用于指示数据中有每个字节是否有效的strobe信号(strobe似乎是一个固有名词,大概作用就是指示接收者总线上的数据什么时候是有效的)

BC(写响应通道)

类似读响应信号,用于指示本次写事务是否完成的响应信号。为什么写响应需要单独一条通道是显而易见的,因为读响应信号可以与读数据合并在一次传输,而“写”这个操作本来是不需要响应的,因此单独用一条通道来传递写响应信号。

设备之间的连接

image-20230716183904931

AXI给出了接口的定义。系统拓扑可以是:

  • 共享地址线和数据线
  • 共享地址线和多个数据线
  • 多个地址线和数据线

多数情况下地址带宽比数据带宽小很多,因此可以选择第二种拓扑结构。

Register slice

不知道是什么,暂时不管

信号定义

信号不多且好理解,有的信号用于支持一些可选的特性。可以看一下,有个大致印象

全局信号

时钟信号ACLK和复位信号ARESETn,复位低电平有效。所有信号都是ACLK上升沿同步的

AWC信号

信号名称 信号源 说明
AWID M(Manager) 写事务ID
AWADDR M 写事务起始地址
AWLEN M 写事务中传输次数
AWSIZE M 写事务中一次传输的数据大小
AWBURST M 突发类型
AWLOCK M 原子操作相关
AWCACHE M 内存类型
AWPROT M 访问控制:权限、安全级别等
AWQOS M QoS相关
AWREGION M region指示器
AWUSER M 用户自定义信号
AWVALID M 数据是否有效
AWREADY S(Subordinate) 是否准备好接收数据

WC信号

信号名称 信号源 说明
WID M 写传输ID
WDATA M 写数据
WSTRB M 写strobe,指示数据中哪些字节有效
WLAST M 指示是否写事务中最后一次传输
WUSER M 用户自定义信号
WVALID M 数据是否有效
WREADY S 是否准备好接收数据

BC信号

信号名称 信号源 说明
BID S 写响应ID
BRESP S 写响应
BUSER S 用户自定义信号
BVALID S 数据是否有效
BREADY S 是否准备好接收数据

ARC信号

与AWC信号类似,只是从写操作换成读操作相关,并且信号以AR为前缀

RC信号

信号名称 信号源 说明
RID S 读传输ID
RDATA S 读数据
RREST S 读响应
RLAST S 指示是否读事务的最后一次传输
RUSER S 用户自定义信号
RVALID S 数据是否有效
RREADY S 是否准备好接收数据

一对一接口定义

这个小节介绍一对一主从事务中信号实现的要求和定义

时钟和复位

时钟ALCK

所有输入都是ACLK上升沿有效。

注意,主从接口之间的输入输出信号不能有组合电路

复位ARESETn

ARESETn异步低电平有效,但取消复位是同步的。复位使得:

  • 主机接口置ARVALID、AWVALID、WVALID为0
  • 从机接口置RVALID、BVALID为0
  • 其他信号可以是任意电平

ARVALID、AWVALID、WVALID最早能置1的时刻为:ARESETn置1后的第一个ACLK上升沿

image-20230717135803893

基础读/写事务

握手

当VALID和READY同时为1时才能开始传输数据,利用这点,发送方和接收方可以很方便地控制数据的传输速率。

注意,主从接口之间的输入输出信号不能有组合电路。

下图展示VALID在READY之前有效的一次握手:

image-20230716231528712

文档中还提到:

A source is not permitted to wait until READY is asserted before asserting VALID

我一开始也不理解这句话,以为是VALID必须在READY有效之前就有效,但这样下面的「READY在VALID之前有效的握手」就不成立了。因此结合知乎大佬的文章,应该修正为:发送者不允许主动等待READY有效之后再置VALID有效,而是应该数据一旦有效就应当置VALID为有效

VALID一旦有效,就必须保持到握手完成,即VALID和READY均有效的上升沿。

下图展示READY在VALID之前有效的一次握手:

image-20230716232200610

相应地,文档提到:

A destination is permitted to wait for VALID to be asserted before asserting the corresponding READY

也就是接收者可以等VALID有效之后再令READY有效,并且READY在有效之后,在VALID有效之前即握手完成之前将READY置无效。直观地看,接收者对于设置READY比发送者VALID的自由度更大。

各通道的握手信号及约定

各通道的xVALID和xREADY的共同规则同「握手」小节中的VALID和READY。

AWC

协议推荐AWREADY默认值为1,不推荐默认为0的原因是这样会使得传输需要至少两个周期,第一个周期置AWVALID有效,另一个周期置AWREADY有效。(???)

WC

WREADY的默认值可以是1。当事务中最后一次传输的时候,主机必须置WLAST有效。协议推荐WDATA无效字节置0

BC

BREADY的默认值可以是1

ARC

协议推荐ARREADY默认值为1,理由同AWREADY。

RC

从机只能在响应数据读取时才置RVALID有效。RREADY默认值可以是高电平。当事务中最后一次传输时,从机必须置RLAST有效。协议推荐RDATA无效字节置0

通道之间的关系

AXI协议对于通道之间的关系只作了如下规定:

  • 写事务最后一次传输必须跟着写响应
  • 读地址后必须跟着读数据
  • 握手必须遵循下面的「握手信号间的依赖」规则

对于其他情况,通道间保持独立互不影响。

当主机发起写请求事务,所有写数据的提供不能依赖于该主机其他的事务

握手信号之间的依赖

再次总结VALID和READY的关系如下:

  • VALID不能依赖于READY
  • READY可以依赖VALID

其中第二点有利于设计更高效的通信。

对于不同通道,上述的两个规则有不同的具体表现,并用依赖图表示。在依赖图中:

  • 单箭头:被指的信号不依赖于起始端信号,即可以在箭头起始端信号置有效前或置有效后置有效。
  • 双箭头:被指的信号依赖于箭头起始端信号,即必须在箭头起始端信号置有效后再置有效。

起始端信号这里有点疑惑,起始端信号是依赖于被指信号还是不依赖?其实是起始端信号不能主动等待被指信号的有效而置有效,即起始端信号不能依赖于被指信号,比如读事务依赖中,ARVALID不能依赖于ARREADY,而ARREADY可以依赖于VALID也可以不依赖。

读事务依赖

依赖图如下,可以看到RVALID必须在ARVALID有效之后有效,对应了「通道之间的关系」中的读地址后必须跟着读数据

image-20230717110433754

写事务依赖(AXI3)

依赖图如下,可以看到

image-20230717135944322

由于写数据通道与写地址通道没有依赖关系,因此可以看到WREADY并不依赖于AWVALID。另外手册中图 A3-6 即上图中的注释部分似乎将 BVALID 误写为 WVALID,因为主机置起 WVALID 似乎与本次传输的 WLAST 无关,而且文本中也提到 BVALID 依赖于 WLAST(摘自参考链接)

写事务依赖(AXI4 & AXI5)

这个版本协议的新增内容是,BVALID依赖于AWVAID、AWREADY、WVALID、WREADY,即地址和数据握手都成功的情况下才能响应。这个新增的依赖补充了当只有数据而没提供地址的时候,数据是不会被写入的,因此从机自然也不应该响应。

image-20230717161600844

事务结构

地址结构

AXI是基于突发传输的,也就是主机向从机发送控制信息+起始地址,就可以一次性传输多个数据单元,并且后面的地址都由从机自行给出。

一个突发传输地址不能跨越 4KB 边界,之所以这样规定是为了避免访问两个subordinate(每个subordinate的地址空间是4K/1K对齐的)。

标签:通道,总线,有效,地址,VALID,信号,READY,AXI,小记
From: https://www.cnblogs.com/nosae/p/17560726.html

相关文章

  • 数据结构小记
    线段树区间查询线段树可以维护具有结合律的信息。区间修改区间查询加上修改后应当满足的前提是我们可以维护一个封闭的集合\(\mathcal{S}\),使得任一操作\(o\in\mathcal{S}\),且\(\mathcal{S}\)对于复合封闭,即对任意\(u,v\in\mathcal{S}\),有\(u\circv\in\mathcal{S}\)......
  • react axios跨域解决方案
    跨域问题及其解决方案在Web开发过程中,由于同源策略的限制,浏览器会阻止发送跨域请求,这给前端开发带来了一定的挑战。而在使用React框架进行开发时,我们经常使用Axios库来进行数据通信,因此需要解决Axios跨域问题。本文将为您介绍React中使用Axios解决跨域问题的方案,并提供相应的代码......
  • vue3axios怎么用
    Vue3中使用axios在Vue3中,可以使用axios来进行网络请求。axios是一个基于Promise的HTTP客户端,可以用于浏览器和Node.js,非常便捷和强大。安装axios在开始之前,首先需要安装axios。可以通过npm或者yarn来安装:npminstallaxios引入axios在Vue3中,可以使用import来引入axios:impor......
  • vue3axiosjwt拦截器
    实现Vue3axiosjwt拦截器介绍在Vue3项目中使用axios进行网络请求时,我们经常需要在每次请求中添加JWT令牌(JSONWebToken)以进行身份验证。为了简化这个过程,我们可以使用axios的拦截器来实现自动添加JWT令牌的功能。本文将指导你如何使用Vue3、axios和JWT来实现拦截器。整体流程......
  • vue+axios实现输入框多条件搜索功能
    Vue+Axios实现输入框多条件搜索功能在现代的Web开发中,搜索功能是一个非常重要的特性。用户们希望能够根据自己的需求输入多个条件来筛选出所需要的数据。Vue.js是一个流行的JavaScript框架,可以轻松地实现这样的功能。而Axios是一个基于Promise的HTTP库,可以方便地与后端进行数据......
  • 解决vue axios跨域 Request Method: OPTIONS问题(预检请求)
    解决VueAxios跨域问题(预检请求)一、问题描述在前后端分离开发中,前端通过Vue框架发起Ajax请求时,如果请求的URL与前端所在的域名不一致,就会触发浏览器的跨域机制。其中一种常见的跨域问题是"RequestMethod:OPTIONS",也称为预检请求。在本文中,我们将说明如何解决这个问题。二、......
  • lib64/libstdc++.so.6: version `GLIBCXX_3.4.20' not found (required by /home/liuj
     glibc是GNU发布的libc库,即c运行库。glibc是linux系统中最底层的api,几乎其它任何运行库都会依赖于glibc。glibc除了封装linux操作系统所提供的系统服务外,它本身也提供了许多其它一些必要功能服务的实现。由于glibc囊括了几乎所有的 UNIX 通行的标准,可以想见其内容包罗万象。而......
  • axios详解以及完整封装方法
    """一、axios是什么Axios是一个基于promise网络请求库,作用于node.js和浏览器中。它是isomorphic的(即同一套代码可以运行在浏览器和node.js中)。在服务端它使用原生node.jshttp模块,而在客户端(浏览端)则使用XMLHttpRequests。axios有以下特性:从浏览器创建X......
  • [笔记]组成原理_总线
    总线的概述及特征总线是一组能为多个部件分时共享的公共信息传送线路,分时和共享是总线的两个特点。分时:同一时刻,只允许有一个部件向总线发送信息。共享:总线上可以挂接多个部件,各个部件之间互相交换的信息都可通过这组线路分时共享,多个部件可同时从总线上接收相同的信息。总线......
  • Vue3+Vue-Router+TypeScript+Vite+Element-Plus+Axios+Pinia快速搭建开发框架
    1、环境准备(1)首先你得需要安装node和npm2、环境初始化(1)先随意找个文件夹,初始化vite#安装pnpmnpmi-gpnpm#初始化vitepnpmcreatevite#安装依赖pnpminstall(2)最后我们执行pnpmrundev3、安装插件(1)Eslint校验代码工具安装eslint#安装eslint......