汇编代码分析

本文通过分析一段汇编代码,详细解释了 ebp、esp、eax 和 eip 寄存器的作用,以及如何利用栈进行函数调用、参数传递和返回值存储。在代码中,可以看到函数 f 和 g 的调用过程,涉及堆栈的修改、值的传递和计算,最后通过 ret 指令恢复现场并结束执行。
摘要由CSDN通过智能技术生成

zhang 原创作品转载请注明出处 《Linux内核分析》MOOC课程http://mooc.study.163.com/course/USTC-1000029000

代码如下:



该代码运行中主要涉及以下寄存器ebp(指向栈底),esp(指向栈顶),eax(存放返回值),eip(指向运行代码)

接下来按运行顺序来分析(假定ebp,esp开始指向0,并将堆栈每隔32位从高到底依次命名为1,2,3...)

pushl %ebp         在1位置存入ebp地址0,esp指向1

movl %esp, %ebp 使ebp指向esp指向地址(1)

subl $4, %esp     esp指向2

movl $8, (%esp) 在2位置存入8

call f

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值