1.前言

本文主要介绍原子变量的实现原理,对原子变量的修改有一套特殊的机制

2. Local monitor和Global monitor

  • UP时执行Load EX和Store EX时仅需关注Local Monitor的状态即可

图 UP时Local Monitor和Global Monitor

  • SMP时执行Load EX和Store EX时需关注Local Monitor和Global Monitor的状态

图 SMP时Local Monitor和Global Monitor

3. Exclusive access instructions and Non-shareable memory locations

Non-hareable内存指的是具有内部共享属性的的一块存储区域。它仅会在本PE内部进行共享

图 Local Monitor状态机图

  • Load-Exclusive

Load-Exclusive指令执行时local monitor标记PE执行load EX的地址为独占,local monitor由Open Access状态转换为Exclusive Access状态;

  • Store-Exclusive

依赖local monitor的状态:

(1)如果local monitor 为Exclusive Access状态

如果store的地址为先前load EX访问时的地址,则store EX会发生,并清空独占地址标记,否则由各个厂商自己定义,状态值会返回给寄存器,如果store EX发生则状态值为0,否则状态值为1;

(2)如果local monitor为Open Access状态:

不会有store EX发生;状态值1返回给寄存器,表示store EX没有发生;状态local monitor保持open access状态

4. Exclusive access instructions and shareable memory locations

Shareable内存指的是具有内部共享或外部共享属性的的一块存储区域。它会在所有的PE之间进行共享。

图 SMP Global monitor状态机

  • Load-Exclusive

1. 对于shareable内存,local monitor会将本PE的load EX访问地址标记,忽略其他PE的访问请求, store Ex交由global monitor检查;

2. PE执行load EX时,global monitor会为这个PE标记访问的物理地址为独占访问,这标记主要用于本PE store EX操作,这个独占访问标记会被其它PE的load EX清除。

  • Store-Exclusive

store EX操作时会检查global monitor状态是否对本PE设置独占标记,如果是则store EX会执行,如果成功会清除global monitor为本PE设置的独占标记, 并返回状态0,失败返回1。

也就是本PE store EX操作只有在gloabal monitor为本PE设置独占标记的时候才能执行, 任一时刻global monitor至少为一个PE标记地址

5. Marking and the size of the marked memory block(?)

当执行Load Ex指令时,通过忽略掉64bit内存地址的的LSB来标记一个块,标记的块大小为2a 个Bytes ,标记的块大小范围为4~512 words,  由SOC厂家自定义。

例如厂家定义为4个words,则a为4,LDXRB地址 0x341B4 会使用0x341B4的bits[47:4] 标记一个块为独占访问,也就是从0x341B0 到0x341BF被标记为独占访问。

6. Context switch support

异常返回会清空local monitor

7. Load-Exclusive and Store-Exclusive 指令使用限制

  • LoadExcl/StoreExcl pair只有运行在相同的虚拟地址才能成功;
  • LoadExcl/StoreExcl pair操作的数据宽度必须相同;
  • LoadExcl/StoreExcl pair必须访问相同数量的寄存器;
  • LoadExcl/StoreExcl pair满足一定的条件才可以继续运行;
  • LoadExcl/StoreExcl pair相隔越近则性能越好,因为相隔近,就会减少mornitor标记被清除的可能性;
  • 体系结构设置了LoadExcl/StoreExcl pair设置独享访问的地址上限为2048字节。性能考虑,则将独享访问范围分割成设定的粒度,分多次进行访问;
  • 如果接收到data abort异常,则独享标记是未知的;
  • LoadExcl/StoreExcl pair内存访问属性必须一致,否则store行为未知;
  • LoadExcl/StoreExcl pair之间发生了虚拟地址与物理地址映射的改变,则store EX不会通过monitor的独占标记检查;

8.spin-locks中使用WFE 和 SEV指令

ARMv8 提供了 如下指令:

  • Wait For Event
  • Send Event
  • and Send Event Local instructions
  • WFE
  • SEV
  • SEVL

如上指令减少了power consumption and bus contention caused by PEs repeatedly attempting to obtain a spin-lock.这些指令是应用级的

9.参考文档

[1] Linux内核ARM构架中原子变量的底层实现研究

[2] DDI0487A_k_armv8_arm_iss10775.pdf

