arm add指令
ARM 汇编中的 ADD 指令是用于加法运算的核心指令。它的基本功能是将两个操作数相加,并将结果存储到目标寄存器中。以下是关键细节和使用示例(使用 A32/T32 语法):
基本格式
ADD{<cond>}{S} <Rd>, <Rn>, <Operand2>
{<cond>}:可选条件码(如EQ,NE,GT等),根据CPSR标志决定是否执行。{S}:可选标志,表示指令执行结果影响CPSR寄存器(包括N-负数,Z-零,C-进位,V-溢出)。<Rd>:目标寄存器,用于存储加法结果。<Rn>:第一个操作数寄存器。<Operand2>:第二个操作数,具有极高的灵活性。
Operand2 的形式
Operand2 可以是以下形式之一:
-
立即数 (Immediate):
- 一个数值常量(如
#10)。 - 在 A32 中,必须是8位数值旋转偶数位得到(如
0xFF000000有效,0x123可能无效)。 - 在 T32 中,范围限制更宽松但仍有约束(如
ADD R0, R1, #0xAB)。ADD R0, R1, #42 @ R0 = R1 + 42
- 一个数值常量(如
-
寄存器 (Register):
- 另一个寄存器的值(如
R2)。ADD R0, R1, R2 @ R0 = R1 + R2
- 另一个寄存器的值(如
-
移位的寄存器 (Shifted Register):
- 一个寄存器经过移位或循环移位后的值。移位类型包括:
LSL:逻辑左移LSR:逻辑右移ASR:算术右移ROR:循环右移RRX:带扩展的循环右移1位
- 移位量可以是立即数或另一个寄存器的值。
ADD R0, R1, R2, LSL #3 @ R0 = R1 + (R2 * 8) 相当于逻辑左移3位 ADD R0, R1, R2, LSR R3 @ R0 = R1 + (R2 逻辑右移 R3 指定的位数)
- 一个寄存器经过移位或循环移位后的值。移位类型包括:
主要功能与作用
- 寄存器加法:将两个寄存器的值相加。
- 寄存器加立即数:将寄存器值与立即数常量相加。
- 地址计算:常用于计算内存地址(结合基址寄存器
Rn和偏移量Operand2)。 - 修改栈指针:常用
ADD SP, SP, #size释放栈空间。 - 影响标志位 (加
S后缀):N(Negative):结果为负时置1Z(Zero):结果为零时置1C(Carry):加法产生进位时置1V(oVerflow):有符号加法溢出时置1
示例代码
- 基础加法:
ADD R0, R1, R2 @ R0 = R1 + R2 (不改变CPSR) - 立即数加法并设置标志:
ADDS R3, R3, #10 @ R3 = R3 + 10, 结果影响标志位(CPSR)。 - 带移位的加法:
ADD R0, R1, R2, LSL #2 @ R0 = R1 + (R2 * 4) - 栈操作:
ADD SP, SP, #16 @ 栈指针SP向上移动16字节(释放空间)
ARM64 (A64) 的区别
在 ARMv8-A 的64位模式中,ADD 指令遵循类似逻辑,但有显著变化:
- 寄存器名为
Wn(32位) 或Xn(64位)。 - 立即数范围更大,格式不同。
- 有专门的
ADD和ADDS指令,ADDS会更新标志位。ADD X0, X1, X2 @ X0 = X1 + X2 (64位) ADDS W3, W4, #255 @ W3 = W4 + 255, 更新标志位
总结
ARM ADD 是一个高度灵活的加法指令,通过可选的 条件执行、标志设置 和 复杂的第二操作数(立即数/寄存器/移位寄存器),实现了强大的数学和寻址能力。它是ARM汇编编程中最常用的指令之一。具体支持的格式取决于所使用的ARM指令集(A32, T32, A64)。
讲讲ARM指令集格式以及常用的ARM汇编指令
对于搞嵌入式驱动或者操作系统的人来说,掌握汇编语言的使用还是比较重要的,毕竟有时候在分析定位问题的时候,多多少少都会有汇编的身影。本文主要讲讲ARM指令集格式以及常用的
2023-11-08 12:34:22
ARM汇编指令(6)——批量数据加载/存储指令资料下载
电子发烧友网为你提供ARM汇编指令(6)——批量数据加载/存储指令资料下载的电子资料下载,更有其他相关的电路图、源代码、课件教程、中文资料、英文
资料下载
h1654155275.3301
2021-04-23 08:46:23
ARM MOV和LDR的指令关系是怎么样的
ARM是RISC结构,数据从内存到CPU之间的移动只能通过L/S指令来完成,也就是ldr/str指令比如想把数据从内存中某处读取到寄存器中,只能
资料下载
佚名
2019-05-16 18:05:00
介绍一些MOV与ADD指令的简单例子
因为嵌入式系统学习需要,开始学习汇编语言学习资料是B站的视频:汇编语言程序 P9目录一、一些简单的指令例子二、一个练习一、一些简单的指令例子下图是一些简单的MOV 与
ADD加法指令相关资料分享
ADD 指令将< shifter_operand > 表示的数据与寄存器< Rn >中的值相加,并把结果保存到目标寄存器< Rd > 中,同时根据操作的结果更新
【工程源码】ARM汇编指令 连载一
快很多。我现在看一些执行起来很奇怪的代码,就直接看看对应的汇编部分,很多C语言中不易发现的问题,汇编一目了然。相信了解过arm汇编的都听说过ARM指令
换一换
- 如何分清usb-c和type-c的区别
- 中国芯片现状怎样?芯片发展分析
- vga接口接线图及vga接口定义
- 芯片的工作原理是什么?
- 华为harmonyos是什么意思,看懂鸿蒙OS系统!
- 什么是蓝牙?它的主要作用是什么?
- ssd是什么意思
- 汽车电子包含哪些领域?
- TWS蓝牙耳机是什么意思?你真的了解吗
- 什么是单片机?有什么用?
- 升压电路图汇总解析
- plc的工作原理是什么?
- 再次免费公开一肖一吗
- 充电桩一般是如何收费的?有哪些收费标准?
- ADC是什么?高精度ADC是什么意思?
- EDA是什么?有什么作用?
- dtmb信号覆盖城市查询
- 苹果手机哪几个支持无线充电的?
- type-c四根线接法图解
- 华为芯片为什么受制于美国?
- 怎样挑选路由器?
- 元宇宙概念股龙头一览
- 锂电池和铅酸电池哪个好?
- 什么是场效应管?它的作用是什么?
- 如何进行编码器的正确接线?接线方法介绍
- 虚短与虚断的概念介绍及区别
- 晶振的作用是什么?
- 大疆无人机的价格贵吗?大约在什么价位?
- 苹果nfc功能怎么复制门禁卡
- amoled屏幕和oled区别
- 单片机和嵌入式的区别是什么
- 复位电路的原理及作用
- BLDC电机技术分析
- dsp是什么意思?有什么作用?
- 苹果无线充电器怎么使用?
- iphone13promax电池容量是多少毫安
- 芯片的组成材料有什么
- 特斯拉充电桩充电是如何收费的?收费标准是什么?
- 直流电机驱动电路及原理图
- 传感器常见类型有哪些?
- 自举电路图
- 通讯隔离作用
- 苹果笔记本macbookpro18款与19款区别
- 新斯的指纹芯片供哪些客户
- 伺服电机是如何进行工作的?它的原理是什么?
- 无人机价钱多少?为什么说无人机烧钱?
- 以太网VPN技术概述
- 手机nfc功能打开好还是关闭好
- 十大公认音质好的无线蓝牙耳机
- 元宇宙概念龙头股一览