2019-2020-1 20199316《Linux内核原理与分析》第二周作业

计算机是如何工作的

反编一个C程序

实验过程

  • 首先在shell环境下查看目录以及编译main.c文件
    1801303-20190922153147570-1555604574.png

  • main.c代码如下:

// main.c
int g(int x)
{
    return x + 3;
}

int f(int x)
{
    return g(x);
}

int main(void)
{
    return f(8) + 1;
}
  • 接着,在平台上输入下面一行代码进行反编

gcc -s -o main.s main.c -m32
  • 然后,当我满心欢喜的打开反编文件时- -
    1801303-20190922154302179-1513136279.png

  • 这是什么东西?这不是我想要的代码啊!你们走错片场了吧......
    1801303-20190922155000090-364944113.jpg
  • 言归正传,待我检查出自己的小错误,终于无伤大雅的把反编代码给搞出来了,真心不容易- -

1801303-20190922155132963-697442153.png

1801303-20190922155139084-1067213875.png

实验分析

  • pushl %ebp,将ebp寄存器的值进行压栈。接着将esp寄存器指向的地址减4,即向下移动一位。
  • movl %esp,%ebp,将esp所指的位置赋值给ebp。
  • subl $4,%esp,esp寄存器减4,并且eip的值加一。
  • movl $8,(%esp),将8放入到esp所指向的位置。
  • call f,把eip的值先压倒栈顶,再将函数f的第一条指令pusjl %ebp位置放到eip中。
  • pushl %ebp(意思同上)
  • 这里我就把重复的指令省略啦
    1801303-20190922160710800-719932065.jpg

  • leave,撤销函数main的堆栈。
  • ret,ebp和esp变回初始状态。

转载于:https://www.cnblogs.com/destiny-love/p/11567621.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值