算数运算指令

本文介绍了在ARM-v7和ARM-v8架构中,如何使用基本的算术运算指令如add、adc、sub、sbc进行64位数据的加法和减法,并演示了乘法指令mul的用法。练习题展示了具体的操作步骤,包括如何处理进位和借位情况。
摘要由CSDN通过智能技术生成
@ 算数运算指令 add adc sub sbc mul
@ 注:ARM-v7架构不支持除法指令
@ ARM-v8架构支持除法指令(div)
@ 指令的语法格式:opcode{s}{cond} Rd, Rn, oprand2

@ 练习题1:实现两个64位数据的加法运算
@ 第一个64位的数通过R1,R0表示,
@ 第二个64位的数通过R3,R2表示。
@ 结果放到R5,R4寄存器中。
mov r0, #0xFFFFFFFE
mov r1, #4
mov r2, #5
mov r3, #6
@ add : 普通的加法指令
adds r4, r0, r2 @ R4 = R0 + r2
@ adc : 带进位标志位的加法指令
adc r5, r1, r3 @ R5 = R1 + R3 + C

@ 练习题2:实现两个64位数据的减法运算
@ 第一个64位的数通过R1,R0表示,
@ 第二个64位的数通过R3,R2表示。
@ 结果放到R5,R4寄存器中。
mov r0, #4
mov r1, #9
mov r2, #5
mov r3, #6
@ sub : 普通的减法指令
subs r4, r0, r2 @ r4 = r0 - r2
@ sbc : 带借位的减法指令 注意C位变化
sbc r5, r1, r3 @ r5 = r1 - r3 - !C

@ 乘法指令 mul
@ 格式:opcode{s}{cond} Rd, Rn, Rm
@ 第二个操作数只能是一个寄存器
mov r0, #3                   
mov r1, #4
mul r2, r0, r1
@ mul r2, r0, #3 @ error : 第二个操作数只能是一个寄存器
@ mul r0, r0, r1 @ error : Rd和Rn必须不同
mul r0, r1 @ 如果Rd=Rn,可以合并只写一个
            @ 等价于 R0 *= R1
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

小徐的记事本

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值