您的位置:首页 > 运维架构 > Linux

Linux内核分析 第一次作业

2015-03-08 22:27 211 查看
实验环境:ubuntu14.10 + gcc 4.9.1

实验截图:



代码分析:

从main函数开始

20 保存%rbp

21 设置帧指针

22 %edi=4

23 调用函数f

10 保存%rbp

11 设置帧指针

12 在栈上分配8个字节

13 保存%edi

*寄存器%eax,%ebx,%ecx被划分为调用者保存寄存器。当过程P调用Q时,Q可以覆盖这些寄存器,而不会破坏任何P所需要的数据。寄存器%ebx,%esi,%edi被划分为被调用者保存寄存器。Q必须在覆盖这些寄存器的值之前,先把它们保存到栈中,并在返回前恢复他们,因为P可能会在今后的计算中需要这些值。

14 %eax=4

15 %edi=4

16 调用函数g

2 保存%rbp

3 设置帧指针

4 保存%edi

5 %eax=4

6 %eax=4+3=7

7 恢复%rbp

8 从过程调用g中返回

17 使栈做好返回的准备(%rsp=%rbp,恢复%rpb)

18 从过程调用f中返回

24 %eax=7+1=8

25 恢复%rbp

26 从过程调用main中返回

计算机是如何工作的:

计算机内部的信息被表示为一组组的位,依据上下文有不同的解释。开始时时ASCII文本,然后被编译器和链接器翻译成二进制可执行文件。

处理器通过eip读取并解释存放在主存的二进制命令。主存通过IO接口读取低层存储设备的数据。

火杨 原创作品转载请注明出处

《Linux内核分析》MOOC课程http://mooc.study.163.com/course/USTC-1000029000
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息