一.过程调用的执行步骤(P为调用者,Q为被调用者)
现场:通用寄存器的内容
二.寄存器的约定
三. 局部变量存放在另一个存储区:栈区
全局变量和静态变量连续存放在同一个存储区:可读写数据区
栈区的地址高
四.具体过程
准备阶段
形成帧底:pushl %ebp 和movl %esp, %ebp
注:此函数ebp和调用这个函数的函数esp不是相等的
生成栈帧(如果需要的话):subl $24, %esp
保存现场(如果有被调用者保存寄存器) :push指令
过程(函数)体
分配局部变量空间,并赋值
具体处理逻辑,如果遇到函数调用时
准备参数:将实参送栈帧入口参数处
CALL指令:保存返回地址并转被调用函数
注:返回地址即为esp-4
在EAX中准备返回参数
结束阶段
恢复现场,释放局部变量空间
退栈:leave指令 或 pop指令(恢复栈底,指向返回地址)
取返回地址返回:ret指令
五.Ebp ,esp的位置如图
返回地址为call指令的下一个地址,
EBP所指的为上一个函数的ebp的值
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)