ARM汇编之数据处理指令

ARM汇编之数据处理指令

前言

首先,请问大家几个小小问题,你清楚:

  • ARM汇编中有关数据处理的相关指令有哪些吗?
  • 数据处理指令可以分为哪几类呢?

今天,我们来一起探索并回答这些问题。为了便于大家理解,以下是本文的主题大纲:

在这里插入图片描述


正文

数据传送指令

MOV:数据传输指令

MOV指令的作用如下:

  • 将数据从一个寄存器传送至另一个寄存器;
  • 将一个常数传送至一个寄存器;
  • 实现单纯的移位操作,左移操作可以实现操作数乘以2的n次方;
  • 当PC作为目标寄存器,可直接实现程序的跳转;

MOV指令格式与实例展示如下:

在这里插入图片描述

图1 MOV指令格式说明与实例

MVN:数据求反传送指令

MVN指令的主要作用如下:

  • 向寄存器传送一个负数;
  • 生成位掩码;
  • 求一个数的反码;

MVN指令格式与实例展示如下:

在这里插入图片描述

图2 MVN指令格式说明与实例

其中上图中的0x4用二进制数(0x00000100)表示, 然后对其取反得到(0x11111011),可见取反后为负数,因此针对负数求其补码则为储存在R0中的值,先将负数最高位转换为正数(01111011)取反,得到(10000100),加1得到其补码,最后结果为(10000101),即结果为-5;

算法逻辑运算指令

算法逻辑运算涉及到加减乘除,位操作等操作,这些都是汇编语言经常会使用到指令,掌握这些基本指令对分析问题产生很多帮助。

ADD:加法指令

ADD指令顾名思义就是加法指令,目的就是为了实现两个操作数进行相加。

ADD指令格式与实例展示如下:

在这里插入图片描述

图3 ADD指令格式说明与实例

如上图所示,ADD指令就是将<shift_operand>表示的数据与寄存器中的值相加,并把结果保存到目标寄存器中,同时根据操作的结果更新CPSR中相应的条件标志位。

SUB:减法指令

SUB指令就是为了实现两个操作数相减。

SUB指令格式与实例展示如下:

在这里插入图片描述

图4 ADD指令格式说明与实例

如上图所示,SUB指令就是从中减去<shift_operand>表示的数值,并把结果保存至目标寄存器中中,同时,根据操作的结果更新CPSR中的相应的条件标志位;

当SUBS指令与跳转指令结合使用时,便可以实现成循环程序,这样就不需要CMP指令了。

RSB:逆向减法指令

RSB指令用于实现两个数相减。

RSB指令格式与实例展示如下:

在这里插入图片描述

图5 RSB指令格式说明与实例

如上图所示,RSB指令可以从<shifter_operand>表示的数值中减去寄存器值,并把结果保存到目标寄存器中,同时根据操作的结果更新CPSR中相应的条件标志位。

ADC:带位加法指令

ADC指令和ADD指令结合使用,可以实现两个64位的操作数相加。

ADC指令格式与实例展示如下:

在这里插入图片描述

图6 ADC指令格式说明与实例

SBC:带位减法指令

SBC指令与SUBS指令可以联合使用,来实现两个64位的操作数相减。

SBC指令格式与实例展示如下:

在这里插入图片描述

图7 SBC指令格式说明与实例

需要注意的是在SBCS指令中,如果发生了借位操作,CPSR寄存器中的C标志位设置为0;如果没有发生借位操作,CPSR寄存器中的C标志位设置为1。

RSC:带位逆向减法指令

RSC指令将<shifter_operand>表示的数值减去寄存器的值,再减去寄存器CPSR中C条件标志位的反码,并把结果保存到目标寄存器z中,同时,根据操作的结果更新CPSR寄存器中的条件标志位。

RSC指令格式与实例展示如下:

在这里插入图片描述

图8 RSC指令格式说明与实例

AND:逻辑与操作指令

AND指令就是将如下<shifter_operand>表示的数值与寄存器的值按位做逻辑与操作,并把结果保存到目标寄存器中,同时根据是否存在S来决定是否将操作的结果更新CPSR寄存器的条件标志位中的值。

AND指令格式与实例展示如下:

在这里插入图片描述

