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

相关推荐
承渊政道14 分钟前
Linux系统学习【Linux基础开发工具】
linux·运维·笔记·学习·centos·编辑器
承渊政道23 分钟前
C++学习之旅【C++中模板进阶内容介绍】
c语言·c++·笔记·学习·visual studio
浅念-30 分钟前
C语言——动态内存管理
c语言·开发语言·c++·笔记·学习
ASKED_20199 小时前
Langchain学习笔记一 -基础模块以及架构概览
笔记·学习·langchain
Lois_Luo10 小时前
Obsidian + Picgo + Aliyun OSS 实现笔记图片自动上传图床
笔记·oss·图床
(❁´◡`❁)Jimmy(❁´◡`❁)10 小时前
Exgcd 学习笔记
笔记·学习·算法
傻小胖10 小时前
21.ETH-权益证明-北大肖臻老师客堂笔记
笔记·区块链
梁洪飞11 小时前
内核的schedule和SMP多核处理器启动协议
linux·arm开发·嵌入式硬件·arm
云小逸12 小时前
【nmap源码学习】 Nmap网络扫描工具深度解析:从基础参数到核心扫描逻辑
网络·数据库·学习
一只小小的芙厨14 小时前
寒假集训笔记·树上背包
c++·笔记·算法·动态规划