当前位置: 首页 > article >正文

T32状态下寄存器组织、AArch32/64重要寄存器(ARM处理器架构模型——寄存器组织,中篇)

本文声明内容来源于网络进行整合/再创作部分内容由AI辅助生成。T32状态下的寄存器组织Thumb状态寄存器是ARM状态的子集。注意在Thumb状态下发生异常时处理器自动进入ARM状态。A32与T32状态下的寄存器组织在Thumb状态中高寄存器R8R15不是标准寄存器集的一部分。汇编语言对它们的访问受到限制但可以将它们用于快速暂存。可以使用MOV、CMP和ADD指令对高寄存器操作。Thumb状态寄存器在ARM状态寄存器上的映射AArch32 重要寄存器简介寄存器类型Bit描述R0-R1532bit通用寄存器但ARM不建议将有特殊功能的R13~R15作为通用寄存器使用SP_x32bit一般将R13作为堆栈指针寄存器SP 除了SYS模式外其他各种模式下都有对应的SP_x 寄存器x{und/svc/abt/irq/fiq/hyp/mon}LR_x32bit一般将R14作为链接寄存器LR 除了SYS和HYP模式外其他各种模式下都有对应的LR_x寄存器x{und/svc/abt/irq/fiq/mon}用于保存子程序返回的链接信息地址。AArch32状态下也用于保存异常返回的地址即LR和ELR是公用一个而AArch64执行状态下是独立的ELR_hyp32bitHYP模式下特有的异常链接寄存器保存异常进入HYP模式时的异常地址PC32bit通常称R15为程序计算器PC指针。AArch32中PC指向的取指地址是当前执行指令地址8Thumb状态下是当前执行指令地址4CPSR32bit记录当前PE的运行状态数据CPSR.M[4:0]记录运行模式AArch64下使用PSTATE代替SPSR_x32bit是CPSR的备份除了USR和SYS模式外其他各种模式下都有对应的SPSR_x寄存器x{und/svc/abt/irq/fiq/hpy/mon}注意这些模式只适用于32bit运行环境APSR32bit应用程序状态寄存器EL0下可以使用APSR访问部分PSTATE值HCR32bitEL2特有HCR.{TEG,AMO,IMO,FMO,RW}控制EL0/EL1的异常路由SCR32bitEL3特有SCR.{EA,IRQ,FIQ,RW}控制EL0/EL1/EL2的异常路由注意EL3始终不会路由VBAR32bit保存任意异常进入非HYP模式、非MON模式的跳转向量基地址HVBAR32bit保存任意异常进入HYP模式的跳转向量基地址MVBAR32bit保存任意异常进入Monitor mode的跳转向量基地址ESR_ELx32bit保存异常进入ELx时的异常综合信息包含异常类型EC等可以通过EC值判断异常classAArch64 重要寄存器简介寄存器类型Bit描述X0-X3064bit通用寄存器原先AArch32下的SP、PC不再是了但如果有需要向下兼容可以作为32bit寄存器使用W0-W30LR64bit通常称X30为专用链接寄存器保存程序跳转返回的信息地址ELR_ELx64bit异常链接寄存器保存异常进入ELx的异常地址x{0,1,2,3}SP_ELx64bit管理不同异常级别的堆栈指针寄存器若PSTATE.M[0]1则每个ELx选择SP_ELx否则选择同一个SP_EL0PC64bit程序计数器俗称PC指针总是指向当前正在执行的指令地址执行完当前指令后PC 硬件本身会自动更新为下一条指令的地址当前指令地址 4SPSR_ELx32bit保存程序状态寄存器主要用于在异常处理过程中保存当前异常级别ELx的PSTATE状态信息。NZCV32bit允许访问的符号标志位DIAF32bit中断使能位D-DebugI-IRQA-SErrorF-FIQ逻辑0允许CurrentEL32bit记录当前处于哪个异常等级Exception levelSPSel32bit记录当前使用SP_EL0还是SP_ELxx{1,2,3}HCR_EL232bitHCR_EL2.{TEG,AMO,IMO,FMO,RW}控制EL0/EL1的异常路由 逻辑1允许SCR_EL332bitSCR_EL3.{EA,IRQ,FIQ,RW}控制EL0/EL1/EL2的异常路由 逻辑1允许ESR_ELx32bit保存异常进入ELx时的异常综合信息包含异常类型EC等VBAR_ELx64bit保存任意异常进入ELx的跳转向量基地址x{0,1,2,3}PSTATE——不是一个寄存器是保存当前PE状态的一组寄存器统称其中可访问寄存器有PSTATE.{NZCV,DAIF,CurrentEL,SPSel}属于ARMv8新增内容在AArch64执行状态下代替CPSRTipsPEProcessing Element——处理单元即处理器的一个核心执行单元。ARMv8架构64位和32位寄存器的映射关系

