linux汇编语法格式(和Intel汇编的区别)

(1)在AT&T汇编格式(Linux汇编)中,寄存器需要加上“%”作为前缀,而Intel汇编则不用;

AT&T格式 Intel格式

pushl %eax   push   eax

(2)在AT&T汇编格式(Linux汇编)中,用‘$’前缀表示一个立即操作数,而Intel汇编则不用;

AT&T格式 Intel格式

pushl $1 push   1

(3)AT&T和Intel格式中的源操作数和目标操作数的位置正好相反。在Intel汇编格式中,目标操作数在源操作数的左边;

而在AT&T汇编格式中,目标操作数在源操作数的右边;

AT&T格式 Intel格式

addl   $1,%eax add eax,1

(4)在AT&T汇编中,操作数的字长由操作符的最后一个字母决定,后缀‘b’,'l'分别表示操作数为字节、字、和双字,而在Intel汇编格式中,

操作数的字长是用”byte ptr“和“word ptr”等前缀来表示的。

AT&T格式 Intel格式

movb val,%al mov al,byte ptr val

(5)在AT&T中,绝对转移和调用指令(jump/call)的操作数前要加上‘*’作为前缀,而Intel中则不用;

(6)远程转移指令和远程调用指令的操作码,在AT&T汇编格式中为”ljump“和”lcall“,而在Intel中则为”jmp far“和”call far“,即

AT&T格式 Intel格式

ljump $section,$offset jmp far section:offset

lcall $seciton,$offset call far section:offset

与之相应的远程返回指令则为:

AT&T格式 Intel格式

lret $stack_adjust ret far stack_adjust

(7)在AT&T汇编格式中,内存操作数的寻找方式为:

section:disp(base,index,scale)

而在Intel汇编格式中,内存操作数的寻址方式为:

section:[base+index*scale+disp]

在linux工作在保护模式下,用的是32位线性地址,所以在计算地址时不考虑段基址和偏移量,而采用如下的地址计算方式

disp+base+index*scale




  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值