刘帅嵌入式系统-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

相关文章

golang程序打包成脚本部署到Linux系统方式

《golang程序打包成脚本部署到Linux系统方式》Golang程序通过本地编译(设置GOOS为linux生成无后缀二进制文件),上传至Linux服务器后赋权执行,使用nohup命令实现后台运行,完... 目录本地编译golang程序上传Golang二进制文件到linux服务器总结本地编译Golang程序

Linux系统性能检测命令详解

《Linux系统性能检测命令详解》本文介绍了Linux系统常用的监控命令(如top、vmstat、iostat、htop等)及其参数功能,涵盖进程状态、内存使用、磁盘I/O、系统负载等多维度资源监控,... 目录toppsuptimevmstatIOStatiotopslabtophtopdstatnmon

SQLite3 在嵌入式C环境中存储音频/视频文件的最优方案

《SQLite3在嵌入式C环境中存储音频/视频文件的最优方案》本文探讨了SQLite3在嵌入式C环境中存储音视频文件的优化方案,推荐采用文件路径存储结合元数据管理,兼顾效率与资源限制,小文件可使用B... 目录SQLite3 在嵌入式C环境中存储音频/视频文件的专业方案一、存储策略选择1. 直接存储 vs

嵌入式数据库SQLite 3配置使用讲解

《嵌入式数据库SQLite3配置使用讲解》本文强调嵌入式项目中SQLite3数据库的重要性,因其零配置、轻量级、跨平台及事务处理特性,可保障数据溯源与责任明确,详细讲解安装配置、基础语法及SQLit... 目录0、惨痛教训1、SQLite3环境配置(1)、下载安装SQLite库(2)、解压下载的文件(3)、

linux重启命令有哪些? 7个实用的Linux系统重启命令汇总

《linux重启命令有哪些?7个实用的Linux系统重启命令汇总》Linux系统提供了多种重启命令,常用的包括shutdown-r、reboot、init6等,不同命令适用于不同场景,本文将详细... 在管理和维护 linux 服务器时,完成系统更新、故障排查或日常维护后,重启系统往往是必不可少的步骤。本文

k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)

《k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)》本文记录在K8s上运行的MySQL/MariaDB备份方案,通过工具容器执行mysqldump,结合定时任务实... 目录前言一、获取需要备份的数据库的信息二、备份步骤1.准备工作(X86)1.准备工作(arm)2.手

Mac系统下卸载JAVA和JDK的步骤

《Mac系统下卸载JAVA和JDK的步骤》JDK是Java语言的软件开发工具包,它提供了开发和运行Java应用程序所需的工具、库和资源,:本文主要介绍Mac系统下卸载JAVA和JDK的相关资料,需... 目录1. 卸载系统自带的 Java 版本检查当前 Java 版本通过命令卸载系统 Java2. 卸载自定

使用jenv工具管理多个JDK版本的方法步骤

《使用jenv工具管理多个JDK版本的方法步骤》jenv是一个开源的Java环境管理工具,旨在帮助开发者在同一台机器上轻松管理和切换多个Java版本,:本文主要介绍使用jenv工具管理多个JD... 目录一、jenv到底是干啥的?二、jenv的核心功能(一)管理多个Java版本(二)支持插件扩展(三)环境隔

基于Python实现一个简单的题库与在线考试系统

《基于Python实现一个简单的题库与在线考试系统》在当今信息化教育时代,在线学习与考试系统已成为教育技术领域的重要组成部分,本文就来介绍一下如何使用Python和PyQt5框架开发一个名为白泽题库系... 目录概述功能特点界面展示系统架构设计类结构图Excel题库填写格式模板题库题目填写格式表核心数据结构

Linux系统中的firewall-offline-cmd详解(收藏版)

《Linux系统中的firewall-offline-cmd详解(收藏版)》firewall-offline-cmd是firewalld的一个命令行工具,专门设计用于在没有运行firewalld服务的... 目录主要用途基本语法选项1. 状态管理2. 区域管理3. 服务管理4. 端口管理5. ICMP 阻断