C语言中的Linux进程加载器

  

我正在为C语言中的Linux平台开发进程加载器;这只是一个娱乐项目.基本上,我想将可执行文件的所有部分手动加载到内存中,然后执行它.

大约一周前,我问了一个相关但更具体的问题here.但是,经过更多阅读之后,我意识到内存映射将是无关紧要的,直到我学习如何实际创建该过程为止.所以我的问题是,是否有一种方法可以在Linux上使用其自己的虚拟地址空间(我将能够访问它来加载代码和数据)创建“空白”新进程?

甚至有关过程加载器开发的一般资源也将很有用,因为我还没有找到任何资源.

解决方法:

如果您有兴趣在要求它执行exec()某些操作时查看Linux进程加载程序在幕后的真正作用,请获取内核源代码的副本,并在fs / exec.c中查找do_execve_common().

ELF处理程序本身位于fs / binfmt_elf.c中,如果您尝试运行ELF二进制文件,则最终会被调用.特别是,在给定struct linux_binprm包含给定的信息以从磁盘装载过程映像的结构linux_binprm的情况下,load_elf_binary()会进行实际装载.

请注意,Linux支持的二进制格式有很多binfmt _ *.c文件.如果您具有自定义的二进制格式,则原则上可以编写自己的二进制格式并将其作为内核模块提供.进程加载的内部对于用户模式代码是不透明的(正确的做法是:如果不存在,将存在严重的安全漏洞).

相关文章