AT&T汇编
AT&T汇编是在Linux平台下的汇编语言。
MOV指令
movb
:8位
movw
:16位
movl
:32位
movq
64位
例子:
movl %eax,%edx ; edx = eax
movl $0x123,%edx ; edx = 0x123(立即寻址)
movl 0x123,%edx ; edx = *(int_32 *)0x123(直接寻址)
movl (%ebx),%edx ; edx = *(int_32 *)ebx(间接寻址)
movl 4(%ebx),%edx ; edx = *(int_32)(ebx + 4) (变址寻址)
%
开头的是寄存器,$
开头的是立即数。
PUSH指令
例子:
pushl %eax ;
实际上它只是对两条指令的封装:
subl $4,%esp ;为栈腾出一个单位的空间
movl %eax,(%esp) ;将eax的值压进esp栈顶
POP指令
例子:
popl %eax
它相当于执行了:
movl (%esp),eax ;将栈顶的元素放到eax中
addl $4,%esp
CALL指令
CALL
就像是C语言中的函数调用,它的功能是调用一个地址的指令
例子:
call 0x12345
它相当于:
pushl %eip ;将指令指针压入栈
movl $0x12345,%eip
这样,它就可以调用0x12345
地址中的指令。
RET指令
ret
指令非常简单,它相当于:
popl %eip
CALL
指令执行结束后,调用RET
指令将eip
(指令指针)弹出栈,此时cpu又从call
指令的上一个位置向下执行指令。
ENTER指令
它是由两条指令构成的:
pushl %ebp
movl %%esp,%ebp
LEAVE指令
作用是撤销函数调用的堆栈。
相当于
movl %ebp,%esp
popl %ebp
与C语言的关系
call
与c语言中函数的调用是对应的,而ret
与c语言函数调用结束是相对应的。