相关文章:

T32状态下寄存器组织、AArch32/64重要寄存器(ARM处理器架构模型——寄存器组织,中篇)

本文声明:内容来源于网络,进行整合/再创作;部分内容由AI辅助生成。T32状态下的寄存器组织Thumb状态寄存器是ARM状态的子集。注意,在Thumb状态下发生异常时,处理器自动进入ARM状态。A32与T32状态下的寄存器组织在Thumb状…...

问题整理清单

问题整理清单 请问模版匹配这个HHandle 这个句柄 序列化之前和序列化之后不一样呢 ?“HALCON error #2404: Invalid handle type in operator do_ocr_multi_class_cnnpython训练出来的结果预测之后的结果很对,但是一到C#上面就不行了什么是LinuxCNC...

【Dv3Admin】FastCRUD MD编辑器操作

富文本字段和 Markdown 字段在后台表单里的问题,本质上很像,真正麻烦的都不是“能不能挂进去”,而是挂进去以后尺寸、回显、校验和展示边界是否稳定。放到 md-editor-v3 之后,最常见的问题通常集中在编辑区高度不合适、宽度被表单…...

【C++】左值引用、右值引用

目录 一、右值引用的意义 二、基础:理解左值与右值 1. 左值(Lvalue,Locator Value) 常见的左值场景: 2. 右值(Rvalue,Read Value) 2.1 纯右值(prvalue)…...

Tower I3C Host Adapter 使用范例 (20)

Easyi3C是一家领先的嵌入式系统工具供应商,可简化各种通信协议的开发和调试。公司提供一系列产品,旨在帮助工程师和开发人员更高效地使用 I3C、I2C等协议。 基于Tower I3C Host Adapter 测试DDR5 RCD (4) 一 DDR5 RCD I3C背景介绍 在高性能计算和服务器…...

Qt进程间通信

QSharedMemory 共享内存(Shared Memory)是一种进程间通信(Inter-Process Communication, IPC)机制,允许多个进程共享同一块内存区域。共享内存提供了高效的数据交换方式,适用于需要频繁传递大量数据的场景。…...

Hive数仓分区设计与更新操作指南

目录 一、Hive 分区概述 1.1 分区的核心作用 1.2 分区的本质示例 二、分区设计原则 2.1 分区字段选择原则 2.2 分区粒度与数量控制 2.3 分区设计常见误区 三、分区表的创建 3.1 静态分区表 3.1.1 创建静态分区表 3.1.2 向静态分区表插入数据 3.2 动态分区表 3.2.1 …...

2026年最新免费5S管理系统盘点!盘点10个免费的5S系统!

在2026年制造业数字化转型的关键节点,寻找一套高效且低成本的5S管理系统已成为众多中小企业的迫切需求。面对市场上繁杂的软件选择,如何精准定位到真正的免费5S系统?本文为您带来2026年最新免费5S管理系统盘点,深度剖析当前市场格…...

一、STM32入门

用的是正点原子STM32F103MINI、JLINK v8 1.准备工作 1.1手册 1.1.1数据手册 STM32F103RCT6 开发板各个元件的特性。 1.1.2参考手册 在逻辑层面上,如何利用STM32F10X开发板各个部位的特性实现各种功能。 1.1.3厂家的学习开发手册 具体厂家设计的代码层面的如何学…...

《UNIX高级环境编程》第十三章 守护进程(一文读懂UNIX下守护进程)

