1.前言

关于存储系统体系架构,可以概述如下:

存储系统体系结构的形式

VMSA

存储属性

 

2. 存储系统体系结构

2.1.    地址空间

指令地址空间溢出

指令地址计算((address_of_current_instruction) + (size_of_executed_instruction))超过0xFFFF FFFF FFFF FFFF,PC变成不可知

2.2    Cache支持

  • Caches的一般行为

(1)Cache中已解锁的项不会一直驻留在cache;

(2)Cache中锁定的项会保证会一直在cache中;

(3)任何时候具有cacheable属性的内存在当前异常级别或更高异常级别都可以分配到cache;

(4)不具有cacheable属性的内存不会分配到cache;

(5)一个cache项的释放会写回内存;

  • Cache identification

Cache维护指令

(1)       影响整个cache,如IC IALLU;

(2)       对某个地址的操作,如IC IVAU;

(3)       对set/way的操作,如DC ISW

Cache identification registers

(1)       Cache type寄存器(CTR_EL0)

定义了最小的指令cache line长度;

定义了最小的数据cache line长度;

L1 Cache索引和tag策略

(2)       single cache level ID寄存器(CLIDR_EL1)

实现了哪几级cache;

待续

(3)       single cache size selection寄存器

待续

(4)       cache size identification寄存器

是否支持写透、回写、读分配和写分配;

映射方式、sets/ways等

  • Cacheablity,cache分配,cache瞬态

Cacheablity

cacheablity只适用于normal memory,内存位置可定义为内部cache(如各PE内部的L1)或外部cache(各PE共享的L2);所有的device memory都作为non-cacheablity;

cacheablity属性包含non-cacheablity;写透;写回。

Cache allocate hints

待续

Cache transient hints

待续

  • Enable/disable内存的caching访问
  • Reset的cache行为

(1)reset到自定义状态的所有cache可能是未知的;

(2)cacheablity控制域强制所有内存作为non-cacheablity

(3)在cache被使能前,cache初始化时必须被invalidate

(4)如(2)所述,reset所有的内存都被作为non-cacheablity,如果仍然允许cahce hit,则需:(1)提供确保cache正确初始化的机制;(2)清楚记录cache初始化;

(5)ARM建议任何时候需要无效cache时都要基于ARMV8 cache维护指令???

  • Non-cacheable访问和指令cache
  • 关于ARMV8的cache维护

术语

Level:cache的级别;

Set:由多个连续的cache line组成一个组(set);

Way: 每个set中冲突的备选表项的数目;

(1)Clean:为确保更新到cache中的内容flush到内存;

(2)Invalidate:确保内存中的修改,能够重新加载到cache;

(3)Clean and invalidate:clean指令后跟一个invalidate指令,针对的是同一访问地址;

(1)PoU(Point of Unification):对所有的PE可以观察到一致拷贝的点;

(2)PoC(Point of Coherence):对系统中所有的agent可以观察到一致拷贝的点;

(1)LoC(Level of Coherence):定义了 整个系统  clean或invalidate PoC时所要clean或invalidate的最后一级cache级别号,如:PoU为Level4,则LoC为3,执行clean和invalidate后会清空L1,L2, L3;

(2)LoUU(Level of Unification, uniprocessor):定义了  PE   clean或invalidate PoU时所要clean或invalidate的最后一级cache级别号;

(3)LoUIS(Level of Unification, Inner Shareable):定义了  内部共享域   clean或invalidate PoU时所要clean或invalidate的最后一级cache级别号;

ARMV8 cache层级抽象

操作VA的cache维护指令

操作set/way的cache维护指令

  • Cache维护指令

指令cache维护指令

数据cache维护指令

EL0 cache维护指令的使能配置

Cache维护指令的行为

没有限制cache维护指令的行为,每个cache位置都可能被清空或无效

操作VA到PoU的影响

会影响共享域内的其它PE

所有set/way维护指令的影响

只影响到运行指令的PE

虚拟化和安全性维护指令的影响

每个安全状态有自己的物理地址空间,cache与物理地址关联

边界条件

维护指令会强制所有的内存访问为non-cache???

数据和指令cache维护指令的执行顺序和完成

运行cache维护指令

  • Data cache zero指令
  • cache lockdown

一个cache lock 可保证cache 中的内容一直被保留

  • System level caches

