ARM体系结构的版本v1-v8
来源:互联网 发布:综合返利源码 编辑:程序博客网 时间:2024/05/21 08:00
ARM指令集体系结构,从最初开发至今已有了重大改进,而且将会不断完善和发展。为了精确表达每个ARM实现中所使用的指令集,到目前ARM体系结构共定义了8个版本,以版本号v1~v8表示,各版本特点如下。
1. 版本1(v1)
该版本包括:
●基本数据处理指令(不包括乘法)。
●字节、字以及半字加载/存储指令。
●分支(branch)指令,包括用于子程序调用的分支与链接(branch-and-link)指令。
●软件中断指令,用于进行操作系统调用。
●26位地址总线。
2. 版本2(v2)
与版本1相比,版本2增加了下列指令:
●乘法和乘加指令(multiply & multiply-accumulate)。
●支持协处理器。
●原子性(atomic)加载/存储指令SWP和SWPB(稍后的版本称v2a)。
●FIQ中的两个以上的分组寄存器。
3. 版本3(v3)
版本3较以前的版本发生了大的变化,具体改进如下:
●推出32位寻址能力。
●分开的CPSR(current program status register,当前程序状态寄存器)和SPSR(saved program status register,备份的程序状态寄存器),当异常发生时,SPSR用于保存CPSR的当前值,从异常退出时则可由SPSR来恢复CPSR。
●增加了两种异常模式,使操作系统代码可方便地使用数据访问中止异常、指令预取中止异常和未定义指令异常。
●增加了MRS指令和MSR指令,用于完成对CPSR和SPSR寄存器的读/写;修改了原来的从异常中返回的指令。
4. 版本4(v4)
版本4在版本3的基础上增加了如下内容:
●有符号、无符号的半字和有符号字节的load和store指令。
●增加了T变种,处理器可工作于Thumb状态,在该状态下,指令集是16位压缩指令集(Thumb指令集)。
●增加了处理器的特权模式。在该模式下,使用的是用户模式下的寄存器。
另外,在版本4中还清楚地指明了哪些指令会引起未定义指令异常。版本4不再强制要求与以前的26位地址空间兼容。
5. 版本5(v5)
与版本4相比,版本5增加或修改了下列指令:
●提高了T变种中ARM/Thumb指令混合使用的效率。
●增加了前导零计数(CLZ)指令。
●增加了BKPT(软件断点)指令。
●为支持协处理器设计提供了更多的可选择的指令。
●更加严格地定义了乘法指令对条件标志位的影响。
6. 版本6(v6)
ARM体系版本6是2001年发布的。该版本在降低耗电的同时,还强化了图形处理性能。通过追加有效多媒体处理的SIMD(single instruction multiple datastream,单指令流,多数据流)功能,将语音及图像的处理功能提高到了原机型的4倍。ARM体系版本6首先在2002年春季发布的ARM11处理器中使用。除此之外,v6还支持多微处理器内核。表2.1给出了ARM处理器核使用ARM体系结构版本的情况。
7.版本7 (v7)
ARMv7架构是在ARMv6架构的基础上诞生的。该架构采用了Thumb-2技术,Thumb-2技术是在ARM的Thumb代码压缩技术的基础上发展起来的,并且保持了对现存ARM解决方案的完整的代码兼容性。Thumb-2技术比纯32位代码少使用 31%的内存,减小了系统开销。同时能够提供比已有的基于Thumb技术的解决方案高出38%的性能。ARMv7架构还采用了NEON技术,将DSP和媒体处理能力提高了近4倍,并支持改良的浮点运算,满足下一代3D图形、游戏物理应用以及传统嵌入式控制应用的需求。此外,ARMv7还支持改良的运行环境,以迎合不断增加的JIT(Just In Time)和DAC(DynamicAdaptive Compilation)技术的使用。另外,ARMv7架构对于早期的ARM处理器软件也提供很好的兼容性。
ARMv7架构定义了三大分工明确的系列:“A”系列面向尖端的基于虚拟内存的操作系统和用户应用;“R”系列针对实时系统;“M”系列对微控制器和低成本应用提供优化。
8.版本8(v8)
ARMv8-A 将 64 位架构支持引入 ARM 架构中,其中包括:
- 64 位通用寄存器、SP(堆栈指针)和 PC(程序计数器)
- 64 位数据处理和扩展的虚拟寻址
- 两种主要执行状态:
- AArch64 - 64 位执行状态,包括该状态的异常模型、内存模型、程序员模型和指令集支持
- AArch32 — 32 位执行状态,包括该状态的异常模型、内存模型、程序员模型和指令集支持
这些执行状态支持三个主要指令集:
- A32(或 ARM):32 位固定长度指令集,通过不同架构变体增强部分 32 位架构执行环境现在称为 AArch32。
- T32 (Thumb) 是以 16 位固定长度指令集的形式引入的,随后在引入 Thumb-2 技术时增强为 16 位和 32 位混合长度指令集。部分 32 位架构执行环境现在称为 AArch32。
- A64:提供与 ARM 和 Thumb 指令集类似功能的 32 位固定长度指令集。随 ARMv8-A 一起引入,它是一种 AArch64 指令集。
ARM ISA 不断改进,以满足前沿应用程序开发人员日益增长的要求,同时保留了必要的向后兼容性,以保护软件开发投资。在 ARMv8-A 中,对 A32 和 T32 进行了一些增补,以保持与 A64 指令集一致。
- ARM体系结构的版本v1-v8
- arm体系结构的版本及命名方法
- ARM体系结构版本
- ARM体系结构的优点
- ARM体系结构的发展
- ARM体系结构的发展
- ARM体系结构的理解
- ARM体系结构的基本概念
- ARM体系结构的基本概念
- ARM处理器的体系结构
- **arm的中断体系结构
- ARM微处理器的体系结构
- arm的v7体系结构
- arm的中断体系结构
- ARM的体系结构
- ARM的体系结构
- ARM的体系结构变种
- ARM的体系结构与编程系列博客——ARM体系版本
- java 数字与字母的转换
- 个人网页:mask.org.tw
- iOS学习交流群:230644538
- Windows 任务计划 隐藏执行窗口的几种方法
- 工作狂的悲哀
- ARM体系结构的版本v1-v8
- 红帽订阅管理器跳出解决方法
- 程序员的鄙视链
- 敏捷脑图用例实践之路
- ZOJ 2615——用栈模拟dfs
- 推荐7本书201505
- [Unity基础]解析excel以及动画切割
- 算法分析与设计实验三 回溯法 24点问题 n皇后问题
- QT解压缩文件