您的位置 首页 分销

ARM指令集杂项指令

ARM指令集可以分为6类,即是跳转指令,数据处理指令,程序状态传输指令,Load、Store指令,协处理器指令和异常中断指令跳转指令:在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

声明:本文内容来自网络转载或用户投稿,文章版权归原作者和原出处所有。文中观点,不代表本站立场。若有侵权请联系本站删除(kf@86ic.com)https://www.86ic.net/bandaoti/fenxiao/276409.html

为您推荐

联系我们

联系我们

在线咨询: QQ交谈

邮箱: kf@86ic.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部