一文搞懂 ARM 64 系列: ADC

news/2024/10/3 12:34:52

1 指令语法

adc <Xd>, <Xn>, <Xm>

2 指令语义

adc就是带「进位」加法,指令中的c就是英文carry

整个指令等价于:

(Xd, _) = Xn + Xm + PSTATE.C

也就是将寄存器Xn,寄存器XmPSTATE中的「进位」标志相加,将相加的结果写入寄存器Xd,但是丢弃相加产生的「进位」。

也就是说,adc指令只是使用PSTATE中的「进位」标志,但是最终结果不影响PSTATE中的「进位」标志。

3 PSTATE

上面代码中PSTATEProcess State,存储着ARM CPU运行时的一些状态。

PSTATE 中最常见的状态就是 NZCV:

N: 借位标志 - Negative Condition flag
Z: 0 - Zero Condition flag
C: 进位标志 - Carry Condition flag
V: 溢出标志 - Overflow Condition flag

要表示PSTATE中的某一标志,比如「进位」,可以写成PSTATE.C

PSTATE除了NZCV4个标志外,还有其他标志。

如果将PSTATE定义成一个结构体,可以表示为:

type ProcState is ( bits (1) N, // Negative condition flag bits (1) Z, // Carry condition flagbits (1) C, // Zero condition flagbits (1) V, // Overflow condition flagbits (1) D, // Debug mask bit [AArch64 only]bits (1) A, // SError interrupt mask bitbits (1) I, // IRQ mask bitbits (1) F, // FIQ mask bitbits (1) PAN, // Privileged Access Never Bit [v8.1]bits (1) UAO, // User Access Override [v8.2]bits (1) DIT, // Data Independent Timing [v8.4]bits (1) TCO, // Tag Check Override [v8.5, AArch64]bits (2) BTYPE, // Branch Type  [v8.5]bits (1) ZA, // Accumulation array [SME]bits (1) SM, // Streaming SVE mode  [SME]bits (1) ALLINT, // Interrupt mask bitbits (1) SS, // Software step bitbits (1) IL, // Illegal Execution state bitbits (2) EL, // Exception levelbits (1) nRW, // not Register Width: 0=64, 1=32bits (1) SP, // Stack pointer select: 0=SP0, 1=SPx [AArch64 only]bits (1) Q, // Cumulative saturation flag [AArch32 only]bits (4) GE, // Greater than or Equal flags [AArch32 only]bits (1) SSBS, // Speculative Store Bypass Safebits (8) IT, // If-then bits, RES0 in CPSR [AArch32 only]bits (1) J, // J bit, RES0  [AArch32 only, RES0 in SPSR and CPSR]bits (1) T, // T32 bit, RES0 in CPSR  [AArch32 only]bits (1) E, // Endianness bit [AArch32 only]bits (5) M // Mode field   [AArch32 only]
)

可以看到,PSTATEARM64ARM32中不一样。有些标志在ARM64ARM32都存在,有些却只在ARM64或者ARM32中单独存在。

同时,不同版本的ARM架构,PSTATE也不一样,比如标志BTYPE就存在ARMv8.5版本中。

4 查看 PSTATE

按照ARM文档,在ARM32下只能通过CPSR寄存器查看PSTATE的部分标志。

ARM64想要查看PSTATE,不同的标志都有单独对应的寄存器。比如查看NZCV标志,就有NZCV寄存器,ARM64下已没有CPSR寄存器。

CPSR32bit寄存器,结构如下:

但是在实践过程中,iPhone 13 pro64bitARM架构处理器,但是却提供了CPSR寄存器,而不能访问比如NZCV寄存器:

(lldb) p/t $cpsr
(unsigned int) 0b01100000000000000001000000000000
(lldb) p/t $nzcv
error: <user expression 2>:1:1: use of undeclared identifier '$nzcv'
$nzcv
^

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.ryyt.cn/news/29195.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈,一经查实,立即删除!

相关文章

Linux Shell 脚本专题

本文介绍了Linux Shell环境变量和脚本使用的常用知识点。V1.0 2024年5月8日 发布于博客园目录常用环境变量一、环境变量的概念1、环境变量的含义2、环境变量的分类3、Linux环境变量二、常用的环境变量1、查看环境变量2、常用的环境变量三、设置环境量1、系统环境变量2、用户环境…

OpenDiary 24.5

我去!五月了我去!五月了 一亿年没更日寄了pixiv 100277433四月后日谈 鉴于整个四月基本没记日记,有必要开展一次考古活动 因为考古是比较困难的事情,所以想到什么就写什么了打了一整月的 p5r,四月下旬全都在高强度 p5r,每天都情不自禁打很长很长时间 一个月打了 93h 之多…

第八章——软件工程基础知识

软件工程概述,软件开发模型,软件开发方法,需求分析,系统设计,系统测试,软件开发项目管理,软件质量,软件度量第八章——软件工程基础知识 软件工程概述 软件开发模型 软件开发方法 需求分析 系统设计 系统测试 软件开发项目管理 软件质量 软件度量

Linux 中如何设置每个特定的时间执行特定的程序

那会突然想到一个问题,如何每隔一段时间执行特定的程序。想到了如下的一种方法: 测试如下: 一个小问题,比如 每隔5秒统计一个特定文件的行数 001、[b20223040323@admin1 test]$ ls false.gff pan.fna pan.fna.fai record.sh true.gff variable.gff x_variable_protei…

TextMeshPro - 艺术字(图片字)

1、首先要有一张包含了图片字的图集,每个图片字一个Spirte 2、然后右键 -> 创建创建好的TMP_Sprite Asset 3、编辑Sprite Character Table 调整顺序,将index和图片数字对上 修改下Unicode值(默认都是0xFFFE),比如9的Unicode为0x0039。(注意:填写完后,按Enter没用,…

注册表延长Windows更新时间

打开注册表【Win】+【R】打开运行窗口输入regedit在输入框中输入计算机\HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\WindowsUpdate\UX\Settings后回车在右侧空白处选择新建->DWORD(32位)值(D)命名为FlightSettingsMaxPauseDays,选中10进制数据数值为暂停更新的天数。 确定后关…

Face Detection API

一个针对图像中的人脸进行识别的底层加速平台组件<!DOCTYPE html> <html lang="en"><head><meta charset="UTF-8" /><meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0…

如果你还不了解 Java Class 文件结构,来看看这篇吧

文章首发于【Java天堂】,跟随我探索Java进阶之路!Class文件是什么 Java Class文件是Java编译器将源代码编译后的二进制表示,它是Java虚拟机(JVM)运行的基础。 Class文件绝大部分内容是在1997年发布的第一版《Java虚拟机规范》中就已经定义好的,后续20多年的发展过程当中J…