刘帅嵌入式系统-CMP比较指令

CMP指令从寄存器Rn中减去< shifter_operand > 表示的数值,根据操作的结果更新CPSR中相应的条件标志位,后面的指令就可以根据CPSR中相应的条件标志位来判断是否执行了。

指令的编码格式

指令的语法格式

CMP{< cond >} {S} < Rd >, < Rn> ,< shifter_operand >

其中:

  • < cond >为指令执行的条件码。当< cond >忽略是指令为无条件执行。

  • < Rn > 寄存器为第1个操作数所在的寄存器。

  • < shifter_operand >为第2个操作数。计算方法见之前介绍。

指令操作的伪代码

if ConditionPassed<cond> then
    alu_out=Rn - shifter_operand
    N Flag=alu_out[31]
    Z Flag=if alu_out==0 then 1 else 0
    C Flag=NOT BorrowFrom(Rn - shifter_operand)
    V Flag=OverflowFrom(Rn - shifter_operand)

指令的使用

CMP指令与SUBS指令的区别在于CMP指令不保存操作结果。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值