ARM 汇编指令:ORRS
本文来自于我关于 ARM 汇编指令系列文章。欢迎阅读、点评与交流~
1、汇编指令在不同架构中的联系与区别
2、ARM 汇编指令:MOV
3、ARM 汇编指令:LDR
4、ARM 汇编指令:STR
5、ARM 汇编指令:MRS 和 MSR
6、ARM 汇编指令:ORRS
在 ARM 架构中,ORRS 是一条按位逻辑或(OR)指令 ,并且会根据操作结果更新条件标志位。
1. 基本含义
- ORR = 逻辑或(Bitwise OR)
- S = 后缀,表示该指令执行后要更新 APSR(应用程序状态寄存器)中的条件标志位(主要是 N、Z、C、V 中的相关位)。
指令格式通常为:
ORRS Rd, Rn, Operand2
作用是将 Rn 和 Operand2 按位进行逻辑或运算,结果存入 Rd,并更新标志位。
2. 运算规则
- 按位或:
Rd = Rn | Operand2 Operand2可以是立即数、寄存器或经过移位/旋转的寄存器。
例如:
assembly
ORRS R1, R2, R3 ; R1 = R2 | R3,并更新标志位
ORRS R0, R0, #0x8 ; 将 R0 的 bit3 置 1,并更新标志位
3. 影响的条件标志位
执行 ORRS 后会更新:
- N(Negative):结果的最高位(bit31)为 1 则置 1。
- Z(Zero):结果为 0 则置 1。
- C(Carry) :如果
Operand2是立即数或移位寄存器,则标志可能由移位器的进位输出更新(与ORR不带 S 时相同,但 ORRS 会写入 APSR)。 - V(Overflow):不受影响(保持原值)。
4. 典型用途
-
设置特定位 并检查结果是否为 0 或负数。
assemblyORRS R0, R1, R2 ; 做 OR,同时根据结果设置 Z 和 N BEQ zero_result ; 如果结果为 0 则跳转 -
测试两个值的位组合 ,同时丢弃结果只留标志(常用
TST指令更直接,TST本质上就是ANDS但不存结果)。
ORRS可以类似地用于测试,不过更常见的是用ANDS、TST做位测试。 -
在需要组合位且同时更新标志以便后续条件执行时使用。
5. 与普通 ORR 的区别
ORR:只做运算,不更新标志位。ORRS:运算并更新 N、Z、C 标志。
6. 示例
assembly
MOV R2, #0
ORRS R1, R2, #0 ; R1 = 0,Z = 1, N = 0
BNE somewhere ; 不会跳转,因为 Z=1 表示相等(结果为0)
assembly
MOV R2, #0x80000000
ORRS R1, R2, #0 ; R1 = 0x80000000,最高位为1
; 结果不为0 → Z=0
; 最高位为1 → N=1
7. 在 Thumb/Thumb-2 中的可用性
在 ARMv6T2 及更高版本中,大多数形式的 ORRS 在 Thumb-2 中可用(包括窄指令和宽指令)。在早期的 Thumb 中(ARMv4T/ARMv5),ORRS 有受限的寄存器范围(如 ORRS Rd, Rd, Rm,Rd 和 Rm 必须是低寄存器 R0--R7)。
8. 注意
- 如果你只需要置位而不关心标志,用
ORR即可。 - 如果需要测试两个寄存器是否同时为 0 的位模式,更常用
TST Rn, Operand2(即ANDS但不存结果)。 ORRS在编写需要条件执行的代码时很有用,例如在循环或状态判断中。