AXI 原子访问

今天因为又看到了关于原子访问的问题,因此将对应的内容记录在这里。

在之前工作中会看到cpu中有原子指令,就是在做同一块memory地址进行读写时,会以原子的方式去写,读写期间不会在插入其他操作。后来在AMBA协议中也看到了原子访问的这种描述,就在想这两者之间的联系,想来想去,关系应该就是cpu发原子操作,互联协议保证原子操作的执行,但是互联上本身存在着很多的事务和传输,因此,怎么高效和可靠的完成原子传输就是互联要做的事情。

  1. AMBA3实现

在AMBA3中,采用LOCK操作来实现原子访问,本质上来说就是以READ-MODIFY-WRITE来作为连续的序列,第一笔读先来获取权限,此时axlock有效,之后的modify为多笔写操作,此时axlock依旧有效,当最后一笔写来临时,此时axlock无效,该笔访问操作完成。

注意:这里有几个关注点:

a. 一笔完整的lock操作中,不是lock信号不是都有效的;

b. lock操作会一起发起原子操作的master完全占有总线,这有两个点:

  1. lock操作需要等总线的所有操作都已经完成;

  2. lock操作会独占总线,在原子访问期间,其他所有的操作都不能干,这一点可是会降低总线带宽的哦。

c. lock访问不约束访问的id啥的;

因此,ARM在AMBA4优化了这个操作,为了提升总线带宽和性能,提出了exclusive的操作。

  1. AMBA4

在AMBA4中为了解决lock带来的总线占用问题,因此提出了exclusive。在exclusive上面,依旧采用READ-WRITE的操作,但是因为不再独占总线,因此需要slave侧来monitor exclusive操作,monitor的内容包含了transaction ID和transaction addr,slave侧需要监控每一个exclusive访问的ID,因此,可支持exclusive访问的数量会改变slave侧的monitor容量。

这里也有几个点需要注意:

a. exclusive访问并不会独占总线,会在slave侧记录exclusive访问;

b. 如果在exclusive访问期间,对应的memory空间被别的master写了,那么exclusive的写序列就没法完成,写数据也不会更新;

c. exclusive访问采用EXOKAY和OKAY来判别exclusive访问的成功与否。OKAY表示exclusive访问失败;

d. exclusive在整个序列期间exclusive信号都会有效。

OK,就这些了。

相关推荐
二哈赛车手4 小时前
新人笔记---ApiFox的一些常见使用出错
java·笔记·spring
吃好睡好便好5 小时前
在Matlab中绘制横直方图
开发语言·学习·算法·matlab
nashane5 小时前
HarmonyOS 6学习:CapsLock键失效诊断与长截图完整实现指南
学习·华为·harmonyos
xian_wwq7 小时前
【学习笔记】AGC协调控制系统概述
笔记·学习
x_yeyue7 小时前
三角形数
笔记·算法·数论·组合数学
憧憬成为java架构高手的小白8 小时前
docker学习笔记(基于b站多个视频学习)【未完结】
笔记·学习
辰海Coding8 小时前
MiniSpring框架学习-完成的 IoC 容器
java·spring boot·学习·架构
RainCity9 小时前
Java Swing 自定义组件库分享(七)
java·笔记·后端
闫记康9 小时前
Linux学习day5
linux·chrome·学习
一楼的猫10 小时前
从工具链视角对比:番茄作家助手 vs 第三方写作辅助方案
java·服务器·开发语言·前端·学习·chatgpt·ai写作