一文搞懂 ARM 64 系列: ADC
1 指令语法
复制代码
2 指令语义
adc
就是带「进位」加法,指令中的c
就是英文carry
。
整个指令等价于:
复制代码
也就是将寄存器Xn
,寄存器Xm
,PSTATE
中的「进位」标志相加,将相加的结果写入寄存器Xd
,但是丢弃相加产生的「进位」。
也就是说,adc
指令只是使用PSTATE
中的「进位」标志,但是最终结果不影响PSTATE
中的「进位」标志。
3 PSTATE
上面代码中PSTATE
是Process State
,存储着ARM CPU
运行时的一些状态。
PSTATE
中最常见的状态就是 NZCV
:
复制代码
要表示PSTATE
中的某一标志,比如「进位」,可以写成PSTATE.C
。
PSTATE
除了NZCV
这4
个标志外,还有其他标志。
如果将PSTATE
定义成一个结构体,可以表示为:
复制代码
可以看到,PSTATE
在ARM64
和ARM32
中不一样。有些标志在ARM64
和ARM32
都存在,有些却只在ARM64
或者ARM32
中单独存在。
同时,不同版本的ARM
架构,PSTATE
也不一样,比如标志BTYPE
就存在ARMv8.5
版本中。
4 查看 PSTATE
按照ARM
文档,在ARM32
下只能通过CPSR
寄存器查看PSTATE
的部分标志。
ARM64
想要查看PSTATE
,不同的标志都有单独对应的寄存器。比如查看NZCV
标志,就有NZCV
寄存器,ARM64
下已没有CPSR
寄存器。
复制代码
CPSR
是32bit
寄存器,结构如下:
但是在实践过程中,iPhone 13 pro
是64bit
的ARM
架构处理器,但是却提供了CPSR
寄存器,而不能访问比如NZCV
寄存器:
复制代码
文章转载自:chaoguo1234
评论