图9 ADD指令格式说明与实例

BIC:位清除指令

BIC指令就是将<shifter_operand>表示的数值与寄存器的值的反码按位做逻辑与操作,并把结果保存到目标寄存器中,同时根据操作的结果更新CPSR中的相应的条件标志位。

BIC指令格式与实例展示如下:

在这里插入图片描述

图10 BIC指令格式说明与实例

EOR:逻辑异或操作指令

EOR指令就是将<shifter_operand>表示的数值与寄存器的值按位做逻辑异或操作,并将结果保存进目标寄存器中,同时,根据操作的结果更新CPSR中相应的条件标志位。

EOR指令格式与实例展示如下:

在这里插入图片描述

图11 EOR指令格式说明与实例

ORR:逻辑或操作指令

ORR指令就是将<shifter_operand>表示的数值与寄存器的值按位做逻辑或操作,并将结果保存至目标寄存器中,同时,根据操作的结果更新CPSR中相应的条件标志位。

ORR指令格式与实例展示如下:

在这里插入图片描述

图12 ORR指令格式说明与实例
比较指令

CMP:比较指令

CMP指令就是从寄存器中减去表示的数值,根据操作的结果更新CPSR中的条件标志位,该更新是默认更新,无需是否添加"S"。

CMP指令格式与实例展示如下:

在这里插入图片描述

图13 CMP指令格式说明与实例

CMN:基于相反数的比较指令

CMN指令是指将寄存器中的值加上<shifter_operand>表示的数值,根据操作的结果更新CPSR中的条件标志位,该更新是默认更新,无需是否添加"S"。

CMN指令格式与实例展示如下:

在这里插入图片描述

图14 CMN指令格式说明与实例

TST:位测试指令

TST指令是将<shifter_operand>表示的数值与寄存器的值按位做逻辑与操作,根据操作的结果更新CPSR中相应的条件标志位。

TST指令格式与实例展示如下:

在这里插入图片描述

图15 TST指令格式说明与实例

TST指令通常用于测试寄存器中某些位是1还是0,一般会与BEQ或者BNE指令配合使用完成条件判断跳转功能。

TEQ:相等测试指令

TEQ指令就是将<shifter_operand>表示的数值与寄存器的值按位做逻辑异或操作,根据操作的结果更新CPSR中相应的条件判断位。

TEQ指令格式与实例展示如下:

在这里插入图片描述

图16 TEQ指令格式说明与实例

TEQ指令通常用来判断两个数是否相等,但这种比较操作不会影响到CPSR寄存器中的V位跟C位;同时,TEQ指令也可用于比较操作数符合是否相同,该指令执行后,CPSR寄存器中的N位位两个操作数符号位做异或的结果。

ARM指令条件码

为提高代码密度,减少ARM指令的数量,几乎所有的ARM指令可以根据CPSR寄存器中的标志位,通过指令组合实现条件执行。

如无条件跳转指令B,我们在其后添加条件码就可组成BEQ,BNE组合指令。BEQ指令表示如何两个数比较,结果相等时则跳转,BNE指令则表示结果不相等时跳转了。

因此有必要将ARM指令条件码列举于此,方便大家及时查阅,及时了解指令的含义以及是否可以被执行。一般而言,条件执行经常出现在跳转或者循环的程序结构中。

在这里插入图片描述

