AT&T | Intel | 说明 | |
寄存器命名原则 | %eax | eax | Intel的不带百分号 |
源/目的操作数顺序 | movl %eax, %ebx | mov ebx, eax | Intel的目的操作数在前,源操作数在后 |
常数/立即数的格式 | movl $_value,%ebx | mov eax,_value | Intel的立即数前面不带$符号 |
操作数长度标识 | movw %ax,%bx | mov bx,ax | Intel的汇编中, 操作数的长度并不通过指令符号来标识 AT&T格式中:movb 传送字节、movw 传送字、movl 传送双字 |
寻址方式 | imm32(basepointer,indexpointer,indexscale) | [basepointer + indexpointer*indexscale + imm32) |
两种寻址的实际结果都应该是 imm32 + basepointer + indexpointer*indexscale |
AT&T的汇编格式中, 跳转指令有点特殊.
直接跳转, 即跳转目标是作为指令的一部分编码的.
例如: jmp Label_1
间接跳转, 即跳转目标是从寄存器或存储器位置中读出的. 写法是在" * "后面跟一个操作数指示符.
例如: jmp *%eax 用寄存器%eax中的值作为跳转目标
jmp *(%eax) 以%eax中的值作为读入的地址, 从存储器中读出跳转目标
--------摘自《深入理解计算机系统》
下面是一些寻址的例子:
AT&T: `-4(%ebp)' 相当于 Intel: `[ebp - 4]' AT&T: `foo(,%eax,4)' 相当于 Intel: `[foo + eax*4]' AT&T: `foo(,1)' 相当于 Intel `[foo]' AT&T: `%gs:foo' 相当于 Intel`gs:foo'