ARM指令集----杂项指令

ARM指令集可以分为6类,即是跳转指令,数据处理指令,程序状态传输指令,Load、Store指令,协处理器指令和异常中断指令

跳转指令:

在ARM中有两种方式可以实现程序的跳转,一种是跳转指令,另一种是直接向PC寄存器写入目标地址的值

通过直接向PC寄存器写入目标寄存器的数字可以实现在4GB 地址空间的任意跳转,这种跳转又称为长跳转,如果在残肢令前面使用MOV
LR,PC等指令,可以保存返回来的地址值,这样就实现了在4GB空间中的子程序调用

ARM的跳转指令可以从当前指令向前或者是向后的32位的地址进行空间跳转,这类跳转指令有一下4种

B 跳转指令

BL带换回的跳转指令

BLX 带返回的跳转和切换指令

BX 带状态切换的跳转指令

B和BL的区别在于,L决定是否将PC寄存器的数字保存到LR寄存器中,

BL指令用于实现子程序的调用,子程序的返回地址可以将LR寄存器的值复制到PC寄存器来实现

数据处理指令

数据处理指令包括如下指令

  MOV  数据传送指令

  MVN  数据求反传送指令:MVN指令有以下用途:先寄存器传递一个负数,生成位的掩码,求一个数的反码

  CMP   比较指令:

  CMN  基于相反数的比较指令

  TST  位测试指令 :TST指令通常是用于测试寄存器中某些位是1还是0

  TEQ  测试相等指令:TEQ用来比较两个数是否相等ORR指令

  ADD 加法指令 :典型应用ADD RX,RX,#1         // RX =
RX+1

              ADD RD,RX,lSL#n     //RX= RX+RX*(2*n)

              ADD RS,PC,#oFFSET //生成基于PC的跳转指令

  SUB 减法指令 典型用法:SUB RX,RX,#1           // Rx=
Rx-1

  RSB 逆向减法指令 :逆向减法指令,RSB RD,RX,#0,  //RD = -Rx

  ADC 带进位加法指令  :带进位的加法指令,用于实现64位+64位的加法操作

  SBC 带进位减法指令  :带进位的加法指令,用于实现64位+64位的减法操作

  RSC 带逆向减法指令 :带进位的逆向相减指令

  AND 逻辑与操作
:AND指令可以用于提取寄存器的某些位的值,具体做法是设置一个掩码值,将该值中的对应寄存器欲提取的位设置为1,其余的设置成0,将该寄存器与上该掩码值就可以得到提取的位操作

  BIC 位清除指令:BIC指令可以用于寄存器的某些位的值设置为0,将某些与1做BIC操作,该位被轻微0,将某些位与 0 操作,该位置不变

  EOR 逻辑异或指令:某位与0做异或操作,该位不变,某位与1做异或操作,该位取反

  ORR
逻辑或操作指令:ORR指令主要是用于将寄存器的某些位设置成1,具体做法是设置一个掩码值,将该寄存器中与提取的位设置为1,其他的位设置为0,将该寄存器的值与该掩码值做逻辑或操作即可

   乘法指令:

    ARM有两类乘法指令,1类为32位的乘法指令,即是乘法操作的结果为32位,另一类是64位的乘法指令,即是操作结果位64位,两类指令共有以下6条

    MUL 32位乘法指令

    MLA 32位带加法的的乘法指令

    SMULL 64位有符号乘法指令

    SMLAL 64位有符号带加法的乘法指令

    UMULL 64位无符号乘法指令

    UMLAL 64位无符号带加法乘法指令

示例代码:

    


MUL:
    MUL R0,R1,R2 ;R0 = R1*R2
    MULS R0,R1,R2; R0=R1*R2,同时设置CPSR中的N位和Z位

    MLA:
    MLA R0,R1,R2,R3 R0=R1*R2+R3
    

    SMULL:
    SMULL R1,R2,R3,R4 ;R1 = R3*R4 的低32位
               R2= R3*R4的高32位
    UMULL
    UMULL R1,R2,R3,R4 ;R1 = R3*R4 的低32位

                R2= R3*R4的高32位 也就是说R2R1 = R3*R4

    UMLAL R1,R2,R3,R4 ;R2R1 = R3*R4+R2R1

杂项算术指令

CLZ 用于计算操作数最高端0的个数,这条指令主要用于一下两个场合

  计算操作数规范化(使其最高位为1)时需要左移的位数

  确定一个优先级掩码中最高优先级

CLZ指令用于计算寄存器中操作数的最高位0的个数,如果操作数的bit[31]为1,则返回0,如果操作数为0 ,则指令返回32

转载请注明链接地址:http://www.cnblogs.com/fengdashen/p/3728564.html

ARM指令集----杂项指令,布布扣,bubuko.com

时间: 2024-10-09 12:09:46

ARM指令集----杂项指令的相关文章

ARM指令集—SWP指令

SWP和SWPB是ARM指令集中对存储单元的原子操作,即对存储单元的一次读和一次不可被分割.SWP和SWPB分别完成存储器和寄存器之间 一个字(32bit)和一个字节(8bit)的数据交换. SWP指令主要是完成ARM体系架构处理器的同步操作,在Linux操作系统中实现信号量的操作.但是此指令在ARMv6架构后就没有采用了,而是通过扩展的LDREX和STREX实现.本片文章主要介绍SWP的功能,对于LDREX和STREX以后再介绍. SWP的指令格式如下: SWP {}{B}  Rd,  Rm,

