ARM匯編中立即數的構成規則:必須是一個(gè)8位的二進(jìn)制數,前面補上24位二進(jìn)制0,擴展為32位;然后將這個(gè)32位的擴展數首尾相連循環(huán)偶數位得到。給定一個(gè)立即數,判斷其是否合法可以分三步:首先將給定的立即數寫(xiě)成32位二進(jìn)制的形式;然后看能不能用一個(gè)8位的二進(jìn)制數包括所有含1的部分,如不能則非法;最后看這個(gè)8位二進(jìn)制數能不能循環(huán)右移偶數位得到給定的立即數,不能數則非法。舉例如下:
0xff=00000000 00000000 00000000 11111111:相當于8位二進(jìn)制11111111循環(huán)右移0位得到,合法;
0x104=00000000 00000000 00000001 00000100:相當于8位二進(jìn)制01000001循環(huán)右移2位得到,合法;
0x101=00000000 00000000 00000001 00000001:包含所有1的部分是100000001,無(wú)法用一個(gè)8位二進(jìn)制表示,非法;
0x102=00000000 00000000 00000001 00000010:包含所有1的部分是10000001,但10000001只能循環(huán)右移奇數位得到給定的數,非法;
0xfC000002 =11111100 00000000 00000000 00000010:相當于8位二進(jìn)制10111111循環(huán)右移6位得到,合法。
0x8000007E=10000000 00000000 00000000 01111110:包含所有1的部分是11111101,但10000001只能循環(huán)右移奇數位得到給定的數,非法。
評論