首先,您需要infocenter.arm.com上的ARM体系结构参考手册(ARM ARM),参考手册,获取最老的一个(armv5管他呢)。该指令集在那里有很好的定义。
二,为什么不只是组装一些指令,看看会发生什么?
;@test.s
cmp r1, r0
add r0, #0x1a
任何交叉汇编你(看到一个脚本生成的gcc目录http://github.com/dwelch67/raspberrypi,只是跑起来直通binutils的那个脚本)
arm-none-linux-gnueabi-as test.s -o test.o
arm-none-linux-gnueabi-objdump -D test.o
臂无-Linux的gnueabi VS掰没有精灵VS手臂精灵等不事本,都做同样的
Disassembly of section .text:
00000000 <.text>:
0: e1510000 cmp r1, r0
4: e280001a add r0, r0, #26
前四名的完整的32位ARM指令(不是拇指)是条件码位,见病情场部分在ARM ARM中。 0xE表示始终执行该指令。 0b0000是eq只有当z标志被设置时才执行,0b0001 ne只在z被清除时执行。
在ARM ARM中push进入arm指令集,然后按字母顺序列出arm指令,然后找到cmp它启动与cond 00I10101 rb sbz移位器
从我们的cmp指令上面我们看到1110 000101010001 ...所以我是一个零位15:12是零位27:26是零和24:21是1010所以这是一个cmp指令
上面的第19位到第16位是0b001,这对ARM ARM中的移位器操作数是rn = 1(r1),它告诉您查看寻址模式1数据处理操作数,并在pdf中有一个链接页面
我们知道我们希望第二个操作数只是一个寄存器,即所谓的数据处理操作数寄存器和一个页码,转到该页上的那个页面15:12是11:4是0和3 :0是rm。我们从cmp指令中知道它说15:12应该是零,我想知道它是否在意,cmp不会将结果存储到寄存器,因此不使用rd。 rm被使用,在这种情况下,我们想要r0,所以0b0000进入3:0也注意到它显示位27:25为零,在cmp指令中25是I,我们现在知道我们想在那里有一个零,所以
的CMP页面,这个数据处理之间 - 注册页面,我们有整个画面
1110 condition
000
1010 opcode
1 S (store flags, that is a 1 for a cmp to be useful)
0001 rn
0000 rd/dont care/sbz
00000
000
0000 rm
cmp rn,rm
cmp r1,r0
附加类似,但采用了直接的,所以去的指令阿尔法列表中的加法指令。我们现在从cmp得知,这个类的指令是24:21是操作码,我们可以直接转到操作数的操作数上去继续从这里开始
这次我们正在做add rd,rn,#immediate
所以找页面#immediate
和编码是
1110 condition, always
001 (note the immediate bit is set)
0100 (opcode for add for this type of instruction)
0 (S not saving the flags, it would be adds r0,r0,#26 for that)
0000 (rn = r0)
0000 (rd = r0)
现在到了有趣的部分,我们可以编码26种不同的方式。位7:0是立即数,位11:8允许立即旋转,26是0x1A,我们可以简单地将0x1A放在低8位,并将旋转设置为0,这就是gnu汇编器所做的。可能会在低8位中放置一个0x68,并且在rotate_imm字段1101000中向右旋转1 1 * 2位是11010 = 0x1A = 26.
很好的问题;不幸的是该链接已经死亡。对于路过的人来说,这里有一个快速的[web档案链接](https://web.archive.org/web/20150426195854/http://www.nyx.net/~troddis/ARM.html) – Asu 2016-11-10 22:26:22