刘帅嵌入式系统-ARM体系结构的版本

2023-12-09 17:18

本文主要是介绍刘帅嵌入式系统-ARM体系结构的版本,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

这次介绍一下ARM的前6个版本(V1~V6),特点如下:

1、版本1(V1)

    再ARM1中实现,没有商用。此版本地址空间是26位,已经不在使用。

2、版本2(V2)

    和版本1相比,增加了一些指令(乘法和乘加法指令,支持协处理器指令,新增两个FIQ的备份寄存器,SWP和SWB指令),地址空间同V1(26位),也不在使用。

3、版本3(V3)

    和之前的两个版本相比,V3版本变化比较大。改进如下:

    1)地址空间扩展到了32位,但向前兼容,支持26位地址空间(除去版本3G,V3的一个变种)。

    2)程序状态寄存器,从以前的R15,移到一个新的寄存器cpsr。

    3)增加spsr,备份程序状态寄存器,用于异常中断时,保存被中断的程序状态。

    4)增加两种处理器模式,方便操作系统访问部分异常。

    5)增加指令MRS和MSR,用于访问cpsr和spsr。

    6)修改异常返回指令。

4、版本4(V4)

    于V3相比,增加了一些指令:

    1)半子的读取和写入指令。

    2)带符号字节和半子的读取指令load。

    3)增加可以使处理器切换到Thumb状态的指令,改状态运行的指令集是16位的Thumb指令集。

    4)增加了处理器的特权模式。在此模式下,使用的用户模式下的寄存器。

另外,V4版本不强制要求对26位地址空间的支持。另外,明确定义了哪些指令会引起未定义指令异常。

5、版本5(V5)

    于V4相比,V5增加和修改了下列指令:

    1、提高了Thumb/ARM指令混合使用的效率。

    2、对T变种指令和非T变种指令采用了相同的代码生产技术。

    3、增加了前导零计数指令,可以使整数除法和中断优先级排队操作更有效。

    4、增加了软件断电指令。

    5、威胁处理器设计提供了更多可选指令。

    6、更加严格地定义了乘法指令对条件标志位的影响。

 

6、版本6(V6)

    版本6主要特点是增加了SIMD功能扩展。降低了功耗,更适合使用电池供电的高性能的便携设备。

 

这篇关于刘帅嵌入式系统-ARM体系结构的版本的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/474493

相关文章

Nginx配置系统服务&设置环境变量方式

《Nginx配置系统服务&设置环境变量方式》本文介绍了如何将Nginx配置为系统服务并设置环境变量,以便更方便地对Nginx进行操作,通过配置系统服务,可以使用系统命令来启动、停止或重新加载Nginx... 目录1.Nginx操作问题2.配置系统服android务3.设置环境变量总结1.Nginx操作问题

springboot3.4和mybatis plus的版本问题的解决

《springboot3.4和mybatisplus的版本问题的解决》本文主要介绍了springboot3.4和mybatisplus的版本问题的解决,主要由于SpringBoot3.4与MyBat... 报错1:spring-boot-starter/3.4.0/spring-boot-starter-

mac安装nvm(node.js)多版本管理实践步骤

《mac安装nvm(node.js)多版本管理实践步骤》:本文主要介绍mac安装nvm(node.js)多版本管理的相关资料,NVM是一个用于管理多个Node.js版本的命令行工具,它允许开发者在... 目录NVM功能简介MAC安装实践一、下载nvm二、安装nvm三、安装node.js总结NVM功能简介N

CSS3 最强二维布局系统之Grid 网格布局

《CSS3最强二维布局系统之Grid网格布局》CS3的Grid网格布局是目前最强的二维布局系统,可以同时对列和行进行处理,将网页划分成一个个网格,可以任意组合不同的网格,做出各种各样的布局,本文介... 深入学习 css3 目前最强大的布局系统 Grid 网格布局Grid 网格布局的基本认识Grid 网

在不同系统间迁移Python程序的方法与教程

《在不同系统间迁移Python程序的方法与教程》本文介绍了几种将Windows上编写的Python程序迁移到Linux服务器上的方法,包括使用虚拟环境和依赖冻结、容器化技术(如Docker)、使用An... 目录使用虚拟环境和依赖冻结1. 创建虚拟环境2. 冻结依赖使用容器化技术(如 docker)1. 创

CentOS系统Maven安装教程分享

《CentOS系统Maven安装教程分享》本文介绍了如何在CentOS系统中安装Maven,并提供了一个简单的实际应用案例,安装Maven需要先安装Java和设置环境变量,Maven可以自动管理项目的... 目录准备工作下载并安装Maven常见问题及解决方法实际应用案例总结Maven是一个流行的项目管理工具

java中不同版本JSONObject区别小结

《java中不同版本JSONObject区别小结》本文主要介绍了java中不同版本JSONObject区别小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们... 目录1. FastjsON2. Jackson3. Gson4. org.json6. 总结在Jav

golang1.23版本之前 Timer Reset方法无法正确使用

《golang1.23版本之前TimerReset方法无法正确使用》在Go1.23之前,使用`time.Reset`函数时需要先调用`Stop`并明确从timer的channel中抽取出东西,以避... 目录golang1.23 之前 Reset ​到底有什么问题golang1.23 之前到底应该如何正确的

C#实现系统信息监控与获取功能

《C#实现系统信息监控与获取功能》在C#开发的众多应用场景中,获取系统信息以及监控用户操作有着广泛的用途,比如在系统性能优化工具中,需要实时读取CPU、GPU资源信息,本文将详细介绍如何使用C#来实现... 目录前言一、C# 监控键盘1. 原理与实现思路2. 代码实现二、读取 CPU、GPU 资源信息1.

在C#中获取端口号与系统信息的高效实践

《在C#中获取端口号与系统信息的高效实践》在现代软件开发中,尤其是系统管理、运维、监控和性能优化等场景中,了解计算机硬件和网络的状态至关重要,C#作为一种广泛应用的编程语言,提供了丰富的API来帮助开... 目录引言1. 获取端口号信息1.1 获取活动的 TCP 和 UDP 连接说明:应用场景:2. 获取硬