我正在Linux下编写一个简单的用户空间ELF加载器(为什么?为了“好玩”)。目前我的加载器非常简单,只加载包含位置无关代码的静态链接的ELF文件。
通常,当一个程序被内核的ELF加载程序加载时,它被加载到它自己的地址空间中。这样,数据段和代码段可以加载到ELF段中指定的正确虚拟地址。
然而,在我的例子中,我通过mmap
向内核请求地址,可能会也可能得不到在ELF段中请求的地址。这对于代码段来说不是问题,因为它与位置无关。但是,如果数据段未加载到预期地址,代码将无法正确引用存储在数据段中的任何内容。
实际上,我的加载器似乎可以很好地处理不包含任何数据的简单程序集可执行文件。但是一旦我添加一个数据段并引用它,可执行文件就无法正确运行或SEGFAULT。
如果可能,我如何修复对数据段的任何引用以指向正确的位置?是否在(静态) ELF文件中存储了用于此目的的重定位部分?
https://stackoverflow.com/questions/1349120
复制相似问题