程序从源码到运行

2020-08-06  本文已影响0人  Shawn_Lu_0127

程序从源码到运行

进程在内存中的结构
process_memory_layout.jpg
进程的装载(Loading)

在Linux系统中,通过系统调用(execve或者spawn)从文件系统中装载ELF(Executable and Linking Format)格式的文件来装载进程。

elf_format.png

ELF文件的两种视角

  1. 链接视角, 当程序或者库被链接时的视角。里面包含目标文件的一系列信息,例如数据,指令,重定位信息,符号,debug信息等。
  2. 执行视角,当程序运行时的视角。通常所有的可执行的和只读的数据被放到text段,bss和data被放入data段。

部分的ELF段

进程装载过程

  1. kernel读取ELF header并校验类型,权限,需要的内存大小,和是否可运行里面的指令。通过则计算其所需的内存。
  2. 申请内存
  3. copy地址空间从硬盘到主存
  4. 从硬盘中copy .text和.data段到主存
  5. copy程序参数到stack中
  6. 初始化寄存器,设置stack指针到栈顶
  7. jumps to start routine
ELF文件(可执行文件)生成
steps_of_running_program.png
  1. 预处理
    删除注释,执行条件编译,将所有#include文件内容插入源文件对于位置
  2. 编译
    将预处理后的文件编译成汇编源码文件
  3. 汇编
    将汇编代码转化成机器指令,将编译后的文件汇编成目标文件(object file)
  4. 链接
    将多个目标文件组合成一个可执行文件,并且解析对外部符号的引用,并为函数和参数分配地址,并且修正代码和数据地址,这个过程叫做重定位(relocation)。

链接

linker.png

链接分为动态链接和静态链接

参考

程序编译链接装载过程
调试器工作原理

上一篇 下一篇

猜你喜欢

热点阅读