ARMV8 datasheet学习笔记3:AArch64应用级体系结构之Synchronization and semapores的更多相关文章

  1. ARMV8 datasheet学习笔记3:AArch64应用级体系结构

    1.前言 本文主要从应用的角度介绍ARMV8的编程模型和存储模型 2. AArch64应用级编程模型 从应用的角度看到的ARM处理器元素: 可见的元素(寄存器/指令) 说明 可见的寄存器 R0-R30 ...

  2. ARMV8 datasheet学习笔记5:异常模型

    1.前言 2.异常类型描述 见 ARMV8 datasheet学习笔记4:AArch64系统级体系结构之编程模型(1)-EL/ET/ST 一文 3. 异常处理路由对比 AArch32.AArch64架 ...

  3. ARMV8 datasheet学习笔记1:预备知识

    1. 前言 ARMv8的架构继承以往ARMv7与之前处理器技术的基础; 除了支持现有的16/32bit的Thumb2指令外,也向前兼容现有的A32(ARM 32bit)指令集. 基于64bit的AAr ...

  4. ARMV8 datasheet学习笔记4:AArch64系统级体系结构之VMSA

    1. 前言 2. VMSA概述 2.1 ARMv8 VMSA naming VMSAv8 整个转换机中,地址转换有一个或两个stage VMSAv8-32 由运行AArch32的异常级别来管理 VMS ...

  5. ARMV8 datasheet学习笔记4:AArch64系统级体系结构之编程模型(4)- 其它

    1. 前言 2.可配置的指令使能/禁用控制和trap控制 指令使能/禁用 当指令被禁用,则这条指令就会变成未定义 指令Trap控制 控制某条或某些指令在运行时进入陷阱,进入陷阱的指令会产生trap异常 ...

  6. ARMV8 datasheet学习笔记4:AArch64系统级体系结构之编程模型(3)- 异常

    1.前言 本文介绍异常相关内容,包括异常类型,异常进入,异常返回,异常层次结构,异常的路由等 2.  RESET ARMV8体系结构支持两种类型的RESET Cold reset:Reset PE所有 ...

  7. ARMV8 datasheet学习笔记4:AArch64系统级体系结构之编程模型(1)-EL/ET/ST

    1.前言 ARMV8系统级编程模型主要包括异常级别.运行状态.安全状态.同步异常.异步异常.DEBUG 本文主要对系统级编程模型做一个概要介绍 2. 异常级别 2.1 Exception level概 ...

  8. ARMV8 datasheet学习笔记4:AArch64系统级体系结构之Generic timer

    1.前言 2.generate timer 2.1 概述 提供了一个系统计数器,用来实时测量流逝的时间: 提供了一个虚拟计数器,用来测量某个虚拟机上流逝的虚拟时间: 定时器,每隔一段时间会触发事件,支 ...

  9. ARMV8 datasheet学习笔记4:AArch64系统级体系结构之存储模型

    1.前言 关于存储系统体系架构,可以概述如下: 存储系统体系结构的形式 VMSA 存储属性   2. 存储系统体系结构 2.1.    地址空间 指令地址空间溢出 指令地址计算((address_of ...

随机推荐

  1. BZOJ 4671 异或图 | 线性基 容斥 DFS

    题面 Description 定义两个结点数相同的图 G1 与图 G2 的异或为一个新的图 G, 其中如果 (u, v) 在 G1 与 G2 中的出现次数之和为 1, 那么边 (u, v) 在 G 中 ...

  2. 【dp专题】NOIP真题-DP专题练习

    这里学习一下DP的正确姿势. 也为了ZJOI2019去水一下做一些准备 题解就随便写写啦. 后续还是会有专题练习和综合练习的. P1005 矩阵取数游戏 给出$n \times m$矩阵每次在每一行取 ...

  3. 导出SharePoint2013用户及权限

    cls Add-PSSnapin Microsoft.SharePoint.PowerShell -ea 0 $site = New-Object Microsoft.SharePoint.SPSit ...

  4. 导入Spreadsheet到sharepoint2013报错

    当导入Spreadsheet到sharepoint2013会报下面的错: an unexpected error has occurred -2147467259 The specified file ...

  5. 洛谷P4413 R2

    好,这是一道巨水题...... #include <cstdio> using namespace std; typedef long long LL; int main() { LL a ...

  6. 使用electron为贪吃蛇游戏创建全局快捷键

    上图就是我们的简体版贪吃蛇游戏,我们可以看到使用键盘上面的上下左右可以对贪吃蛇进行控制. The picture above is our simplified version of Snake Ea ...

  7. 20145215《网络对抗》Exp8 Web基础

    20145215<网络对抗>Exp8 Web基础 基础问题回答 什么是表单? 表单是一个包含表单元素的区域,表单元素是允许用户在表单中(比如:文本域.下拉列表.单选框.复选框等等)输入信息 ...

  8. linux driver ------ platform模型,通过杂项设备(主设备号是10)注册设备节点

    注册完设备和驱动之后,就需要注册设备节点 Linux杂项设备出现的意义在于:有很多简单的外围字符设备,它们功能相对简单,一个设备占用一个主设备号对于内核资源来说太浪费.所以对于这些简单的字符设备它们共 ...

  9. django中的数据库外键操作

    以MYSQL为例: (1)在model中定义两个数据表,食物信息和食物类别信息 class foodInfo(models.Model):     food_id = models.AutoField ...

  10. vue2.0 之标签属性

    标签属性v-bind <template> <div> <ul> <li v-for="item in list"> {{ item ...