一、守护进程的特征守护进程是一种生命周期较长的进程,常常在系统启动时被运行,在系统关闭时终止,并且没有关联的终端设备,是一个后台进程。一个系统中,父进程ID为0的一般是内核进程。进程1通常是init进程,…...

杰理AC695N/AC696N歌词回调

想要连接蓝牙播放音乐显示歌词杰理的SDK已经做好封装了, 等待我们去调用就可以了, ac695n和ac696n的sdk调用方法都一样下面开始还有一点最重要的是下面这个宏必须要打开, 最后连接蓝牙播放音乐就能在日志打印中看到歌词的回调了还有一个做法是可以把A2DP的这个宏关掉, 然后就可…...

配置中心的作用?Nacos 配置中心原理?

一句话回答:配置中心的作用,就是把分散在各个服务里的配置统一集中管理,并支持动态推送和环境隔离,避免每次改配置都去改代码、重启服务。 Nacos 官方也把自己定位成“动态配置服务”,强调配置的中心化、外部化和动态化…...

NPM Script 实战:常用命令设计与封装|Vue 工程化篇

【NPM Script】Vue 前端工程化实操:从核心封装逻辑到落地,彻底搞懂 npm run 常用命令最佳写法,避开端口占用、环境变量、多环境构建高频坑! 📑 文章目录 开篇一、NPM Script 是什么?为什么用它&#xff1f…...

KMP算法之 next 数组的计算

/*** brief 计算模式串的next数组(部分匹配表),并可视化计算过程* param pattern 模式串(待查找的基因片段)* param next 输出参数:存储next数组(长度需≥模式串长度)*/ void kmp_ge…...

发电机组并网技术研究