ARM指令集——跳转指令

ARM 汇编指令条件执行 在ARM模式下,任何一条数据处理指令可以选择是否根据操作的结果来更新CPSR寄存器中的ALU状态标志位.在数据处理指令中使用S后缀来实现该功能. 不要在CMP,CMN,TST或者TEQ指令中使用S后缀.这些比较指令总是会更新标志位. 在Thumb模式下,所有数据处理指令都更新CPSR中的标志位.有一个例外就是:当一个或更多个高寄存器被用在MOV和ADD指令时,此时MOV和ADD不能更新状态标志. 几乎所有的ARM指令都可以根据CPSR中的ALU状态标志位来条件执行.参见

【汇编指令】ARM指令集之PSR传送指令

ARM指令集提供了两条指令,可直接控制程序状态寄存器(PSR,Program State Register).MRS指令用于把CPSR或SPSR的值传送到一个寄存器:MSR与之相反,把一个寄存器的内容传送到CPSR或SPSR.这两条指令结合,可用于对CPSR和SPSR进行读/写操作. cpsr_c代表的是这32位中的低8位,也就是控制位 CPSR有4个8位区域:标志域(F).状态域(S).扩展域(X).控制域(C) 通过一般示例如下观察PSR指令的相关操作: 1 > [切换到IRQ模式] 2 >

ARM指令集、Thumb指令集、Thumb-2指令集

MCU使用什么指令集主要由内核决定的,比如Cortex-M3使用的是Thumb-2指令集 ARM指令集: 编代码全部是 32bits 的,每条指令能承载更多的信息,因此使用最少的指令完成功能, 所以在相同频率下运行速度也是最快的, 但也因为每条指令是32bits 的而占用了最多的程序空间. Thumb指令集: 编代码全部是 16bits 的,每条指令所能承载的信息少,因此它需要使用更多的指令才能完成功能, 因此运行速度慢, 但它也占用了最少的程序空间 Thumb-2指令集:在前面两者之间取了一个

Thumb指令集与ARM指令集的差别

Thumb指令集 Thumb指令能够看做是ARM指令压缩形式的子集.是针对代码密度[1]的问题而提出的.它具有16为的代码密度.Thumb不是一个完整的体系结构,不能指望处理程序仅仅运行Thumb指令而不支持ARM指令集. 因此.Thumb指令仅仅须要支持通用功能.必要时,可借助完好的ARM指令集,比如:全部异常自己主动进入ARM状态. 在编写Thumb指令时.先要使用伪指令CODE16声明,并且在ARM指令中要使用BX指令跳转到Thumb指令,以切换处理器状态.编写ARM指令时,可使用伪指令C

ARM重要汇编指令记录

IMPORT ,定义表示这是一个外部变量的标号,不是在本程序定义的EXPORT ,表示本程序里面用到的变量提供给其他模块调用的.以上两个在汇编和C语言混合编程的时候用到 ENDP    表示PROC所定义的过程结束. (end procedure)ENDS    表示SEGMENT定义的段结束.   (end segment)END     程序结束. B.BL.BX.BLX 和 BXJ跳转.带链接跳转.跳转并切换指令集.带链接跳转并切换指令集.跳转并转换到 Jazelle 状态. 状态寄存器传

ARM指令集学习总结-转载

ARM指令集比较简单,本文介绍ARM指令集中需要注意和不易理解的地方. 一.ARM指令集是32位的,程序的启动都是从ARM指令集开始,包括所有异常中断都是自动转化为ARM状态,并且所有的指令都可以是有条件执行的.         二.ARM指令集是Load/Store型的,只能通过Load/Store指令实现对系统存储器的访问,而其他的指令都是基于处理器内部的寄存器操作完成的,这和INTEL汇编是不同的,初学者很不易理解.        三.指令的后缀:     "S"  可选后缀,若

S3C6410 Memory Map & ARM 指令集 笔记

Memory Map &  指令集 上面这幅图表明了 Main memory  物理地址空间和各个控制器之间的关系, 例如,0x 0000 0000 ~ 0x07FF FFFF之间的地址空间属于Int.ROM控制器 SROM控制器 和One NAND控制器寻址的空间,其余的以此类推.具体的细节和内存子系统有关系. 图中标注有2的方框表示这个地址空间既能SROM控制器或OneNAND 控制器,至于具体给谁,这取决于系统控制器 6410 支持 32-bit 的物理地址空间,这部分地址空间可以被划分为

Android上学习ARM指令集之开篇

工作中经常碰到crash的问题,如果是Debug版本,有源代码,那还好,调试信息多.万一Release给QA甚至客户之后,再发现crash之类的问题,如果不熟悉ARM指令.看不懂现场,那调试起来可就费劲了.往往只能到处去猜,相信大家都有过这种难过的经历. 这段时间比较闲,正好利用起来为入门ARM指令集写点初级文章,没什么远大理想,写到哪里算哪里,权当娱乐罢了. 环境准备:现在的学习环境可真是方便啊,几乎人手一台android手机,而绝大多数手机都是ARM家族的,所以只需要给手机或者平板电脑安装一