计算机是如何工作的
反编一个C程序
实验过程
首先在shell环境下查看目录以及编译main.c文件
- 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
然后,当我满心欢喜的打开反编文件时- -
- 这是什么东西?这不是我想要的代码啊!你们走错片场了吧......
言归正传,待我检查出自己的小错误,终于无伤大雅的把反编代码给搞出来了,真心不容易- -
实验分析
- 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(意思同上)
- 这里我就把重复的指令省略啦
- leave,撤销函数main的堆栈。
- ret,ebp和esp变回初始状态。