一、概述在现代电力供应体系中,柴发机组作为应急电源或后备电源,是应对市电中断、用电高峰负荷及特殊场景电力需求,保障电力持续、稳定供应的关键核心设备,其典型应用系统如下图1所示(图1:柴发机组典型供电…...

负载均衡策略有哪些?如何自定义?

你先记一句总纲:负载均衡策略,就是当一个服务有多个实例时,客户端或网关该按什么规则选一个实例去调用。常见负载均衡策略1. 轮询 Round Robin按顺序一个一个分配请求:第1个请求给实例A第2个请求给实例B第3个请求给实例C优点是简单…...

深度解构 BeyondMimic 引导扩散控制策略

深度解构 BeyondMimic 引导扩散控制策略 引导扩散就是先利用 Tracking 的方式训练出多个可以实现各种动作的小模型,随后利用这些小模型在仿真中生成大量的数据,用来训练出一个大模型,也就是蒸馏。但这里用的不是传统的蒸馏手段,我…...

全球爆火的龙虾杀入科研智能体赛道,字节跳动、微软以及英伟达等巨头也早已布局AI4Science领域

小罗碎碎念 如果说2020年至2023年是以AlphaFold为代表的模型在静态数据映射和结构预测上取得历史性突破的阶段,那么2025至2026年则标志着科学智能正式迈入“智能体(Agentic AI)”时代 。 在这一全新阶段,人工智能不再仅仅是被动…...

leetcode 1394. Find Lucky Integer in an Array 找出数组中的幸运数-耗时100

Problem: 1394. Find Lucky Integer in an Array 找出数组中的幸运数 耗时100%&#xff0c;固定数组统计频次&#xff0c;从高到低判断频次和数值是否相等 Code class Solution { public:int findLucky(vector<int>& arr) {vector<int> freq(501, 0);for(int&…...

leetcode 困难题 1392. Longest Happy Prefix 最长快乐前缀

Problem: 1392. Longest Happy Prefix 最长快乐前缀 滚动哈希的&#xff0c;取基26&#xff0c;模1e9 11&#xff0c;首先求出字符串的前缀哈希&#xff0c;前缀哈希用到了滚动哈希计算方式 后缀哈希&#xff0c;可以直接套公式求 像cbcb&#xff0c;前缀哈希这么算&#xf…...

AI新范式 02|拆解世界模型:它是如何理解物理规律的?

当AI学会了“重力加速度”&#xff0c;它就真正开始理解这个世界引言&#xff1a;从“知其然”到“知其所以然” 在第一篇中&#xff0c;我们谈到2026年是“世界模型元年”&#xff0c;NVIDIA Cosmos、Google DeepMind Genie等代表性工作正在重塑AI对物理世界的理解。但一个核心…...

告别绘图软件!Paperxie AI 科研绘图:10 次免费额度,让理工科论文可视化一步到位

paperxie科研绘图https://www.paperxie.cn/drawinghttps://www.paperxie.cn/drawing 在科研写作与论文发表的路上&#xff0c;「科研绘图」永远是那道绕不开的坎&#xff1a;Matplotlib 代码写了几百行还是跑不出理想图表&#xff0c;Origin 复杂的操作界面让新手望而却步&…...

环境变量与虚拟地址空间

环境变量与虚拟地址空间环境变量&#xff08;1&#xff09;问题引入&#xff08;2&#xff09;引入环境变量&#xff08;3&#xff09;环境变量和c代码关系1.用代码获取环境变量2.作用(4)添加环境变量&#xff08;5&#xff09;删除环境变量&#xff08;6&#xff09;set环境变…...

从零开始了解数据采集——制造业数字孪生

近年来&#xff0c;我国的工业领域正经历一场前所未有的数字化变革&#xff0c;从“双碳目标”到工业互联网平台的推广&#xff0c;国家政策和市场需求共同推动了制造业的升级。在这场变革中&#xff0c;数字孪生技术成为备受关注的关键工具&#xff0c;它不仅让企业“看见”设…...

2026 本科生论文工具盘点:9 款 AI 工具搞定初稿 / 绘图 / 排版 / AI 率

一、写在前面&#xff1a;论文季的「工具焦虑」&#xff0c;你需要一份精准选型指南 又到毕业季&#xff0c;朋友圈里满是「论文写到凌晨三点」「格式改到崩溃」「AI 率超标被导师打回」的吐槽。写毕业论文从来不是「敲字」那么简单&#xff1a;从选题定方向、初稿生成&#x…...

cpp刷题打卡20——前k个高频元素

前k个高频元素 题目描述&#xff1a; 给你一个整数数组 nums 和一个整数 k &#xff0c;请你返回其中出现频率前 k 高的元素。你可以按 任意顺序 返回答案。 题目代码&#xff1a; class Solution { public:class Mycompare{public:bool operator()(pair<int, int>&…...

基于docker的LLM服务部署

下载 拿qwen-3.5-9B 为例&#xff1a; https://www.modelscope.cn/models/Qwen/Qwen3.5-9B 首先下模型 git lfs install git clone https://www.modelscope.cn/Qwen/Qwen3.5-9B.git 然后下对应docker,框架我用的是vllm docker pull vllm/vllm-openai:qwen3_5 &#xff08;官…...

城市环境监测传感器—实时监测与分析环境数据

城市环境监测传感器是智慧城市建设中不可或缺的“感知神经”&#xff0c;通过实时监测与分析环境数据&#xff0c;为城市治理、生态保护与居民健康提供科学支撑。能够测量环境中的氧气、二氧化碳、氮气等气体成分&#xff0c;以及温度、湿度、噪音等参数。部分传感器还集成气象…...

【开题答辩全过程】以 户外用品比价系统为例,包含答辩的问题和答案

个人简介一名14年经验的资深毕设内行人&#xff0c;语言擅长Java、php、微信小程序、Python、Golang、安卓Android等开发项目包括大数据、深度学习、网站、小程序、安卓、算法。平常会做一些项目定制化开发、代码讲解、答辩教学、文档编写、也懂一些降重方面的技巧。感谢大家的…...

C的数组概念

一、一维数组1.1 概念数组是一组相同数据类型的元素的集合&#xff0c;这些元素在内存中是连续存储的&#xff0c;并且通过一个唯一的数组名称和索引来访问。1.2 定义一维数组的定义语法格式&#xff1a;数据类型 数组名 [元素个数];1.3 访问与操作1.3.1 访问访问数组元素通过下…...