ebp 函数堆栈esp_函数参数压栈,栈帧ebp,esp怎样移动的?

本文详细介绍了在x86汇编中,如何使用EBP和ESP寄存器进行函数参数压栈、创建堆栈帧以及函数返回时的堆栈恢复。通过具体的示例,解释了函数调用过程中的参数传递、局部变量分配以及堆栈帧的建立和清理。内容涵盖了Enter、Leave指令的使用以及stdcall调用约定。
摘要由CSDN通过智能技术生成

压栈一次esp-4,ebp不变

esp是栈顶指针寄存器,堆栈操作只和esp有关

比如有一个函数a,有两个参数,一般是这样的

PUSH 1 参数2压栈,esp-4

PUSH 2 参数1压栈,esp-4

CALL a 调用

a:

PUSH EBP 保存ebp

MOV EBP,ESP 改变栈帧,以后访问参数通过ebp,访问局部变量通过esp

SUB ESP,8 分配局部变量空间

...

ADD ESP,8

POP EBP 恢复ebp

RETN 8 返回,esp+8

C语句对应汇编语句:

例如函数:

int aaa(int a,int b)

{

int c;

c=a+b;

return c;

}

aaa(1,2);

调试版aaa的代码

PUSH EBP

MOV EBP,ESP

SUB ESP,4//分配局部变量空间,一个int是4个字节

MOV EAX,DWORD PTR SS:[EBP+8]//读取参数a

ADD EAX,DWORD PTR SS:[EBP+C]//加上参数b

MOV DWORD PTR SS:[EBP-4],EAX//保存到局部变量c

MOV EAX,DWORD PTR SS:[EBP-4]//eax是返回值

MOV ESP,EBP//恢复栈顶指针

POP EBP//恢复ebp

RETN//返回

调用

PUSH 2//参数2压栈,esp-4

PUSH 1//参数1压栈,esp-4

CALL aaa//调用函数

ADD ESP,8//esp+8,平衡堆栈,清除掉参数

发布版的就是这样了,精简掉了很多内容

MOV EAX,DWORD PTR SS:[ESP+8]

MOV ECX,DWORD PTR SS:[ESP+4]

ADD EAX,ECX

RETN

。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。

下面要讲的是子程序如何存取参数,因为缺省对堆栈操作的寄存器有 ESP 和 EBP,而 ESP是堆栈指针,无法暂借使用,所以一般使用 EBP 来存取堆栈,假定在一个调用中有两个参数,而且在 push 第一个参数前的堆栈指针 ESP 为 X&

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值