Linux 进程加载程序在 C++
Linux process loader in C++
我正在为C++的Linux平台开发一个进程加载器;这只是一个娱乐项目。基本上,我想手动将可执行文件的所有部分加载到内存中,然后执行它。
大约一周前,我在这里问了一个相关但更具体的问题。然而,在阅读了更多内容后,我意识到在我学习如何实际创建该过程之前,内存映射将无关紧要。所以我的问题是,有没有办法在 Linux 上创建一个具有自己的虚拟地址空间的"空白"新进程(我将能够访问该进程以加载代码和数据)?
即使是关于流程加载器开发的一般资源也会很有用,因为我还没有找到任何资源。
如果您有兴趣了解 Linux 进程加载程序在要求您exec()
某些内容时在幕后真正在做什么,请获取内核源代码的副本并在fs/exec.c
内部查看do_execve_common()
。
ELF 处理程序本身(如果您尝试运行 ELF 二进制文件,最终会被调用)位于 fs/binfmt_elf.c
中。特别是,load_elf_binary()
给定一个包含从磁盘加载过程映像所需信息的struct linux_binprm
,实际加载。
请注意,Linux 支持的二进制格式有许多binfmt_*.c
文件;如果您有自定义二进制格式,那么原则上您可以编写自己的文件并将其作为内核模块提供。进程加载的内部对用户模式代码是不透明的(这是理所当然的:否则将存在严重的安全漏洞)。
您可以使用fork()函数创建一个新进程,该进程将创建父进程的副本,然后使用exec系列函数之一,您可以加载可执行文件并执行它。
相关文章:
- Mongodb c++驱动程序:如何查询元素的数组
- C++,系统无法执行指定的程序
- 在C++程序中输入的文本文件将不起作用,除非文本被复制和粘贴
- 在VS代码中交叉编译Windows与Linux上的MinGW的SDL程序
- C++ Windows 驱动程序MSB3030无法复制该文件,因为它找不到
- 重载操作程序时出错>>用于类中的字符串 memebr
- 获取日期异步信号安全吗?如果在信号处理程序中使用,它会导致死锁吗
- 试图在visual studio上用C++创建一个桌面应用程序
- 模板元程序查找相似的连续类型名称
- FFmpeg:制作一个应用程序比直接使用ffmepg更好吗
- 如何通过cpp程序运行shell脚本
- 有没有什么方法可以使用一个函数中定义的常量变量,也可以由c++中同一程序中的其他函数使用
- IPC使用多个管道和分支进程来运行Python程序
- 如何将c++程序的一些输出传递给shell,以便在shell中使用
- 使用C++程序合并排序没有得到正确的输出
- 基于boost的程序的静态链接——zlib问题
- 程序崩溃并显示"std::out_of_range"错误
- 在C应用程序中运行C++(带有STL)函数
- 使用mongocxx驱动程序时包含头文件问题
- 如何在c++程序中找到函数的地址