Linux内核分析 实验1

来源:互联网 发布:python编辑器 编辑:程序博客网 时间:2024/06/05 10:33

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

 

1)实验部分(以下命令为实验楼64Linux虚拟机环境下适用,32Linux环境可能会稍有不同)

使用

1.  gcc –S –o main.s main.c -m32

命令编译成汇编代码,如下代码中的数字请自行修改以防与他人雷同

1.  int g(int x)

2.  {

3.    return x + 3;

4.  }

5.   

6.  int f(int x)

7.  {

8.    return g(x);

9.  }

10.  

11. int main(void)

12. {

13.   return f(5) + 7;

14. }

 

源代码如图:



使用 gcc -S命令编译成汇编代码

 


查看完整的汇编代码



整理过后的汇编代码



C语言源代码和汇编指令对照:


 

eip是控制整个程序运行过程的决定因素:

(1若遇到跳转语句(JMP 等)时,先将 eip 压栈保存,即当前指令的下一条指令的地址,然后将需要跳转的目的地址赋给 eip,实现跳转; 

(2、若遇到函数调用call时,除了将 eip 压栈,还要保存当前堆栈的状态,将栈基指针 ebp 压栈,然后将相应函数地址赋给 eip,实现跳转; 

(3、若为普通指令,则继续从 eip 指向的地址取出下一条指令执行。

 

栈在程序执行过程中发挥着至关重要的作用,栈这种特殊的数据结构为函数的调用提供了可能,使得程序的执行更加灵活、过程更加直观;也使得编程更加简单、方便;同时,只有理解栈的结构和性质,才能理解程序是如何执行的。

 

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

 

0 0