程序加载器如何工作的?

UNIX系统中,每个程序都运行在一个进程上下文中,有自己的虚拟地址空间。如图:

 

 

内核虚拟存储器
用户栈(向下增长)

 

共享库的存储器映射

 
运行时堆(4KB对齐)(向上增长)
数据段(.data  .bss)(4KB对齐)
代码段(.init .text .rodata)(4KB对齐)
未使用

外壳运行一个程序时,父进程生成一个子进程,它是父进程的一个复制品。它通过调用execve来启动加载器。加载器删除子进程现有的虚拟存储器段,并创建一组新的代码、数据、堆和栈。堆和栈被初始化为0。通过将虚拟地址空间中的页映射到可执行文件中页大小的。新的代码和数据段被初始化为可执行文件的内容。最后,加载器跳转到_start地址(ctrl.o),经过初始化后,会跳到应用程序的main函数。除了一些头部信息,在加载过程中没有任何从磁盘到内存的数据拷贝。直到CPU引用一个被映射的虚拟页时才会拷贝。此时,操作系统利用它的页面调度机制自动将页面从磁盘传送到存储器。

posted on 2014-02-24 16:03  奇好猫  阅读(432)  评论(0编辑  收藏  举报

导航