首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >加载时ELF重定位

加载时ELF重定位
EN

Stack Overflow用户
提问于 2009-08-28 20:17:15
回答 2查看 5.2K关注 0票数 21

我正在Linux下编写一个简单的用户空间ELF加载器(为什么?为了“好玩”)。目前我的加载器非常简单,只加载包含位置无关代码的静态链接的ELF文件。

通常,当一个程序被内核的ELF加载程序加载时,它被加载到它自己的地址空间中。这样,数据段和代码段可以加载到ELF段中指定的正确虚拟地址。

然而,在我的例子中,我通过mmap向内核请求地址,可能会也可能得不到在ELF段中请求的地址。这对于代码段来说不是问题,因为它与位置无关。但是,如果数据段未加载到预期地址,代码将无法正确引用存储在数据段中的任何内容。

实际上,我的加载器似乎可以很好地处理不包含任何数据的简单程序集可执行文件。但是一旦我添加一个数据段并引用它,可执行文件就无法正确运行或SEGFAULT。

如果可能,我如何修复对数据段的任何引用以指向正确的位置?是否在(静态) ELF文件中存储了用于此目的的重定位部分?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2009-09-30 08:35:38

如果您修改了.got部分中可用的绝对地址(全局偏移表),那么您的程序应该可以工作。确保修改绝对地址计算,以适应.text和.data之间的新距离,恐怕您需要弄清楚此信息从何而来,为您的架构。

看看这个:Global Offset Table (Processor-Specific)

祝好运。

票数 8
EN

Stack Overflow用户

发布于 2009-09-06 12:52:22

我认为没有任何方法可以做到这一点,除非您完全模拟内核提供的虚拟地址空间,并在该虚拟空间中运行代码。当您映射文件中的数据部分时,本质上是将其重新定位到ELF解释器的虚拟地址空间的未知地址,并且您的代码将无法以任何方式引用它。

很高兴被证明是错的。在这里可以学到一些很酷的东西。

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/1349120

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档