不是体系结构定义的cache,不受体系结构定义的维护指令管理,主要包括三类:

  1. 位于PoC之前的系统级caches,不受cache维护指令管理;
  2. 位于PoC之前的系统级caches,受按地址操作的cache维护指令管理, 不受按set/way操作的cache指令管理;
  3. 位于PoC之前的系统级caches,软件不可见???这部分不受体系结构的管理
  • 分支预测

ARMV8没有定义任何分之预测指令,如果体系结构中分支预测指令对所有agent是可见的,则cache维护指令也要与之适配

2.3   External abort

External abort

存储系统中MMU和debug逻辑检测到的错误除外的其它错误,主要位于SOC外部

取指abort

Data read/write abort

External abort分类

奇偶校验错误/ECC错误报告

3. 参考文档

[1] DDI0487A_k_armv8_arm_iss10775.pdf

ARMV8 datasheet学习笔记4:AArch64系统级体系结构之存储模型的更多相关文章

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

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

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

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

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

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

  4. ARMV8 datasheet学习笔记4:AArch64系统级体系结构之编程模型(2)- 寄存器

    1. 前言 2. 指令运行与异常处理寄存器 ARM体系结构的寄存器分为两类: (1)系统控制和状态报告寄存器 (2)指令处理寄存器,如累加.异常处理 本部分将主要介绍如上第(2)部分的寄存器,分为AA ...

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

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

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

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

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

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

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

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

  9. ARMV8 datasheet学习笔记2:概述

    1. 前言 本文主要概括的介绍ARMV8体系结构定义了哪些内容,概括的说: ARM体系结构定义了PE的行为,不会定义具体的实现 ARM体系结构也定义了debug体系结构和trace体系结构 ARM体系 ...

随机推荐

  1. [SHOI2013]发牌 解题报告

    [SHOI2013]发牌 题意 对一个\(1\sim n(n\le 7\times 10^5)\)的环,指标最开始在\(1\),每次删去顺时针往后第\(d_i\)个元素,指标移到下一个位置.要求输出每 ...

  2. 洛谷 P1430 序列取数 解题报告

    P1430 序列取数 题目描述 给定一个长为\(n\)的整数序列\((n<=1000)\),由\(A\)和\(B\)轮流取数(\(A\)先取).每个人可从序列的左端或右端取若干个数(至少一个), ...

  3. Bean和Spirng模块

    容纳Bean 在Spring中,应用对象生存于Spring容器中,如图所示,Spring容器可以创建.装载.配置这些Bean,并且可以管理它们的生命周期. Spring的容器实现 Bean工厂(org ...

  4. happens-before

    happens-before是JMM最核心的概念.对应Java程序员来说,理解happens-before是理解JMM的关键. JMM的设计 首先,让我们来看JMM的设计意图.从JMM设计者的角度,在 ...

  5. centos6.5安装VNC、远程及启动关闭

    标签: centos vnc 远程桌面 安装 详解 0.说明 安装服务的过程当中,最好是在联网环境下操作.由于涉及到远程连接的问题,系统的防火墙需要关闭,或者是做好相应的过滤策略.参考了网上很多大牛的 ...

  6. CodeBlocks: 生成的exe文件自定义一个图标

    CodeBlocks生成的exe文件的图标默认是系统图标,如何自定义一个漂亮的小图标呢? 我是C菜鸟,平时只用CodeBlocks练习c,也不开发什么软件,这个问题就难倒我了. 到网上搜索了一下,发现 ...

  7. VB|xp风格:终于解决了“图片优化软件”在部分xp系统上无法启动的问题。

    一年以来,图片优化软件一直存在一个“兼容”性问题. 因为之前的软件是在windows 2003系统上开发的,制作成安装文件后,经部分用户测试发现,在部分用户的xp系统上安装后,无法正常启动,只能听到p ...

  8. 初探angular2

    Angular2 是一款开源JavaScript库,由Google维护,用来协助单一页面应用程序运行. Angular2 是 Angular 1.x 的升级版本,性能上得到显著的提高,能很好的支持 W ...

  9. 20145215《网络对抗》Exp7 网络欺诈技术防范

    20145215<网络对抗>Exp7 网络欺诈技术防范 基础问题回答 通常在什么场景下容易受到DNS spoof攻击? 在同一局域网下比较容易受到DNS spoof攻击,攻击者可以冒充域名 ...

  10. GO语言的进阶之路-协程和Channel

    GO语言的进阶之路-协程和Channel 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 看过我之前几篇博客小伙伴可能对Golang语言的语法上了解的差不多了,但是,如果想要你的代码 ...