图17 ARM条件码列表
  • 1
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
学习ARM汇编指令的经典资料。 对ARM的各种汇编指令进行了深入全面的讲解,并给出了各种示例和详细注解,并且还对一些值得注意的点或是容易犯错误的地方进行了总结。 目录 前言................................................................................................................................................................i 目录................................................................................................................................................................I ARM7TDMI(-S)指令集及汇编....................................................................................................................1 ARM处理器寻址方式..........................................................................................................................2 寄存器寻址....................................................................................................................................2 立即寻址........................................................................................................................................2 寄存器偏移寻址............................................................................................................................2 寄存器间接寻址............................................................................................................................3 基址寻址........................................................................................................................................3 多寄存器寻址................................................................................................................................4 堆栈寻址........................................................................................................................................4 块拷贝寻址....................................................................................................................................5 相对寻址........................................................................................................................................5 指令集介绍............................................................................................................................................7 ARM指令集..................................................................................................................................7 指令格式................................................................................................................................7 第2个操作数................................................................................................................7 #immed_8r...........................................................................................................7 Rm..........................................................................................................................8 Rm,shift..................................................................................................................8 条件码............................................................................................................................9 ARM存储器访问指令........................................................................................................11   LDR和STR........................................................................................................11   LDM和STM.......................................................................................................14   SWP.....................................................................................................................17 ARM数据处理指令............................................................................................................19 数据传送指令..............................................................................................................20   MOV............................................................................................................20   MVN............................................................................................................20 算术逻辑运算指令......................................................................................................20   ADD.............................................................................................................20   SUB..............................................................................................................21   RSB..............................................................................................................21   ADC.............................................................................................................21   SBC..............................................................................................................21   RSC..............................................................................................................22   AND.............................................................................................................22   ORR..............................................................................................................22   EOR..............................................................................................................22   BIC...............................................................................................................23 比较指令......................................................................................................................23   CMP.............................................................................................................23   CMN.............................................................................................................23   TST...............................................................................................................24   TEQ..............................................................................................................24 乘法指令......................................................................................................................25   MUL.............................................................................................................25   MLA.............................................................................................................25   UMULL........................................................................................................25   UMLAL........................................................................................................26   SMULL........................................................................................................26   SMLAL........................................................................................................26 ARM跳转指令....................................................................................................................27   B...........................................................................................................................27   BL.........................................................................................................................27   BX........................................................................................................................27 ARM协处理器指令............................................................................................................28   CDP......................................................................................................................28   LDC......................................................................................................................29   STC......................................................................................................................29   MCR.....................................................................................................................30   MRC.....................................................................................................................30 ARM杂项指令....................................................................................................................31   SWI......................................................................................................................31   MRS.....................................................................................................................32   MSR.....................................................................................................................33 ARM指令........................................................................................................................34   ADR.....................................................................................................................35   ADRL...................................................................................................................35   LDR......................................................................................................................36   NOP......................................................................................................................37 Thumb指令集.............................................................................................................................39 Thumb指令集与ARM指令集的区别..............................................................................39 Thumb存储器访问指令.....................................................................................................40   LDR和STR........................................................................................................41   PUSH和POP......................................................................................................43   LDMIA和STMIA..............................................................................................43 Thumb数据处理指令.........................................................................................................45 数据传送指令..............................................................................................................46   MOV............................................................................................................46   MVN............................................................................................................46   NEG..............................................................................................................47 算术逻辑运算指令......................................................................................................47   ADD.............................................................................................................47   SUB..............................................................................................................48   ADC.............................................................................................................49   SBC..............................................................................................................49   MUL.............................................................................................................50   AND.............................................................................................................50   ORR..............................................................................................................50   EOR..............................................................................................................51   BIC...............................................................................................................51   ASR..............................................................................................................51   LSL...............................................................................................................52   LSR..............................................................................................................52   ROR..............................................................................................................53 比较指令......................................................................................................................53   CMP.............................................................................................................53   CMN.............................................................................................................54   TST...............................................................................................................54 Thumb跳转指令.........................................................................................................55   B...................................................................................................................55   BL.................................................................................................................55   BX................................................................................................................55 Thumb杂项指令.........................................................................................................56   SWI..............................................................................................................56 Thumb伪指令.............................................................................................................57   ADR.............................................................................................................57   LDR..............................................................................................................57   NOP..............................................................................................................58 伪指令..................................................................................................................................................59 符号定义伪指令..........................................................................................................................59   GBLA、GBLL、GBLS..............................................................................................59   LCLA、LCLL、LCLS................................................................................................60   SETA、SETL、SETS.................................................................................................61   RLIST...........................................................................................................................61   CN................................................................................................................................62   CP.................................................................................................................................62   DN、SN.......................................................................................................................62   FN.................................................................................................................................63 数据定义伪指令..........................................................................................................................63   LTORG.........................................................................................................................64   MAP.............................................................................................................................64   FIELD..........................................................................................................................65   SPACE..........................................................................................................................66   DCB.............................................................................................................................66   DCD和DCDU............................................................................................................67   DCDO..........................................................................................................................67   DCFD和DCFDU........................................................................................................68   DCFS和DCFSU.........................................................................................................68   DCI...............................................................................................................................69   DCQ和DCQU............................................................................................................69   DCW和DCWU..........................................................................................................70 报告伪指令..................................................................................................................................70   ASSERT.......................................................................................................................70   INFO............................................................................................................................71   OPT..............................................................................................................................71   TTL和SUBT..............................................................................................................72 汇编控制伪指令..........................................................................................................................73   IF、ELSE和ENDIF...................................................................................................73   MACRO和MEND.....................................................................................................74   WHIL和WEND.........................................................................................................75 杂项伪指令..................................................................................................................................76   ALIGN.........................................................................................................................77   AREA...........................................................................................................................78   CODE16和CODE32..................................................................................................79   END.............................................................................................................................80   ENTRY.........................................................................................................................80   EQU.............................................................................................................................81   EXPORT和GLOBAL................................................................................................81   IMPORT和EXTERN.................................................................................................82   GET和INCLUDE......................................................................................................83   INCBIN........................................................................................................................83   KEEP............................................................................................................................83   NOFP...........................................................................................................................84   REQUIRE....................................................................................................................84   PEQUIRE8和PRESERVE8.......................................................................................84   RN................................................................................................................................84   ROUT...........................................................................................................................85 ARM指令................................................................................................................................86   ADR.............................................................................................................................86   ADRL...........................................................................................................................86   LDR..............................................................................................................................86   NOP..............................................................................................................................86   LDFD...........................................................................................................................86   LDFS............................................................................................................................87 Thumb伪指令.............................................................................................................................87   ADR.............................................................................................................................87   LDR..............................................................................................................................87   NOP..............................................................................................................................88 ARM汇编程序设计............................................................................................................................88 文件格式......................................................................................................................................88 ARM汇编的一些规范................................................................................................................88 汇编语句格式......................................................................................................................88 标号......................................................................................................................................89   基于PC的标号...................................................................................................89   基于寄存器的标号..............................................................................................90   绝对地址..............................................................................................................90 局部标号..............................................................................................................................90 符号......................................................................................................................................91 常量......................................................................................................................................91   数字常数..............................................................................................................91   字符常量..............................................................................................................92   布尔常量..............................................................................................................92 段定义..................................................................................................................................92 宏定义及其作用..................................................................................................................93 子程序的调用..............................................................................................................................94 数据比较跳转..............................................................................................................................95 循环..............................................................................................................................................95 数据块复制..................................................................................................................................95 栈操作..........................................................................................................................................96 特殊寄存器定义及应用..............................................................................................................96 散转功能......................................................................................................................................97 查表操作......................................................................................................................................97 长跳转..........................................................................................................................................97 对信号量的支持..........................................................................................................................98 伪指令使用..................................................................................................................................98 一个完整的例子..........................................................................................................................98 外围部件控制..............................................................................................................................99 三级流水线介绍..........................................................................................................................99 C与汇编混合编程............................................................................................................................100 内嵌汇编....................................................................................................................................100 内嵌汇编指令用法........................................................................................................103 内嵌汇编器与armasm汇编器的差异.............................................................................104 内嵌汇编注意事项............................................................................................................104 访问全局变量............................................................................................................................106 C与汇编相互调用....................................................................................................................107 寄存器的使用规则............................................................................................................108 堆栈使用规则....................................................................................................................108 参数传递规则....................................................................................................................109 C程序调用汇编程序........................................................................................................110 汇编程序调用C程序.......................................................................................................111 ARM指令集列表..............................................................................................................................113 ARM存储器访问指令表列表..................................................................................................113 ARM数据处理指令列表..........................................................................................................114 ARM乘法指令列表..................................................................................................................115 ARM跳转指令列表..................................................................................................................116 ARM协处理器指令列表..........................................................................................................117 ARM杂项指令列表..................................................................................................................118 ARM指令列表......................................................................................................................119 Thumb指令集列表...........................................................................................................................120 Thumb存储器访问指令列表...................................................................................................120 Thumb数据处理指令列表.......................................................................................................121 Thumb跳转指令及软中断指令列表.......................................................................................122 Thumb伪指令列表...................................................................................................................123 汇编预定义变量及伪指令................................................................................................................124 预定义的寄存器和协处理器名................................................................................................124 通用寄存器........................................................................................................................124 程序状态寄存器................................................................................................................124 浮点数寄存器....................................................................................................................124 协处理器及协处理器寄存器............................................................................................125 内置变量列表............................................................................................................................125 伪指令列表................................................................................................................................126 指令条件码列表........................................................................................................................128 CPSR和SPSR分配图.............................................................................................................................129
原作者:宛城布衣。 本文件已移除PDF签名,如内容有误,欢迎大家指正。 目录 前言 i 目录 I ARM7TDMI(-S)指令集及汇编1 ARM 处理器寻址方式2 寄存器寻址2 立即寻址2 寄存器偏移寻址2 寄存器间接寻址3 基址寻址3 多寄存器寻址4 堆栈寻址4 块拷贝寻址5 相对寻址5 指令集介绍7 ARM 指令集7 指令格式7 第 2 个操作数7 #immed_8r 7 Rm8 Rm,shift8 条件码9 ARM 存储器访问指令 11 LDR 和 STR 11 LDM 和 STM14 SWP 17 ARM 数据处理指令19 数据传送指令20 MOV 20 MVN 20 算术逻辑运算指令20 ADD 20 SUB21 RSB 21 ADC 21 SBC 21 RSC 22 AND 22 ORR22 EOR22 IIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIII BIC 23 第 I 页常用 ARM 指令集及汇编 Ver:1010 比较指令23 CMP 23 CMN23 TST24 TEQ24 乘法指令25 MUL25 MLA25 UMULL25 UMLAL26 SMULL 26 SMLAL 26 ARM 跳转指令27 B27 BL27 BX 27 ARM 协处理器指令28 CDP28 LDC29 STC 29 MCR30 MRC30 ARM 杂项指令31 SWI 31 MRS 32 MSR 33 ARM指令34 ADR 35 ADRL35 LDR36 NOP37 Thumb 指令集39 Thumb 指令集与 ARM 指令集的区别 39 Thumb 存储器访问指令 40 LDR 和 STR 41 PUSH 和 POP 43 LDMIA 和 STMIA 43 Thumb 数据处理指令 45 数据传送指令46 MOV 46 MVN 46 NEG47 算术逻辑运算指令47 ADD 47 IIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIII 第 II 页常用 ARM 指令集及汇编 Ver:1010 SUB48 ADC 49 SBC 49 MUL50 AND 50 ORR50 EOR51 BIC 51 ASR51 LSL52 LSR 52 ROR53 比较指令53 CMP 53 CMN54 TST54 Thumb 跳转指令 55 B 55 BL55 BX 55 Thumb 杂项指令 56 SWI 56 Thumb 伪指令 57 ADR 57 LDR57 NOP58 伪指令59 符号定义伪指令59 GBLA、GBLL、GBLS 59 LCLA、LCLL、LCLS60 SETA、SETL、SETS 61 RLIST61 CN 62 CP62 DN、SN62 FN63 数据定义伪指令63 LTORG64 MAP64 FIELD 65 SPACE66 DCB 66 DCD 和 DCDU67 DCDO 67 IIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIII 第 III 页常用 ARM 指令集及汇编 Ver:1010 DCFD 和 DCFDU68 DCFS 和 DCFSU68 DCI69 DCQ 和 DCQU69 DCW 和 DCWU 70 报告伪指令70 ASSERT 70 INFO 71 OPT 71 TTL 和 SUBT 72 汇编控制伪指令73 IF、ELSE 和 ENDIF73 MACRO 和 MEND 74 WHIL 和 WEND 75 杂项伪指令76 ALIGN 77 AREA78 CODE16 和 CODE32 79 END 80 ENTRY80 EQU 81 EXPORT 和 GLOBAL 81 IMPORT 和 EXTERN 82 GET 和 INCLUDE 83 INCBIN83 KEEP83 NOFP 84 REQUIRE 84 PEQUIRE8 和 PRESERVE8 84 RN 84 ROUT85 ARM指令86 ADR 86 ADRL86 LDR86

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

汽车小T

感谢打赏,我会继续努力奉献精彩

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值