news 2026/6/23 21:41:04

ARM 汇编指令:ORRS

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
ARM 汇编指令:ORRS

ARM 汇编指令:ORRS

在 ARM 架构中,ORRS是一条按位逻辑或(OR)指令,并且会根据操作结果更新条件标志位


1.基本含义

  • ORR= 逻辑或(Bitwise OR)
  • S= 后缀,表示该指令执行后要更新APSR(应用程序状态寄存器)中的条件标志位(主要是 N、Z、C、V 中的相关位)。

指令格式通常为:
ORRS Rd, Rn, Operand2
作用是将RnOperand2按位进行逻辑或运算,结果存入Rd,并更新标志位。


2.运算规则

  • 按位或:Rd = Rn | Operand2
  • Operand2可以是立即数、寄存器或经过移位/旋转的寄存器。

例如:

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.典型用途

  1. 设置特定位检查结果是否为 0 或负数

    ORRS R0, R1, R2 ; 做 OR,同时根据结果设置 Z 和 N BEQ zero_result ; 如果结果为 0 则跳转
  2. 测试两个值的位组合,同时丢弃结果只留标志(常用TST指令更直接,TST本质上就是ANDS但不存结果)。
    ORRS可以类似地用于测试,不过更常见的是用ANDSTST做位测试。

  3. 在需要组合位且同时更新标志以便后续条件执行时使用。


5.与普通 ORR 的区别

  • ORR:只做运算,不更新标志位。
  • ORRS:运算并更新 N、Z、C 标志。

6.示例

MOV R2, #0 ORRS R1, R2, #0 ; R1 = 0,Z = 1, N = 0 BNE somewhere ; 不会跳转,因为 Z=1 表示相等(结果为0)
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在编写需要条件执行的代码时很有用,例如在循环或状态判断中。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/23 19:08:37

Kotaemon水务管理系统智能预警机制

Kotaemon水务管理系统智能预警机制 在城市供水系统中,一次突发的余氯浓度下降可能意味着潜在的水质安全风险。传统模式下,值班人员需要手动查阅操作手册、比对历史工单、联系现场工程师——整个过程往往耗时数十分钟甚至更久。而如今,随着人…

作者头像 李华
网站建设 2026/6/23 19:17:25

Kotaemon视频内容摘要生成实验记录

Kotaemon视频内容摘要生成实验记录 在音视频内容爆炸式增长的今天,如何从数小时的讲座、会议或教学录像中快速提取核心信息,已成为知识工作者和企业面临的一大挑战。传统做法依赖人工听看并撰写摘要,效率低、成本高;而直接使用大语…

作者头像 李华
网站建设 2026/6/23 19:13:15

用Matlab探索齿轮系统的奥秘:刚度计算与动力学响应

Matlab计算齿轮啮合刚度计算,包括赫兹刚度弯曲刚度等子程序。 以及六自由度齿轮系统动力学响应计算。在机械传动领域,齿轮系统扮演着至关重要的角色。深入了解齿轮的啮合刚度以及系统的动力学响应,对于优化设计、提高性能和延长使用寿命都有着…

作者头像 李华
网站建设 2026/6/23 19:15:18

【node阅读-0】下载编译node

一、下载编译-windows build 工具要求安装方式Visual Studio 2022版本 17.13 或更高必须选 “Desktop development with C” workload必须安装 ClangCL 组件:- C Clang Compiler for Windows (Microsoft.VisualStudio.Component.VC.Llvm.Clang)- MSBuild support f…

作者头像 李华
网站建设 2026/6/23 13:06:49

EmotiVoice支持动态情感过渡,实现平滑情绪变化

EmotiVoice:让语音真正“动情”的合成引擎 在虚拟偶像的直播中,一句从温柔期待逐渐转为委屈落泪的台词,让弹幕瞬间刷满“破防了”;在互动叙事游戏中,NPC因玩家选择而情绪骤变,声音颤抖着说出那句“我信任你…

作者头像 李华