2022年arm汇编指令集 .pdf





《2022年arm汇编指令集 .pdf》由会员分享,可在线阅读,更多相关《2022年arm汇编指令集 .pdf(15页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、算术和逻辑指令ADC:带进位的加法(Addition with Carry)ADC条件 S,dest=op_1+op_2+carryADC 将把两个操作数加起来,并把结果放置到目的寄存器中。它使用一个进位标志位,这样就可以做比32 位大的加法。下列例子将加两个128 位的数。128 位结果:寄存器0、1、2、和3 第一个128 位数:寄存器4、5、6、和7 第二个128 位数:寄存器8、9、10、和11。ADDS R0,R4,R8;加低端的字ADCS R1,R5,R9;加下一个字,带进位ADCS R2,R6,R10;加第三个字,带进位ADCS R3,R7,R11;加高端的字,带进位如果如果要做
2、这样的加法,不要忘记设置S 后缀来更改进位标志。ADD:加法(Addition)ADD条件 S,dest=op_1+op_2ADD 将把两个操作数加起来,把结果放置到目的寄存器中。操作数1 是一个寄存器,操作数2 可以是一个寄存器,被移位的寄存器,或一个立即值:ADD R0,R1,R2;R0=R1+R2 ADD R0,R1,#256;R0=R1+256 ADD R0,R2,R3,LSL#1;R0=R2+(R3 1)加法可以在有符号和无符号数上进行。AND:逻辑与(logical AND)AND条件 S,名师资料总结-精品资料欢迎下载-名师精心整理-第 1 页,共 15 页 -dest=op_1
3、 AND op_2AND 将在两个操作数上进行逻辑与,把结果放置到目的寄存器中;对屏蔽你要在上面工作的位很有用。操作数1 是一个寄存器,操作数2 可以是一个寄存器,被移位的寄存器,或一个立即值:AND R0,R0,#3;R0=保持R0 的位和1,丢弃其余的位。AND 的真值表(二者都是1 则结果为1):Op_1 Op_2 结果0 0 0 0 1 0 1 0 0 1 1 1 BIC:位清除(Bit Clear)BIC 条件 S,dest=op_1 AND(!op_2)BIC 是在一个字中清除位的一种方法,与OR 位设置是相反的操作。操作数2 是一个32 位位掩码(mask)。如果如果在掩码中设置
4、了某一位,则清除这一位。未设置的掩码位指示此位保持不变。BIC R0,R0,#%1011;清除 R0 中的位0、1、和 3。保持其余的不变。BIC 真值表:Op_1 Op_2 结果0 0 0 0 1 0 1 0 1 1 1 0 译注:逻辑表达式为Op_1 AND NOT Op_2EOR:逻辑异或(logical Exclusive OR)EOR 条件 S,dest=op_1 EOR op_2EOR 将在两个操作数上进行逻辑异或,把结果放置到目的寄存器中;对反转特定的位有用。操作数1 是一个寄存器,操作数2 可以是一个寄存器,被移位的寄存器,或一个立即值:EOR R0,R0,#3;反转R0 中的
5、位0 和 1EOR 真值表(二者不同则结果名师资料总结-精品资料欢迎下载-名师精心整理-第 2 页,共 15 页 -为 1):Op_1 Op_2 结果0 0 0 0 1 1 1 0 1 1 1 0 MOV:传送(Move)MOV条件 S,dest=op_1MOV 从另一个寄存器、被移位的寄存器、或一个立即值装载一个值到目的寄存器。你可以指定相同的寄存器来实现NOP 指令的效果,你还可以专门移位一个寄存器:MOV R0,R0;R0=R0.NOP 指令MOV R0,R0,LSL#3;R0=R0*8 如果R15 是目的寄存器,将修改程序计数器或标志。这用于返回到调用代码,方法是把连接寄存器的内容传送
6、到R15:MOV PC,R14;退出到调用者MOVS PC,R14;退出到调用者并恢复标志位(不遵从32-bit 体系)MVN:传送取反的值(Move Negative)MVN条件 S,dest=!op_1MVN 从另一个寄存器、被移位的寄存器、或一个立即值装载一个值到目的寄存器。不同之处是在传送之前位被反转了,所以把一个被取反的值传送到一个寄存器中。这是逻辑非操作而不是算术操作,这个取反的值加1 才是它的取负的值:MVN R0,#4;R0=-5 MVN R0,#0;R0=-1 ORR:逻辑或(logical OR)名师资料总结-精品资料欢迎下载-名师精心整理-第 3 页,共 15 页 -OR
7、R 条件 S,dest=op_1 OR op_2OR 将在两个操作数上进行逻辑或,把结果放置到目的寄存器中;对设置特定的位有用。操作数1 是一个寄存器,操作数2 可以是一个寄存器,被移位的寄存器,或一个立即值:ORR R0,R0,#3;设置R0 中位0 和 1OR 真值表(二者中存在1 则结果为1):Op_1 Op_2 结果0 0 0 0 1 1 1 0 1 1 1 1 RSB:反向减法(Reverse Subtraction)RSB 条件 S,dest=op_2-op_1SUB 用操作数two 减去操作数one,把结果放置到目的寄存器中。操作数1 是一个寄存器,操作数2 可以是一个寄存器,被
8、移位的寄存器,或一个立即值:RSB R0,R1,R2;R0=R2-R1 RSB R0,R1,#256;R0=256-R1 RSB R0,R2,R3,LSL#1;R0=(R3 1)-R2 反向减法可以在有符号或无符号数上进行。RSC:带借位的反向减法(Reverse Subtraction with Carry)RSC 条件 S,dest=op_2-op_1-!carry 同于SBC,但倒换了两个操作数的前后位置。SBC:带借位的减法名师资料总结-精品资料欢迎下载-名师精心整理-第 4 页,共 15 页 -(Subtraction with Carry)SBC 条件 S,dest=op_1-op
9、_2-!carrySBC 做两个操作数的减法,把结果放置到目的寄存器中。它使用进位标志来表示借位,这样就可以做大于32 位的减法。SUB 和 SBC 生成进位标志的方式不同于常规,如果需要借位则清除进位标志。所以,指令要对进位标志进行一个非操作-在指令执行期间自动的反转此位。SUB:减法(Subtraction)SUB条件 S,dest=op_1-op_2SUB 用操作数one 减去操作数two,把结果放置到目的寄存器中。操作数1 是一个寄存器,操作数2 可以是一个寄存器,被移位的寄存器,或一个立即值:SUB R0,R1,R2;R0=R1-R2 SUB R0,R1,#256;R0=R1-256
10、 SUB R0,R2,R3,LSL#1;R0=R2-(R3 1)减法可以在有符号和无符号数上进行。移位指令ARM 处理器组建了可以与数据处理指令(ADC、ADD、AND、BIC、CMN、CMP、EOR、MOV、MVN、ORR、RSB、SBC、SUB、TEQ、TST)一起使用的桶式移位器(barrel shifter)。你还可以使用桶式移位器影响在LDR/STR 操作中的变址值。译注:移位操作在ARM 指令集中不作为单独的指令使用,它是指令格式中是一个字段,在汇编语言中表示为指令中的选项。如果数据处理指令的第二个操作数或者单一数据传送指令中的变址是寄存器,则可以对它进行各种移位操作。如果数据处理
11、指令的第二个操作数是立即值,在指令中用8 位立即值和4 位循环移位来表示它,所以对大于255 的立即值,汇编器尝试通过在指令中设置循环移位数量来表示它,如果不能表示则生成一个错误。在逻辑类指令中,逻辑运算指令由指令中S 位的设置或清除来确定是否影响进位标志,而比较指令的S 位总是设置的。在单一数据传送指令中指定移位的数量只能用立即值而不能用寄存器。下面是给不同的移位类型的六个助记符:LSL 逻辑左移ASL 算术左移名师资料总结-精品资料欢迎下载-名师精心整理-第 5 页,共 15 页 -LSR 逻辑右移ASR 算术右移ROR 循环右移RRX 带扩展的循环右移ASL 和 LSL 是等同的,可以自
12、由互换。你可以用一个立即值(从 0 到 31)指定移位数量,或用包含在0 和 31 之间的一个值的寄存器指定移位数量。逻辑或算术左移(Logical or Arithmetic Shift Left)Rx,LSL#n or Rx,ASL#n or Rx,LSL Rn or Rx,ASL Rn接受 Rx 的内容并按用 n 或在寄存器Rn 中指定的数量向高有效位方向移位。最低有效位用零来填充。除了概念上的第33 位(就是被移出的最小的那位)之外丢弃移出最左端的高位,如果逻辑类指令中S 位被设置了,则此位将成为从桶式移位器退出时进位标志的值。考虑下列:MOV R1,#12 MOV R0,R1,LSL
13、#2在退出时,R0 是 48。这些指令形成的总和是R0=#12,LSL#2 等同于 BASIC 的 R0=12 shift。算术右移(Arithmetic Shift Right)Rx,ASR#n or Rx,ASR Rn类似于LSR,但使用要被移位的寄存器(Rx)的第31 位的值来填充高位,用来名师资料总结-精品资料欢迎下载-名师精心整理-第 6 页,共 15 页 -保护补码表示中的符号。如果逻辑类指令中S 位被设置了,则把最后被移出最右端的那位放置到进位标志中。它同于BASIC 的 register=value shift。循环右移(Rotate Right)Rx,ROR#n or Rx,
14、ROR Rn循环右移类似于逻辑右移,但是把从右侧移出去的位放置到左侧,如果逻辑类指令中S 位被设置了,则同时放置到进位标志中,这就是位的 循环。一个移位量为32 的操作将导致输出与输入完全一致,因为所有位都被移位了32 个位置,又回到了开始时的位置!带扩展的循环右移(Rotate Right with extend)Rx,RRX这是一个ROR#0 操作,它向右移动一个位置-不同之处是,它使用处理器的进位标志来提供一个要被移位的33 位的数量。乘法指令指令格式这两个指令与普通算术指令在对操作数的限制上有所不同:给出的所有操作数、和目的寄存器必须为简单的寄存器。你不能对操作数2 使用立即值或被移位
15、的寄存器。目的寄存器和操作数1 必须是不同的寄存器。最后,你不能指定R15 为目的寄存器。MLA:带累加的乘法(Multiplication with Accumulate)MLA条件 S,dest=(op_1*op_2)+op_3MLA 的行为同于MUL,但它把操作数3 的值加到结果上。这在求总和时有用。名师资料总结-精品资料欢迎下载-名师精心整理-第 7 页,共 15 页 -MUL:乘法(Multiplication)MUL条件 S,dest=op_1*op_2MUL 提供 32 位整数乘法。如果操作数是有符号的,可以假定结果也是有符号的。比较指令指令格式译注:CMP 和 CMP 是算术指
16、令,TEQ 和 TST 是逻辑指令。把它们归入一类的原因是它们的 S 位总是设置的,就是说,它们总是影响标志位。CMN:比较取负的值(Compare Negative)CMN条件 P,status=op_1-(-op_2)CMN 同于CMP,但它允许你与小负值(操作数2 的取负的值)进行比较,比如难于用其他方法实现的用于结束列表的-1。这样与-1 比较将使用:CMN R0,#1;把 R0 与-1 进行比较详情参照CMP 指令。CMP:比较(Compare)CMP条件 P,status=op_1-op_2CMP 允许把一个寄存器的内容如另一个寄存器的内容或立即值进行比较,更改状态标志来允许进行条
17、件执行。它进行一次减法,但不存储结果,而是正确的更改标志。标志表示的是操作数1 比操作数2 如何(大小等)。如果操作数1 大于操作操作数2,则此后的有GT 后缀的指令将可以执行。明显的,你不需要显式的指定S 后缀来更改状态标志.如果你指定了它则被忽略。名师资料总结-精品资料欢迎下载-名师精心整理-第 8 页,共 15 页 -TEQ:测试等价(Test Equivalence)TEQ条件 P,Status=op_1 EOR op_2TEQ 类似于TST。区别是这里的概念上的计算是EOR 而不是AND。这提供了一种查看两个操作数是否相同而又不影响进位标志(不象CMP 那样)的方法。加上P 后缀的T
18、EQ 还可用于改变R15 中的标志(在 26-bit 模式中)。详情请参照psr.html,在32-bit 模式下如何做请参见这里。TST:测试位(Test bits)TST 条件 P,Status=op_1 AND op_2TST 类似于CMP,不产生放置到目的寄存器中的结果。而是在给出的两个操作数上进行操作并把结果反映到状态标志上。使用TST 来检查是否设置了特定的位。操作数1 是要测试的数据字而操作数2 是一个位掩码。经过测试后,如果匹配则设置Zero 标志,否则清除它。象CMP 那样,你不需要指定S 后缀。TST R0,#%1;测试在R0 中是否设置了位0。分支指令B:分支(Branc
19、h)B条件 B 是最简单的分支。一旦遇到一个B 指令,ARM 处理器将立即跳转到给定的地址,从那里继续执行。注意存储在分支指令中的实际的值是相对当前的R15 的值的一个偏移量;而不是一个绝对地址。它的值由汇编器来计算,它是24 位有符号数,左移两位后有符号扩展为32 位,表示的有效偏移为26 位(+/-32 M)。在其他处理器上,你可能经常见到这样的指令:OPT 1 LDA&70 CMP#0 BEQ Zero STA&72.Zero RTS(取自 Acorn Electron User Guide issue 1 page 213)在 ARM 处理器上,它们将变成下面这些东西:OPT 1 AD
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 2022年arm汇编指令集 2022 arm 汇编 指令

限制150内