AMBA AXI - transaction order记录

AXI协议支持5通道,读写分离的传输策略,在之前看AXI时,有很多基本的策略都会有点困扰,比如,通道依赖,传输顺序,以及交织等等之类的内容。所以觉得有必要搞一下这些知识点,把这些东西梳理和整理一下,也方便查阅,不然时间一长,总要重新翻Spec。

  1. 常规的AXI传输

上面两幅图都是简单的AXI传输,其中一笔完整的传输叫transaction,比如A传输,而组成A传输的各个小的传输成为transfer,比如A*。

图一展示的是当读写通道的transaction分别是不会overlap的传输。

图二展示的当读写通道的transation的请求会在前一个transation没完成之前来到,传输就顺序正常的完成。

这两种都是比较常规的AXI传输,放在这其实有点多余,不想看就可以跳过。

  1. Transfer IDs

Transfer id感觉我更愿意说成transaction ID,因为对于同一笔Transaction ID域的不支持修改的。同时,这种ID的机制引入就让transation有了所谓的乱序执行的机会了。这也就可以提升总线的效率,这是为啥呢?因为当可以乱序的时候,那transation就不用排排坐了呀,后来的准备好的就可以先做了,这样就省了时间,也最大化了使用带宽。

介绍完transfer ID的基础概念,再来看看规则吧:

  1. 所有transfer都需要有一个ID;
  2. 一个transaction的所有transfer需要一样;
  3. Master侧需要可以支持给多个transaction分发不同ID的能力,一个ID的话,当我没说;
  4. Slave侧的话,通常需要支持可配的ID宽度,方便适配Master侧的ID;

OK,絮絮叨叨把ID的基本概念和规则描述了,下来看看transation咋用吧。

    1. 写transaction order规则

Arm给的三条军规:

  1. 军规1:W通道的写数据的顺序需要和AW通道的顺序保持一致;
    这里

    |---|----------------------------------------------------------------------------|
    | |
    | | |

    A的请求比B先来,那写数据也要比B先来。

  2. 军规2:不同ID的transaction的完成顺序没有要求;

这里看A/B的ID不同,transaction的响应就可以乱序回。

  1. Master侧可以对同一个ID有oustanding能力,但是必须顺序的执行和完成<对slave侧的要求哈>。
    1. 读transaction的order规则

ARM一样对于读也提了三个军规。

  1. 军规1:不同ID的读数据在R通道上没有保序要求;也就是slave可以随便回哈
  1. 军规2:不同ID的读数据在R通道上可以interleaved, RID和AR对应可以看出来是谁的请求;
  1. 军规3:对于同一个ID的transaction,R通道上的读数据需要保序。

比如A/C, 这种保序的要求是指整体的transaction保序,不是指transfer的概念;

    1. 读写通道的顺序

Ok,看完了读写行为的分别保序的法则,下来就看看读写通道之间的顺序吧。

简单来说,读写之间没有order关系,如果需要保证读写顺序,这是软件需要在行为上保证的哈。

  1. 非对齐起始地址访问

AXI协议支持起始地址是非对齐的,但是非对齐只影响第一个transfer,之后的传输就是对齐的,在传输上,slave侧不需要关注是不是对齐。

所以什么是非对齐呀?

协议里就是说地址没有和transaction宽度对齐,比如一个32bit data packet传输的起始地址是0x1002而不是32bit边界对齐。

按照上图的说明,如果是32bit对齐的地址的话,最多可以传20Byte,但是因为地址不是对齐的,是0x1,所以只能传19byte,第一笔transfer只能有3byte。

再举个例子吧。

比如要发一个5-beat 16bit size的transaction,地址开始于0x03:

所以可以看到开始也是不对齐的。所以和上一个例子一样,第一笔传输是非对齐的,之后是对齐的。

AXI 协议不要求slave针对unalgined的访问做啥特别的处理。

  1. 读写接口的属性

说实话,从AMBA3到AMBA5,AXI的属性越来越多,支持的功能越来越多,对于这个需要单独再记录一下,每个都能开一章讲。

这一节描述一下接口的属性信息:

|----------------------------------|---------------------------------------------|
| 写接口属性 ||
| Write issuing capability | 表示master最多可以发多少写请求 |
| Write interleave depth attribute | 表示从属接口对于已经active write,可以接受的写数据的数目 |
| Write acceptance capability | 只在AXI3上体现。 表示从属接口可以接受写请求的能力 |
| Write interleave capability | 只在AXI3上体现。 表示主接口可以针对当前的active write的传递数据的能力 |

对于读而言也类似:

|----------------------------|--------------------------|
| 读接口的属性 ||
| Read issuing capability | 表示master最多可以发多少写请求 |
| Read acceptance capability | 表示slave可以接受的能力 |
| Read data reordering depth | 表示从接口可以针对已经发出的read乱序回的能力 |

相关推荐
Clarence Liu2 小时前
虚拟机与容器的差异与取舍
linux·后端·容器
幽络源小助理2 小时前
SpringBoot兼职发布平台源码 | JavaWeb项目免费下载 – 幽络源
java·spring boot·后端
co松柏2 小时前
AI+Excalidraw,用自然语言画手绘风格技术图
前端·人工智能·后端
踏浪无痕2 小时前
四个指标,一种哲学:Prometheus 如何用简单模型看透复杂系统
后端·架构·go
Cosolar2 小时前
MySQL EXPLAIN 执行计划分析:能否查看 JOIN 关联顺序
数据库·后端·mysql
TianXinCoord2 小时前
SpringBoot+MyBatis Plus+PostgreSQL整合常用数据类型(json、array)操作
后端
程序员爱钓鱼3 小时前
用Python开发“跳一跳”小游戏——从零到可玩
后端·python·面试
程序员爱钓鱼3 小时前
Python 源码打包成.whl文件的完整指南
后端·python·面试
IT_陈寒3 小时前
Vite 3.0 实战:5个优化技巧让你的开发效率提升50%
前端·人工智能·后端