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,就这些了。

相关推荐
智者知已应修善业5 分钟前
【用74LS151的实现(16序列信号发生器)】2024-6-1
驱动开发·经验分享·笔记·硬件架构·硬件工程
振南的单片机世界15 分钟前
RS485组网三要素:负载、距离、终端电阻
arm开发·stm32·单片机·嵌入式硬件
「維他檸檬茶」15 分钟前
大模型算法学习2026.6.13
学习·算法
代码续发43 分钟前
AI Agent的学习记录
学习
是上好佳佳佳呀1 小时前
【LangChain|Day04】RAG 全流程基础笔记:Document 、 Loader 和 Splitter
笔记·langchain·rag
俊男无期1 小时前
【无标题】
笔记·其他
傻童:CPU1 小时前
PS(ARM)中的寄存器和地址
arm开发
m0_719084111 小时前
es我的笔记
大数据·笔记·elasticsearch
ken22321 小时前
文本编辑器默认字体 收集
学习
H__Rick2 小时前
C51学习-DAY6
单片机·嵌入式硬件·学习