
计算机系统
大作业
题 目 程序人生-Hello’s P2P
专 业 计算学部
学 号 120L021109
班 级 2003010
学 生 柳戴鑫
指 导 教 师 郑贵滨
计算机科学与技术学院
2022年5月
摘 要
本文以hello程序的生命周期为线索,对hello的预处理、编译、汇编和链接等各个阶段的实现过程进行分析。当hello成为可执行文件后,本文将继续从hello的进程管理、存储管理、IO管理等方面进行实践与探讨。通过对hello一生的追踪,体会计算机系统多方面的分工与配合,进一步深入地理解计算机系统。
关键词:hello;预处理;编译;汇编;链接;进程;存储;IO;
目 录
第1章 概述
1.1 Hello简介
1.2 环境与工具
1.3 中间结果
1.4 本章小结
第2章 预处理
2.1 预处理的概念与作用
2.2在Ubuntu下预处理的命令
2.3 Hello的预处理结果解析
2.4 本章小结
第3章 编译
3.1 编译的概念与作用
3.2 在Ubuntu下编译的命令
3.3 Hello的编译结果解析
3.4 本章小结
第4章 汇编
4.1 汇编的概念与作用
4.2 在Ubuntu下汇编的命令
4.3 可重定位目标elf格式
4.4 Hello.o的结果解析
4.5 本章小结
第5章 链接
5.1 链接的概念与作用
5.2 在Ubuntu下链接的命令
5.3 可执行目标文件hello的格式
5.4 hello的虚拟地址空间
5.5 链接的重定位过程分析
5.6 hello的执行流程
5.7 Hello的动态链接分析
5.8 本章小结
第6章 hello进程管理
6.1 进程的概念与作用
6.2 简述壳Shell-bash的作用与处理流程
6.3 Hello的fork进程创建过程
6.4 Hello的execve过程
6.5 Hello的进程执行
6.6 hello的异常与信号处理
6.7本章小结
第7章 hello的存储管理
7.1 hello的存储器地址空间
7.2 Intel逻辑地址到线性地址的变换-段式管理
7.3 Hello的线性地址到物理地址的变换-页式管理
7.4 TLB与四级页表支持下的VA到PA的变换
7.5 三级Cache支持下的物理内存访问
7.6 hello进程fork时的内存映射
7.7 hello进程execve时的内存映射
7.8 缺页故障与缺页中断处理
7.9动态存储分配管理
7.10本章小结
第8章 hello的IO管理
8.1 Linux的IO设备管理方法
8.2 简述Unix IO接口及其函数
8.3 printf的实现分析
8.4 getchar的实现分析
8.5本章小结
结论
附件
参考文献
第1章 概述
1.1 Hello简介
(1)p2p:From Program to Process,即从程序到过程。在 linux 中,源程序到可执行文件的过程是通过编译器驱动程序完成的。
①源文件hello.c 文件经过编译器 cpp 的预处理成为 hello.i;
②再经过编译器 ccl 的编译成为 hello.s;
③接着被汇编器 as 汇编成 hello.o;
④最终经过链接器 ld 的链接成为可执行目标程序 hello;
⑤操作系统会为可执行程序运用fork函数产生子进程,再调用execve函数加载进程。至此,P2P 结束。
(2)020:From Zero-0 to Zero-0:
①shell 通过 execve 加载并执行 hello,映射虚拟内存;
②先删除当前虚拟地址的数据结构并为hello文件创建新的区域结构;
③进入程序入口后,程序开始载入物理内存,然后进入main函数执行目标代码,CPU 为运行的hello分配时间片执行逻辑控制流;
④当程序运行结束后,shell 父进程负责回收 hello 进程,内核删除相关数据结构。
硬件环境:X64 CPU;2