armv8 memory translation table descriptor
上一节大致给出了descriptor的结构,这篇细致分析各个field:
1) Table Descriptor:stage2中不包含任何的attribute的field,每个level中的descriptor高位作为下一个level的attr配置。

NSTable,bit[63], 定义subsequent lookup的secure state
APTable,bit[62:61],
UXNTable,bit[60],
PXNTable,bit[59],
2) Block and Page descriptor:stage1,stage2都可以设置,每个memory attr分为upper block和lower block
Stage1:

Upper:
PBHA,bit[62:59],用来支持ARMv8.2-TTPBHA,
XN、UXN,bit[54],
PXN,bit[53],
Contiguous,bit[52],根据颗粒的大小,表示一定数量的相邻的table,被选中。
DBM,Dirty Bit Modifier,bit[51]
Lower:
AF,bit[10],Access flag
SH,bit[9:8],Shareability field
AP,bit[7:6],Data Access Permission
NS,bit[5],non-secure bit
Attrindex,bit[4:2],Stage1 memory attributes index, for MAIR_ELx
Stage2:

新的field包括:
S2AP,bit[7:6],Stage2 Data Access Permission
MemAttr,bit[5:2],Stage2 memory attributes,
接下来分为access permission和memory attributes来分析field。
Access Permission,控制data access和instruction fetch。
Pstate,在ARMv8.2中,是一个描述process state的寄存器,包括
1) condition flags---------N(negative),Z(zero),C(carry),V(overflow)
2) execution state--------EL(current except level),SP(Stack Pointer)
3) exception mask bit
4) access control bit----PAN(privilege access never),UAO(User Access Override)
Stage1中的AP[2:1],
1) AP[2],在read-only和write-read之间选择;
2) AP[1],在EL0和更高的exception level中选择;(none表示mmu报错)

S2AP,在non-secure的EL0、EL1中,
AP和S2AP都设置时,都会起作用。
TCR_ELn寄存器中的APTable[1:0],

总结,关于execution 的 access

。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。
AF(access flag),是软件的应用,表明目前该page是否被访问过,优化在OS memory control中的实现。
还有dirty state bit,也是做软件优化使用的,具体看armv8 doc
Bit[58:55],不论是block descripter还是table descripter,中都会预留,为OS使用。可以存放page是否dirty等信息。
memory region atribute,只针对block和page类型的descriptor
stage1中,AttrIndx[2:0],选定某个MAIR_ELn,实现memory attri的配置;

SH[1:0]对于normal memory,定义Shareability;

stage2中的MemAttr,4bit实现类似MARI的配置、
SH[1:0]对于normal memory,实现shareability的配置。
stage1和stage2都配置时,都会起作用,优先级以及覆盖情况,详见armv8 doc
MAIR_ELn64位寄存器,一共有三个,分为EL1,EL2,EL3,64bit被分为8个byte,每个byte内部编码指定attribute。

armv8 memory translation table descriptor的更多相关文章
- armv8 memory translation
AArch32,arm的32bit架构: AArch64,arm的64bit架构: ARMv8.2-LPA,是armv8.2中的新feature,扩大了IPA和PA的支持范围,从48bit扩展到52b ...
- VMSAv8-64 translation table format descriptors
通常情况下,一个 descriptor 可能是以下的几种 entry: 非法或者异常的 entry. Table entry, 指向 next-level translation table. Blo ...
- memcached vs MySQL Memory engine table 速度比较_XMPP Jabber即时通讯开发实践_百度空间
memcached vs MySQL Memory engine table 速度比较_XMPP Jabber即时通讯开发实践_百度空间 memcached vs MySQL Memory engin ...
- Memory Translation and Segmentation.内存地址转换与分段
原文标题:Memory Translation and Segmentation 原文地址:http://duartes.org/gustavo/blog/ [注:本人水平有限,只好挑一些国外高手的精 ...
- Virtual Memory PAGE TABLE STRUCTURE
COMPUTER ORGANIZATION AND ARCHITECTURE DESIGNING FOR PERFORMANCE NINTH EDITION The basic mechanism f ...
- armv8 memory system
在armv8中,由于processor的预取,流水线, 以及多线程并行的执行方式,而且armv8-a中,使用的是一种weakly-ordered memory model, 不保证program or ...
- MySQL memory引擎 table is full 问题处理
解决mysql的内存表“table is full”错误 101209 13:13:32 [ERROR] /usr/local/mysql/bin/mysqld: The table ‘test_ ...
- org.apache.hadoop.hbase.DoNotRetryIOException: Class org.apache.phoenix.coprocessor.MetaDataEndpointImpl cannot be loaded Set hbase.table.sanity.checks to false at conf or table descriptor if you want
https://stackoverflow.com/questions/38495331/apache-phoenix-unable-to-connect-to-hbase 这个坑不该啊 首选配置hb ...
- 关于ARMv8另外几个问题
版权声明:本文为博主原创文章.未经博主同意不得转载. https://blog.csdn.net/qianlong4526888/article/details/27510675 问题1:支持ARMv ...
随机推荐
- 模拟器运行报错:ld: symbol(s) not found for architecture x86_64
模拟器运行报错: 报错信息如下: Undefined symbols for architecture x86_64: "_x264_encoder_open_142", refe ...
- 第一版STM32PCB的问题
1.5与6引脚连在一起了 2.有3个插排隔得太近,导致传感器安装不了 3.开关不匹配,画PCB时可以考虑一下实验室有哪些东西 4.可以用开关代替跳冒 5.AM3.3电路电容 6.钽电容的正负极区分 有 ...
- 最全的MonkeyRunner自动化测试从入门到精通(2)
一.Python环境变量的配置 步骤一:在官网进行下载python安装包,官网下载的路径:https://www.python.org/,如图所示: 步骤二:下载完成后,双击安装包,进行如下安装的界面 ...
- Java+selenium 如何定位下拉框select
场景:需要进行下拉选择定位元素. 一.select菜单 select也是比较常见的,selenium封装了以下方法, 创建select WebElement selector = dr ...
- 洛谷P3354 Riv河流 [IOI2005] 树型dp
正解:树型dp 解题报告: 传送门! 简要题意:有棵树,每个节点有个权值w,要求选k个节点,最大化∑dis*w,其中如果某个节点到根的路径上选了别的节点,dis指的是到达那个节点的距离 首先这个一看就 ...
- 一个ajax请求,接收json数据
<a id="inviterDel" onclick="delInviter(${item.inviterAddId})">删除</a> ...
- java安全删除一个文件,防止工具恢复数据
解决移动端文件删除的安全问题:file.delect() Java 确保安全删除某个文件 http://outofmemory.cn/code-snippet/14222/Java-securit ...
- mysql 数据表操作 目录
mysql 数据表操作 存储引擎介绍 mysql 使用存储引擎 mysql 数据表的增删改查 mysql 数据类型 mysql 约束条件
- [MySQL优化1]centos中MySQL列出所有表
步骤1 - 连接到MySQL数据库服务器:[root@host]# mysql -u root -pEnter password:******提示登陆成功Welcome to the MySQL mo ...
- mysql-utilities1.6
mysql-utilities1.6 mysql-utilities是一个用python编写的mysql工具集 mysql-utilities是Oracle专门开发的 一共有28个工具 /usr/bi ...