[转]ARM MOV指令对立即数的要求

MOV R1,#9

以上指令表示把9传送到寄存器R1中。

 

需要注意的是,这里的立即数是有要求的,不是说任何一个立即数都可以。

 

要求是:立即数可以由一个8位的常数循环右移偶数位得到。其中循环右移的位数由一个4位二进制的两倍表示。

 

如果立即数记作immediate,8位常数记作immed_8,4位的循环右移值记作rotate_imm,则

immediate=immed_8循环右移(2*rotate_imm

 

所以,MOV r0, #0xFF, 2

这里2是循环右移数,必须为偶数,奇数会报错

 

对于机器码0xE3A004FF,可解析为:MOV  r0, #0xFF, 8

这里的立即数#0xFF, 8为一个整体,其中0xFF为immed_8,8为rotate_imm *2=4×2计算得来。

这样并不是每一个32位的常数都是合法的立即数,只有能通过上面的构造方法得到的才是合法的立即数。

 

比如,0x101,0x102,0xFFF;

 

另外,一个合法的立即数,可能有多种编码方法。如0x3F0,它可以采用下面两种编码方法:

immed_8=0x3F,rotate_imm=0xE

(0x3F循环右移28位,即0x3F左移4位得到0x3F0)

 

或者

immed_8=0xFC,rotate_imm=0xF

(0xFC循环右移30位,即0xFC左移2位得到0x3F0)

 

对于不合法的立即数,比如要把0xFFF传送到R1中,虽然不能用MOV指令,但是可以用LDR伪指令,用法是

LDR R1,=0xFFF

 

原文:https://blog.csdn.net/longintchar/article/details/72824409

版权声明:本文为博主原创文章,转载请附上博文链接!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值