ARMV8 datasheet学习笔记1:预备知识
1. 前言
ARMv8的架构继承以往ARMv7与之前处理器技术的基础;
除了支持现有的16/32bit的Thumb2指令外,也向前兼容现有的A32(ARM 32bit)指令集。
基于64bit的AArch64架构,除了新增A64(ARM 64bit)指令集外,也扩充了现有的A32(ARM 32bit)和T32(Thumb2 32bit)指令集,另外还新增加了CRYPTO(加密)模块支持。
2. 相关术语
|
Items |
Notes |
|
PE |
Processing element,处理器单元可以理解成一个cpu core |
|
Execution state |
运行状态,包括AArch32和AArch64两种运行状态 |
|
AArch32 |
描述32bit Execution State,地址存在32bit寄存器;指令集使用32位寄存器;支持A32和T32指令集 |
|
AArch64 |
描述64bit Execution State,地址存在64bit寄存器;指令集使用64位寄存器;支持A64指令集 |
|
A32、T32 |
AArch32 ISA (Instruction Architecture) |
|
A64 |
AArch64 ISA (Instruction Architecture) |
|
Interprocessing |
AArch32和AArch64两种执行状态之间的切换 |
|
SIMD |
Single-Instruction, Multiple-Data (单指令多数据) |
|
translation table walks |
指页表的查找过程 |
|
Volatile |
标有Volatile的字段编译器认为是多线程代码, 从而不会执行优化; 这保证内存中字段的值总是最新的。比如连续两次读一个变量,不加volatile则编译器会优化,只会读一次,加上volatile,则编译器不会优化,会读两次,对寄存器的访问一般会加此关键字 |
3. 主要内容
|
主要内容 |
说明 |
|
Execution state |
包括AArch32与AArch64 |
|
Instruction sets |
包括AArch32下A32和T32指令集 与 AArch64下的A64指令集 |
|
state |
包括当前的Exception level和Secure state,这决定了PE的行为 |
|
异常模型 |
异常的类型、路由及处理 |
|
Interprocessing |
AArch64与AArch32的切换规则 |
|
存储模型 |
描述内存访问的规则和内存管理 |
|
编程模型 |
通过访问系统寄存器来控制PE和存储系统的大部分特性,并提供状态信息 |
|
SIMD和浮点指令 |
提供了高性能 |
|
Security模型 |
提供了两种安全状态,支持安全特性的应用开发 |
|
虚拟化模型 |
支持non-security的虚拟化操作 |
|
Debug |
提供了软件访问debug的一些特性 |
表 ARMV8描述的主要内容
4. 内容编排
|
章节 |
说明 |
|
A |
简介和体系结构概述 |
|
B C D |
AArch64应用级体系结构 A64指令集 AArch64系统级体系结构 |
|
E F G |
AArch32应用级体系结构 AArch32指令集 AArch32系统级体系结构 |
|
H |
外部debug |
|
I |
Armv8体系结构的内存映射组件 |
|
J |
体系结构伪代码 |
表 本数据手册的内容编排
5. 参考文档
[1] ARMv8-A Architecture reference manual-DDI0487A_g_armv8_arm.pdf
ARMV8 datasheet学习笔记1:预备知识的更多相关文章
- ARMV8 datasheet学习笔记5:异常模型
1.前言 2.异常类型描述 见 ARMV8 datasheet学习笔记4:AArch64系统级体系结构之编程模型(1)-EL/ET/ST 一文 3. 异常处理路由对比 AArch32.AArch64架 ...
- ARMV8 datasheet学习笔记3:AArch64应用级体系结构
1.前言 本文主要从应用的角度介绍ARMV8的编程模型和存储模型 2. AArch64应用级编程模型 从应用的角度看到的ARM处理器元素: 可见的元素(寄存器/指令) 说明 可见的寄存器 R0-R30 ...
- ARMV8 datasheet学习笔记4:AArch64系统级体系结构之VMSA
1. 前言 2. VMSA概述 2.1 ARMv8 VMSA naming VMSAv8 整个转换机中,地址转换有一个或两个stage VMSAv8-32 由运行AArch32的异常级别来管理 VMS ...
- ARMV8 datasheet学习笔记4:AArch64系统级体系结构之存储模型
1.前言 关于存储系统体系架构,可以概述如下: 存储系统体系结构的形式 VMSA 存储属性 2. 存储系统体系结构 2.1. 地址空间 指令地址空间溢出 指令地址计算((address_of ...
- ARMV8 datasheet学习笔记4:AArch64系统级体系结构之编程模型(4)- 其它
1. 前言 2.可配置的指令使能/禁用控制和trap控制 指令使能/禁用 当指令被禁用,则这条指令就会变成未定义 指令Trap控制 控制某条或某些指令在运行时进入陷阱,进入陷阱的指令会产生trap异常 ...
- ARMV8 datasheet学习笔记4:AArch64系统级体系结构之编程模型(3)- 异常
1.前言 本文介绍异常相关内容,包括异常类型,异常进入,异常返回,异常层次结构,异常的路由等 2. RESET ARMV8体系结构支持两种类型的RESET Cold reset:Reset PE所有 ...
- ARMV8 datasheet学习笔记4:AArch64系统级体系结构之编程模型(2)- 寄存器
1. 前言 2. 指令运行与异常处理寄存器 ARM体系结构的寄存器分为两类: (1)系统控制和状态报告寄存器 (2)指令处理寄存器,如累加.异常处理 本部分将主要介绍如上第(2)部分的寄存器,分为AA ...
- ARMV8 datasheet学习笔记4:AArch64系统级体系结构之编程模型(1)-EL/ET/ST
1.前言 ARMV8系统级编程模型主要包括异常级别.运行状态.安全状态.同步异常.异步异常.DEBUG 本文主要对系统级编程模型做一个概要介绍 2. 异常级别 2.1 Exception level概 ...
- ARMV8 datasheet学习笔记3:AArch64应用级体系结构之Synchronization and semapores
1.前言 本文主要介绍原子变量的实现原理,对原子变量的修改有一套特殊的机制 2. Local monitor和Global monitor UP时执行Load EX和Store EX时仅需关注Loca ...
随机推荐
- Linux中无权限使用sudo
提示:$USER is not in the sudoers file. This incident will be reported. 解决方法: 切换到root用户,su 编辑sudo配置文件,v ...
- UVA 1394 And Then There Was One / Gym 101415A And Then There Was One / UVAlive 3882 And Then There Was One / POJ 3517 And Then There Was One / Aizu 1275 And Then There Was One (动态规划,思维题)
UVA 1394 And Then There Was One / Gym 101415A And Then There Was One / UVAlive 3882 And Then There W ...
- 关于promise的一些用法
Promise,简单说就是一个容器,里面保存着某个未来才会结束的事件(通常是一个异步操作)的结果.从语法上说,Promise 是一个对象,从它可以获取异步操作的消息. Promise对象有以下两个特点 ...
- prototype和__proto__区别
prototype和__proto__分别是显式原型和隐式原型,直接上代码吧: function person(){ this.age = 12; } person.prototype; //Obje ...
- 原生ajax写法
ajax1.0,ie9及以下,ie10+支持ajax2.0 ajax2.0比ajax1.0: 1.多了FormData对象,xhr.send(formData) //不能用GET 2.文件上传,文件 ...
- ACPI:Memory错误解决办法
Linux系统装在vmware12中,打开虚拟机时报错,报错内容大概如下: ACPI:memory_hp:Memory online failed for 0x100000000 - 0x400000 ...
- mysql -- 索引补充
.unique索引补充:联合唯一 unique(name,email)是name和email这两列联合起来唯一,不再试某个字段唯一 .主键索引,类似唯一索引,也是允许联合多个字段作为主键,例如:pri ...
- javascript 函数的4种调用模式
1. 函数模式 // this 指向 window 全局对象 2. 方法模式 // this 指向调用这个方法的对象 3. 构造函数模式 // this 指向 new 新创建出来的实例 4. 上下文模 ...
- Redis在Windows上使用和集群配置
一.什么是Redis Redis是一个开源的,使用C语言编写的面向键值对类型的分布式Nosql数据库系统,功能类似Memcache,但比Memcache功能更丰富.官网地址:https://redis ...
- C#星夜拾遗之delegate示例
概念 delegate即委托.如果你使用过C++或者js中的回调函数,你会更容易明白一些.在异步操作中常常使用回调函数,例如在Ajax中,当HttpRequest执行异步请求时,就需要有一个状态改变时 ...