欢迎使用CSDN-markdown编辑器

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

汇编代码:

这里写图片描述

运行流程:
这里写图片描述

从main:开始执行
ebp = esp = 0x0;
pushl %ebp: ebp的值0x0入栈[0x4],esp向下移动4字节,esp = 0x4;
movl %esp, %ebp: esp的值赋给ebp,ebp = 0x4;
subl 4,movl 2016, (%esp): 将立即数2016赋给 esp指向的地址0x8(2016);
call f :将23行代码地址入栈,并将9行代码地址赋给eip0x12(23),sp(0x16);
pushl %ebp: 将ebp的值(0x4)入栈[0x16],esp向下生成4字节,esp = 0x20;
movl %esp, %ebp:将esp的值赋给ebp,ebp = 0x20;
subl $4, %esp: esp向下生长4字节,esp = 0x24;
movl 8(%ebp),%eax: ebp(0x16)向上偏移8字节(0x8)中的2016赋给eax;
movl %eax, (%esp): 将eax中的值2016赋给esp0x24(2016);
call g: 将15行地址入栈,sp加4; sp(0x28)

pushl ebp: ebp入栈;sp(0x32) 0x32(0x24)
movl esp ebp: sp->bp; ebp(0x32)
movl 8(ebp), eax: ebp向上偏移8字节地址中的值赋给eax;
addl 28, eax: eax的值加立即数28;
popl ebp: 将ebp指向的内容赋给ebp(0x24), sp的值向上生长4字节 sp(0x28);
ret: 将sp指向的内容赋给ip, sp向上生长4字节sp(0x24);
回到第15行leave: bp->sp popl ebp, sp = 0x20;
ret:将sp指向的内容赋给ip, sp向上生长4字节 sp(0x16);
addl $2, %eax: eax中的值加立即数2;
leave:bp->sp, pop bp sp = 0x4;
ret:将sp指向的内容赋给ip, sp向上生长4字节 sp(0x00);

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值