AT&T汇编格式与Intel汇编格式的比较

GCC采用的是AT&T的汇编格式, 也叫GAS格式(Gnu ASembler GNU汇编器), 而微软采用Intel的汇编格式.
一 基本语法
语法上主要有以下几个不同.
1、寄存器命名原则

AT&TIntel说明
%eaxeaxIntel的不带百分号


2、源/目的操作数顺序

AT&TIntel说明
movl %eax, %ebxmov ebx, eaxIntel的目的操作数在前,源操作数在后


3、常数/立即数的格式

AT&TIntel说明
movl $_value,%ebxmov eax,_valueIntel的立即数前面不带$符号
movl $0xd00d,%ebxmov ebx,0xd00d规则同样适用于16进制的立即数


4、操作数长度标识

AT&TIntel说明
movw %ax,%bxmov bx,axIntel的汇编中, 操作数的长度并不通过指令符号来标识

在AT&T的格式中, 每个操作都有一个字符后缀, 表明操作数的大小. 例如:mov指令有三种形式:

movb  传送字节

movw  传送字

movl   传送双字

因为在许多机器上, 32位数都称为长字(long word), 这是沿用以16位字为标准的时代的历史习惯造成的.

---------摘自《深入理解计算机系统》


5、寻址方式

AT&TIntel
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'
例子摘自 http://sourceware.org/binutils/docs/as/i386_002dMemory.html#i386_002dMemory
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值