ARM8位图立即数格式

operand2的常数表达式有如下规定:“该常数必须对应8位位图,即常数是由一个8位的常数循环右移偶数位得到的。”这句话的意思是说,当用12位第二操作数来表示一个32位立即数时,采用的是将8位数通过移位的方式来实现的,其中12位第二操作数的低八位存放被移位的“基本”数(取值范围为0到255),而高四位存放的是循环右移的位数,因为位四位二进制数,所以取值范围位为0到15,而对应的移位位数则为0到30位,也就是说若“移位”数为0,则表示“基本”数不变,若“移位”数位1,则表示将“基本”数在32位数字空间中循环右移2位,若“移位”数位5,则表示将“基本”数在32位数字空间中循环右移10位,若“移位”数位10,则表示将“基本”数在32位数字空间中循环右移20位,依次类推。举例表示:

     AND R1,R2,#0xff

     当处理器处理这条指令的第二操作数0xff时,因为0xff为8位二进制数,所以处理器就将其直接放进8位“基本”数中,而4位“移位”数则为0.

     AND R1,R2,#0x104

     当处理器处理这条指令的第二操作数0x104时,因为此时0x104已经超过了8位二进制数,所以处理器就要将其“改造”一下,我们先把0x104转换成二进制0000 0000 0000 0000 0000 0001 0000 0100,我们可以看到,这个数是0000 0000 0000 0000 0000 0000 0100 0001通过循环右移30位得到的,因此改造后的结果是8位“基本”数中存放0100 0001,而“移位”数为15。

     AND R1,R2,#0xff000000

     当处理器处理这条指令的第二操作数0xff000000时,处理器同样要对其“改造”,我们先把0xff000000转换成二进制1111 1111 0000 0000 0000 0000 0000 0000,我们可以看到,这个数是0000 0000 0000 0000 0000 0000 1111 1111通过循环右移8位得到的,因此改造后的结果是8位“基本”数中存放1111 1111,而“移位”数为4。

猜你喜欢

转载自blog.csdn.net/zilan23/article/details/104338031
今日推荐