我正在为 C++ 中的 Linux 平台开发进程加载器;这只是一个娱乐项目。基本上,我想手动将可执行文件的所有部分加载到内存中,然后执行它。
大约一周前,我在这里问了一个相关但更具体的问题。然而,在阅读更多之后,我意识到在我学会如何实际创建进程之前,内存映射是无关紧要的。所以我的问题是,有没有办法在 Linux 上创建一个具有自己的虚拟地址空间的“空白”新进程(我将能够访问它以加载代码和数据)?
即使是关于进程加载器开发的一般资源也会很有用,因为我还没有找到任何资源。
我正在为 C++ 中的 Linux 平台开发进程加载器;这只是一个娱乐项目。基本上,我想手动将可执行文件的所有部分加载到内存中,然后执行它。
大约一周前,我在这里问了一个相关但更具体的问题。然而,在阅读更多之后,我意识到在我学会如何实际创建进程之前,内存映射是无关紧要的。所以我的问题是,有没有办法在 Linux 上创建一个具有自己的虚拟地址空间的“空白”新进程(我将能够访问它以加载代码和数据)?
即使是关于进程加载器开发的一般资源也会很有用,因为我还没有找到任何资源。
如果您有兴趣了解 Linux 进程加载器在您请求exec()
某事时在幕后的真正作用,请获取内核源代码的副本并在里面fs/exec.c
查找do_execve_common()
.
如果您尝试运行 ELF 二进制文件,ELF 处理程序本身最终会被调用,它位于fs/binfmt_elf.c
. 特别是,load_elf_binary()
实际加载是否struct linux_binprm
包含从磁盘加载过程映像所需的信息。
binfmt_*.c
请注意,Linux 支持的二进制格式有很多文件;如果您有自定义二进制格式,那么原则上您可以编写自己的格式并将其作为内核模块提供。进程加载的内部对用户模式代码是不透明的(这是理所当然的:如果不这样,就会存在严重的安全漏洞)。
您可以使用 fork() 函数创建一个新进程,该进程将创建父进程的副本,然后使用exec系列函数之一,您可以加载可执行文件并执行它。